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=75c36a9bf66bfc734fb854d6f0689793787409db;hpb=1f3074ea2b80c4c8dfc081414f87285bc7892c82;p=gitmo%2FMooseX-Storage.git diff --git a/t/060_basic_deferred.t b/t/060_basic_deferred.t index 75c36a9..c8bbe33 100644 --- a/t/060_basic_deferred.t +++ b/t/060_basic_deferred.t @@ -1,18 +1,25 @@ #!/usr/bin/perl + $|++; use strict; use warnings; -use Test::More tests => 33; +use Test::More; use Storable; -use Test::JSON; -use Test::YAML::Valid; BEGIN { - $ENV{JSON_ANY_ORDER} = qw(JSON); + 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)' ); }