--- trunk/t/4-store.t 2005/12/05 17:48:00 218 +++ trunk/t/4-store.t 2006/09/26 12:42:49 713 @@ -1,6 +1,6 @@ #!/usr/bin/perl -w -use Test::More tests => 31; +use Test::More tests => 37; use Test::Exception; use Cwd qw/abs_path/; use blib; @@ -17,8 +17,9 @@ diag "abs_path: $abs_path"; my $db; -my $debug = 1; +my $debug = shift @ARGV; my $no_log = 1; # force no log output +$no_log = 0 if ($debug); diag "NULL Store"; @@ -26,15 +27,15 @@ throws_ok { new WebPAC::Store( path => '/tmp' ) } qr/database/, 'new without database'; -ok($db = new WebPAC::Store( path => '/tmp', database => '.', debug => $debug ), "new"); +ok($db = new WebPAC::Store( path => '/tmp', database => 'foobar', debug => $debug ), "new"); -ok(! $db->path, "path"); +cmp_ok($db->path, 'eq', '/tmp', "path"); -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; @@ -42,9 +43,10 @@ diag "Store path: $path"; -ok($db = new WebPAC::Store( path => $path, database => '.', debug => $debug, no_log => $no_log ), "new"); +ok($db = new WebPAC::Store( path => $path, database => 'webpac-test', debug => $debug, no_log => $no_log ), "new"); cmp_ok($db->{'path'}, 'eq', $path, "path"); +cmp_ok($db->path, 'eq', $path, "path"); ok(! $db->path(''), "path - disable caching"); @@ -89,11 +91,25 @@ ok(! $db->load_ds( id => 42 ), "load_ds non-existing"); -ok($db = new WebPAC::Store( path => $path, database => '.', debug => $debug, no_log => $no_log ), "new"); +ok($db = new WebPAC::Store( path => $path, database => 'webpac-test', debug => $debug, no_log => $no_log ), "new"); -ok(! $db->load_ds( id => 1, prefix => 'foobar' ), "load_ds with invalid prefix"); +ok(! $db->load_ds( id => 1, input => 'foobar' ), "load_ds with invalid input"); -ok($ds2 = $db->load_ds( id => 1, database => '.' ), "load_ds"); +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"); + +my $l = { + foo => { 42 => 1 }, +}; + +ok($db->save_lookup( input => 'foo', key => 'bar', data => $l ), "save_lookup"); + +ok(-e $db->path . '/lookup/webpac-test/foo/bar', "exists"); + +ok($db->save_lookup( database => 'baz', input => 'foo', key => 'bar', data => $l ), "save_lookup with database"); + +ok(-e $db->path . '/lookup/baz/foo/bar', "exists"); undef $db;