X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F060_basic_deferred.t;h=c8bbe33bd7ef6a2b0a1ed9b7ea755167892506de;hb=f5f21f1d7a779ab86ca5981ae3e716effd8325ca;hp=cec3ab3aa67f4de7013f8dfbe335c4f2bca4abd1;hpb=cfee09ad9535c50ee223c90fb34afd9667866bcb;p=gitmo%2FMooseX-Storage.git diff --git a/t/060_basic_deferred.t b/t/060_basic_deferred.t index cec3ab3..c8bbe33 100644 --- a/t/060_basic_deferred.t +++ b/t/060_basic_deferred.t @@ -1,4 +1,5 @@ #!/usr/bin/perl + $|++; use strict; use warnings; @@ -7,12 +8,18 @@ use Test::More; use Storable; BEGIN { - eval "use Test::JSON; use Test::YAML::Valid;"; - plan skip_all => "Test::JSON and Test::YAML::Valid are required for this test" if $@; - plan tests => 33; + eval "use Test::JSON"; + plan skip_all => "Test::JSON is required for this test" if $@; + eval "use JSON::Any"; + plan skip_all => "JSON::Any is required for this test" if $@; + eval "use YAML::Any"; + plan skip_all => "YAML::Any is required for this test" if $@; + plan tests => 31; use_ok('MooseX::Storage'); } +diag('Using implementation: ', YAML::Any->implementation); + { package Foo; @@ -150,94 +157,21 @@ BEGIN { my $yaml = $foo->freeze({ 'format' => 'YAML' }); - yaml_string_ok( $yaml, '... we got valid YAML out of it' ); - - is( - $yaml, - q{--- -__CLASS__: Foo -array: - - 1 - - 2 - - 3 - - 4 - - 5 - - 6 - - 7 - - 8 - - 9 - - 10 -float: 10.5 -hash: - 1: ~ - 10: ~ - 2: ~ - 3: ~ - 4: ~ - 5: ~ - 6: ~ - 7: ~ - 8: ~ - 9: ~ -number: 10 -object: - __CLASS__: Foo - number: 2 -string: foo -}, - '... got the same YAML' - ); - -} + my $bar = Foo->thaw( $yaml, { 'format' => 'YAML' } ); + isa_ok( $bar, 'Foo' ); -{ - my $foo = Foo->thaw( - q{--- -__CLASS__: Foo -array: - - 1 - - 2 - - 3 - - 4 - - 5 - - 6 - - 7 - - 8 - - 9 - - 10 -float: 10.5 -hash: - 1: ~ - 10: ~ - 2: ~ - 3: ~ - 4: ~ - 5: ~ - 6: ~ - 7: ~ - 8: ~ - 9: ~ -number: 10 -object: - __CLASS__: Foo - number: 2 -string: foo -}, { 'format' => 'YAML' } - ); - isa_ok( $foo, 'Foo' ); - - is( $foo->number, 10, '... got the right number' ); - is( $foo->string, 'foo', '... got the right string' ); - is( $foo->float, 10.5, '... got the right float' ); - is_deeply( $foo->array, [ 1 .. 10 ], '... got the right array' ); + is( $bar->number, 10, '... got the right number' ); + is( $bar->string, 'foo', '... got the right string' ); + is( $bar->float, 10.5, '... got the right float' ); + is_deeply( $bar->array, [ 1 .. 10 ], '... got the right array' ); is_deeply( - $foo->hash, + $bar->hash, { map { $_ => undef } ( 1 .. 10 ) }, '... got the right hash' ); - isa_ok( $foo->object, 'Foo' ); - is( $foo->object->number, 2, + isa_ok( $bar->object, 'Foo' ); + is( $bar->object->number, 2, '... got the right number (in the embedded object)' ); }