Run author side tests always
[gitmo/MooseX-Storage.git] / t / 100_io.t
index fc5d0f5..b1e1504 100644 (file)
@@ -4,11 +4,14 @@ use strict;
 use warnings;
 
 use Test::More;
+use Test::TempDir;
+use File::Spec::Functions;
+my $dir = tempdir;
 
-BEGIN {  
+BEGIN {
     eval "use JSON::Any";
-    plan skip_all => "JSON::Any is required for this test" if $@;         
-    plan tests => 10;    
+    plan skip_all => "JSON::Any is required for this test" if $@;
+    plan tests => 10;
     use_ok('MooseX::Storage');
 }
 
@@ -16,18 +19,18 @@ BEGIN {
     package Foo;
     use Moose;
     use MooseX::Storage;
-    
+
     with Storage(format => 'JSON', io => 'File');
-    
+
     has 'number' => (is => 'ro', isa => 'Int');
     has 'string' => (is => 'ro', isa => 'Str');
-    has 'float'  => (is => 'ro', isa => 'Num');        
+    has 'float'  => (is => 'ro', isa => 'Num');
     has 'array'  => (is => 'ro', isa => 'ArrayRef');
-    has 'hash'   => (is => 'ro', isa => 'HashRef');    
-       has 'object' => (is => 'ro', isa => 'Object');    
+    has 'hash'   => (is => 'ro', isa => 'HashRef');
+       has 'object' => (is => 'ro', isa => 'Object');
 }
 
-my $file = 'temp.json';
+my $file = catfile( $dir, 'temp.json' );
 
 {
     my $foo = Foo->new(
@@ -57,4 +60,3 @@ my $file = 'temp.json';
     is($foo->object->number, 2, '... got the right number (in the embedded object)');
 }
 
-unlink $file;