Test::Deep is already required; use it instead of is_deeply
[gitmo/MooseX-Storage.git] / t / 002_basic_io.t
index 971261b..7aacd30 100644 (file)
@@ -4,10 +4,18 @@ use strict;
 use warnings;
 
 use Test::More;
+use Test::Deep;
+use File::Temp qw(tempdir);
 
-BEGIN {        
-    eval "use JSON::Any";
-    plan skip_all => "JSON::Any is required for this test" if $@;            
+use File::Spec::Functions;
+
+my $dir = tempdir;
+
+use Test::Requires {
+    'JSON::Any' => 0.01, # skip all if not installed
+};
+
+BEGIN {
     plan tests => 10;
     use_ok('MooseX::Storage');
 }
@@ -30,7 +38,7 @@ BEGIN {
        has 'object' => (is => 'ro', isa => 'Object');    
 }
 
-my $file = 'temp.json';
+my $file = catfile($dir, 'temp.json');
 
 {
     my $foo = Foo->new(
@@ -53,11 +61,10 @@ my $file = 'temp.json';
     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_deeply($foo->hash, { map { $_ => undef } (1 .. 10) }, '... got the right hash');
+    cmp_deeply($foo->array, [ 1 .. 10], '... got the right array');
+    cmp_deeply($foo->hash, { map { $_ => undef } (1 .. 10) }, '... got the right hash');
 
     isa_ok($foo->object, 'Foo');
     is($foo->object->number, 2, '... got the right number (in the embedded object)');
 }
 
-unlink $file;