X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=t%2F4-store.t;h=43629a003b302c5328b2388098a346693dac7da5;hb=5f5d44c525baf7d887f809f4281f208da33ac846;hp=3ea803df17f5b5a56d0224bd5aca00da439e4bf2;hpb=b3f778f66bb2d0e533aa1ba7cce3f87d8b74e89b;p=webpac2 diff --git a/t/4-store.t b/t/4-store.t index 3ea803d..43629a0 100755 --- a/t/4-store.t +++ b/t/4-store.t @@ -1,56 +1,40 @@ #!/usr/bin/perl -w -use Test::More tests => 25; -use Test::Exception; -use Cwd qw/abs_path/; +use strict; use blib; + +use Test::More tests => 38; + use File::Temp qw/tempdir/; -use strict; -use Data::Dumper; BEGIN { +use_ok( 'WebPAC::Test' ); use_ok( 'WebPAC::Store' ); } -ok(my $abs_path = abs_path($0), "abs_path"); -$abs_path =~ s#/[^/]*$#/#; -diag "abs_path: $abs_path"; - my $db; -my $debug = 1; -my $no_log = 1; # force no log output diag "NULL Store"; -ok($db = new WebPAC::Store( debug => $debug, ), "new"); +ok(new WebPAC::Store(), 'new without database'); -ok(! $db->path, "path"); +ok($db = new WebPAC::Store({ database => 'foobar', %LOG }), "new"); -ok(! $db->load_ds(), 'load_ds'); +throws_ok { $db->load_ds() } qr/id/, 'load_ds without id'; ok(! $db->load_ds( id => 000 ), 'load_ds'); -ok(! $db->save_ds(), "save_ds"); -ok(! $db->save_ds( id => 000 ), 'save_ds'); +throws_ok { $db->save_ds() } qr/id/, "save_ds without id"; +throws_ok { $db->save_ds( id => 000 ) } qr/ds/, 'save_ds without ds'; undef $db; -ok(my $path = tempdir( CLEANUP => 1 ), "path"); - -diag "Store path: $path"; - -ok($db = new WebPAC::Store( path => $path, debug => $debug, no_log => $no_log ), "new"); - -cmp_ok($db->{'path'}, 'eq', $path, "path"); - -ok(! $db->path(''), "path - disable caching"); +ok($db = new WebPAC::Store({ database => 'webpac-test', %LOG }), "new"); -ok(! defined($db->{'path'}), "no path"); +# +# test *_ds +# -ok($db->path( $path ), "path($path)"); - -cmp_ok($db->{'path'}, 'eq', $path, "path"); - -ok(! $db->load_ds(), 'load_ds'); +throws_ok { $db->load_ds() } qr/without id/, 'load_ds without arguments'; ok(! $db->load_ds( id => 000 ), 'load_ds'); throws_ok { $db->save_ds() } qr/id/, "save_ds - need id"; @@ -77,11 +61,66 @@ ok(my $ds2 = $db->load_ds( id => 1 ), "load_ds with id"); is_deeply($ds, $ds2, "loaded data"); -ok($ds2 = $db->load_ds( 1 ), "load_ds without id"); +throws_ok { $ds2 = $db->load_ds( 1 ) } qr/HASH/, "load_ds without hash"; + +ok($ds2 = $db->load_ds( id => 1 ), "load_ds"); is_deeply($ds, $ds2, "loaded data"); ok(! $db->load_ds( id => 42 ), "load_ds non-existing"); +ok($db = new WebPAC::Store({ database => 'webpac-test', %LOG }), "new"); + +ok(! $db->load_ds( id => 1, input => 'foobar' ), "load_ds with invalid input"); + +ok(! $db->load_ds( id => 1, database => 'non-existant', ), "load_ds with unknown database"); + +ok($ds2 = $db->load_ds( id => 1, database => 'webpac-test' ), "load_ds"); + +# +# test *_lookup +# + +my $l = { + foo => { 42 => 1 }, +}; + +ok(! $db->load_lookup( input => 'non-existant', key => 'foo' ), 'invalid load_lookup'); + +ok($db->save_lookup( input => 'foo', key => 'bar', data => $l ), "save_lookup"); + +ok(-e $db->var_path( 'lookup', 'webpac-test', 'foo', 'bar'), "exists"); + +is_deeply($db->load_lookup( input => 'foo', key => 'bar' ), $l, 'load_lookup'); + +ok($db->save_lookup( database => 'baz', input => 'foo', key => 'bar', data => $l ), "save_lookup with database"); + +ok(-e $db->var_path( '/lookup','baz','foo','bar'), "exists"); + +is_deeply($db->load_lookup( database => 'baz', input => 'foo', key => 'bar' ), $l, 'load_lookup'); + +# +# test *_row +# + +my $row = { + '000' => [ 42 ], + '900' => [ qw/a foo b bar c baz/ ], +}; + +ok(! $db->load_row( input => 'non-existant', id => 1234 ), 'invalid load_row'); + +ok($db->save_row( input => 'foo', id => 1234, row => $row ), "save_row"); + +ok(-e $db->var_path( 'row','webpac-test','foo',1234), "exists"); + +is_deeply($db->load_row( input => 'foo', id => 1234 ), $row, 'load_row'); + +ok($db->save_row( database => 'baz', input => 'foo', id => 1234, row => $row ), "save_row with database"); + +ok(-e $db->var_path( 'row','baz','foo',1234), "exists"); + +is_deeply($db->load_row( database => 'baz', input => 'foo', id => 1234 ), $row, 'load_row'); + undef $db;