X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F101_io_atomic.t;h=cdc9320e269d33e529563994a87917d6f27b89a3;hb=8725bb5d7fbdf359440b192c53f23f7b9b36b73e;hp=20e0aa54aae32b436e3c2aaf28d6ec2da416f756;hpb=8d8356bb0a96c1c4e909b56c812b16fc82c7bbd2;p=gitmo%2FMooseX-Storage.git diff --git a/t/101_io_atomic.t b/t/101_io_atomic.t index 20e0aa5..cdc9320 100644 --- a/t/101_io_atomic.t +++ b/t/101_io_atomic.t @@ -1,13 +1,18 @@ -#!/usr/bin/perl - use strict; use warnings; use Test::More; +use Test::Deep; +use File::Temp qw(tempdir); +use File::Spec::Functions; +my $dir = tempdir( CLEANUP => 1 ); + +use Test::Requires { + 'JSON::Any' => 0.01, # skip all if not installed + 'IO::AtomicFile' => 0.01, +}; BEGIN { - eval "use IO::AtomicFile"; - plan skip_all => "IO::AtomicFile is required for this test" if $@; plan tests => 10; use_ok('MooseX::Storage'); } @@ -16,18 +21,18 @@ BEGIN { package Foo; use Moose; use MooseX::Storage; - + with Storage(format => 'JSON', io => 'AtomicFile'); - + 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( @@ -36,7 +41,7 @@ my $file = 'temp.json'; float => 10.5, array => [ 1 .. 10 ], hash => { map { $_ => undef } (1 .. 10) }, - object => Foo->new( number => 2 ), + object => Foo->new( number => 2 ), ); isa_ok($foo, 'Foo'); @@ -50,11 +55,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;