- added clean parametar to stores to start with empty database
[perl-cwmp.git] / t / 05-store.t
index fb42380..6e315a3 100755 (executable)
@@ -4,7 +4,7 @@ use warnings;
 
 my $debug = shift @ARGV;
 
-use Test::More tests => 18;
+use Test::More tests => 34;
 use Data::Dump qw/dump/;
 use Cwd qw/abs_path/;
 use lib 'lib';
@@ -12,6 +12,7 @@ use lib 'lib';
 BEGIN {
        use_ok('CWMP::Store');
        use_ok('CWMP::Store::DBMDeep');
+       use_ok('CWMP::Store::YAML');
 }
 
 ok(my $abs_path = abs_path($0), "abs_path");
@@ -19,48 +20,58 @@ $abs_path =~ s!/[^/]*$!/!;  #!fix-vim
 
 my $path = "$abs_path/var/";
 
-unlink $path if -e $path;
+sub test_store {
+       my $module = shift;
 
-ok( my $store = CWMP::Store->new({
-       debug => $debug,
-#      module => 'DBMDeep',
-       module => 'YAML',
-       path => $path,
-}), 'new' );
-isa_ok( $store, 'CWMP::Store' );
+       diag "testing store plugin $module";
 
-cmp_ok( $store->path, 'eq', $path, 'path' );
+       ok( my $store = CWMP::Store->new({
+               debug => $debug,
+               module => $module,
+               path => $path,
+               clean => 1,
+       }), 'new' );
+       isa_ok( $store, 'CWMP::Store' );
 
-my $state = {
-       foo => 'bar',
-       DeviceID => {
-               SerialNumber => 123456,
-       },
-};
+       cmp_ok( $store->path, 'eq', $path, 'path' );
 
-cmp_ok( $store->ID_to_uid( 42, $state ), 'eq', 123456, 'ID_to_uid' );
+       my $state = {
+               foo => 'bar',
+               DeviceID => {
+                       SerialNumber => 123456,
+               },
+       };
 
-ok( $store->update_state( ID => 42, $state ), 'update_state new' );
+       cmp_ok( $store->ID_to_uid( 42, $state ), 'eq', 123456, 'ID_to_uid' );
 
-ok( my $store_state = $store->state( ID => '42'), 'db->get' );
+       ok( $store->update_state( ID => 42, $state ), 'update_state new' );
 
-is_deeply( $store_state, $state, 'state ID' );
+       ok( my $store_state = $store->get_state( ID => '42'), 'get_state ID' );
 
-ok( $store_state = $store->state( uid =>  123456 ), 'db->get' );
+       is_deeply( $store_state, $state, 'state ID' );
 
-is_deeply( $store_state, $state, 'state uid' );
+       ok( $store_state = $store->get_state( uid =>  123456 ), 'get_state uid' );
 
-ok( $store->update_state( ID => 42, { baz => 12345 } ), 'update_state existing' );
+       is_deeply( $store_state, $state, 'state ID same as uid' );
 
-$state->{baz} = 12345;
+       ok( $store->update_state( ID => 42, { baz => 12345 } ), 'update_state existing' );
 
-is_deeply( $store->state( ID => 42 ), $state, 'store->state ID' );
+       $state->{baz} = 12345;
 
-is_deeply( $store->state( uid => 123456 ), $state, 'store->state uid' );
+       is_deeply( $store->get_state( ID => 42 ), $state, 'get_state ID' );
 
-is_deeply( [ $store->known_CPE ], [ 123456 ], 'known_CPE' );
+       is_deeply( $store->get_state( uid => 123456 ), $state, 'get_state uid' );
 
-ok( $store->update_state( ID => 11, { DeviceID => { SerialNumber => 99999 } } ), 'new device' );
+       is_deeply( [ $store->all_uids ], [ 123456 ], 'all_uids' );
 
-is_deeply( [ $store->known_CPE ], [ 123456, 99999 ], 'known_CPE' );
+       ok( $store->update_state( ID => 11, { DeviceID => { SerialNumber => 99999 } } ), 'new device' );
+
+       is_deeply( [ $store->all_uids ], [ 123456, 99999 ], 'all_uids' );
+
+}
+
+# now test all stores
+
+test_store('DBMDeep');
+test_store('YAML');