/[Search-TokyoDystopia]/t/12-tcj.t
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Annotation of /t/12-tcj.t

Parent Directory Parent Directory | Revision Log Revision Log


Revision 39 - (hide annotations)
Sat Feb 14 17:34:01 2009 UTC (15 years, 2 months ago) by dpavlin
File MIME type: application/x-troff
File size: 2151 byte(s)
tcjdbsearch2 , tcjdbsearch doesn't work
1 dpavlin 37 #!/usr/bin/perl
2    
3     use warnings;
4     use strict;
5    
6     use blib;
7    
8 dpavlin 39 use Test::More tests => 32;
9 dpavlin 37 use Test::Exception;
10     use Data::Dump qw/dump/;
11    
12     BEGIN {
13     use_ok( 'Search::TokyoDystopia' );
14     }
15    
16     my $path = 'casket-jdb';
17    
18     cmp_ok( $Search::TokyoDystopia::debug, '==', 0, '$debug' );
19    
20     cmp_ok( tcjdberrmsg(0), 'eq', 'success', 'tcjdberrmsg' );
21    
22     ok( my $jdb = tcjdbnew, 'tcjdbnew' ); # FIXME check better
23    
24     ok( ! tcjdbdel( $jdb ), 'tcjdbdel' );
25    
26     ok( $jdb = tcjdbnew, 'tcjdbnew again' );
27    
28     is( tcjdbecode( $jdb ), 0, 'tcjdbecode' );
29    
30     ok( tcjdbtune( $jdb, 0, 0, 0, JDBTLARGE | JDBTDEFLATE ), 'tcjdbtune' );
31    
32     ok( tcjdbsetcache( $jdb, 0, 0 ), 'tcjdbsetcache' );
33    
34     ok( tcjdbsetfwmmax( $jdb, 0 ), 'tcjdbsetfwmmax' );
35    
36     ok( tcjdbopen( $jdb, $path, JDBOWRITER | JDBOCREAT | JDBOTRUNC ), "tcjdbopen $path" );
37    
38 dpavlin 38 SKIP: {
39     skip 'close on empty database makes next open segfault', 2;
40 dpavlin 37
41 dpavlin 38 ok( tcjdbclose( $jdb ), 'tcjdbclose' );
42 dpavlin 37
43 dpavlin 38 ok( tcjdbopen( $jdb, $path, JDBOWRITER | JDBOCREAT ), "tcjdbopen $path again" );
44    
45     }
46    
47 dpavlin 37 ok( tcjdbput( $jdb, 1, [ 'foobar' ] ), 'tcjdbput' );
48    
49     ok( tcjdbout( $jdb, 1 ), 'tcjdbout' );
50    
51     ok( tcjdbput( $jdb, 42, [ 'some', 'data' ] ), 'tcjdbput again' );
52    
53     ok( tcjdbput2( $jdb, 99, 'some more data again', ' ' ), 'tcjdbput2' );
54    
55 dpavlin 39 is_deeply( tcjdbsearch( $jdb, 'some', JDBSSUBSTR ), [ 42, 99 ], 'tcjdbsearch' );
56     is_deeply( tcjdbsearch2( $jdb, 'some' ), [ 42, 99 ], 'tcjdbsearch2' );
57 dpavlin 37 ok( tcjdbput( $jdb, 65536, [ 'some', 'more', 'data' ] ), 'tcjdbput more data' );
58 dpavlin 39 is_deeply( tcjdbsearch( $jdb, 'some', JDBSSUBSTR ), [ 42, 99, 65536 ], 'tcjdbsearch' );
59     is_deeply( tcjdbsearch2( $jdb, 'some' ), [ 42, 99, 65536 ], 'tcjdbsearch2' );
60 dpavlin 37
61     ok( tcjdbsync( $jdb ), 'tcjdbsync' );
62    
63     ok( tcjdboptimize( $jdb ), 'tcjdboptimize' );
64    
65     my $copy_path = $path . '-copy';
66    
67     ok( tcjdbcopy( $jdb, $copy_path ), "tcjdbcopy $copy_path" );
68     ok( -e $copy_path, 'copy exists' );
69    
70     is( tcjdbpath( $jdb ), $path, 'tcjdbpath' );
71    
72 dpavlin 38 is( tcjdbrnum( $jdb ), 3, 'tcjdbrnum' );
73 dpavlin 37
74     ok( my $file_size = tcjdbfsiz( $jdb ), 'tcjdbfsiz' );
75    
76     ok( tcjdbvanish( $jdb ), 'tcjdbvanish' );
77    
78     is( tcjdbrnum( $jdb ), 0, 'tcjdbrnum' );
79    
80     cmp_ok( tcjdbfsiz( $jdb ), '<=', $file_size, 'tcjdbfsiz' );
81    
82     diag tcjdberrmsg( tcjdbecode( $jdb ) );

Properties

Name Value
svn:executable *

  ViewVC Help
Powered by ViewVC 1.1.26