/[fuse-comp]/t/fs.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

Diff of /t/fs.t

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 6 by dpavlin, Sun Jul 8 17:03:12 2007 UTC revision 12 by dpavlin, Mon Jul 9 10:35:02 2007 UTC
# Line 4  use warnings; Line 4  use warnings;
4    
5  my $debug = shift @ARGV;  my $debug = shift @ARGV;
6    
7  use Test::More tests => 23;  use Test::More tests => 227;
8    use File::Slurp;
9    use IO::File;
10    
11  my ( $from, $to, $tmp ) = ( '/tmp/comp', '/tmp/no-comp', '/dev/shm' );  my ( $from, $to, $tmp ) = ( '/tmp/comp', '/tmp/no-comp', '/dev/shm/comp' );
12    
13  ok( -e $from, 'from' );  ok( -e $from, 'from' );
14  ok( -e $to, 'to' );  ok( -e $to, 'to' );
15  ok( -e $tmp, 'tmp' );  ok( -e $tmp, 'tmp' );
16    
17    ok( (system "touch $to/.debug") == 0, 'debug on' );
18    
19    sub dump_debug {
20            my $msg = shift;
21            ok( open(my $d, '<', "$to/.debug"), 'open debug' );
22            local $/;
23            my $dump = <$d>;
24            diag "DEBUG: $msg\n$dump\n";
25            ok( close($d), 'close debug' );
26    }
27    
28  sub file {  sub file {
29          my ( $op, $path, $content ) = @_;          my ( $op, $path, $content ) = @_;
30            my $orig_size = -s "$to/$path";
31          ok( open( my $fh, $op, "$to/$path" ), "open( $op $path )");          ok( open( my $fh, $op, "$to/$path" ), "open( $op $path )");
32          if ( $content ) {          if ( $op eq '>' ) {
33                    cmp_ok( -s "$to/$path", '==', 0, "truncate $to/$path" );
34                  print $fh $content;                  print $fh $content;
35          } else {          } elsif ( $op eq '>>' ) {
36                    cmp_ok( -s "$to/$path", '==', $orig_size, "no truncate $to/$path" );
37                    print $fh $content;
38    
39            } elsif ( $op eq '<' ) {
40                    my $orig_content = $content;
41                  local $/;                  local $/;
42                  $content = <$fh>;                  $content = <$fh>;
43                  ok( $content, 'has content' );                  if ( defined( $content ) ) {
44                            cmp_ok( $content, 'eq', $orig_content, "content " . length($content) . " bytes" );
45                    } else {
46                            ok( $content, "has " . length($content) . " bytes" );
47                    }
48            } else {
49                    die "unsupported op: $op";
50          }          }
51            dump_debug 'before close';
52          ok( close($fh), 'close' );          ok( close($fh), 'close' );
53            dump_debug 'after close';
54    
55            ok ( -e "$to/$path", "exists $to/$path" );
56    
57          ok ( -e "$to/$path", 'exists' );          my $pack = "$from/${path}.gz";
58            my $size = length($content);
59    
60            if ( -e $pack ) {
61                    ok( -s $pack, "on disk $pack" ) if ( $size > 0 );
62                    # check uncompressed size if read
63                    ok( -e "$tmp/$path" , "in tmp $tmp/$path" ) if ( $op eq '<' );
64                    # check total size if not append
65                    if ( $op ne '>>' ) {
66                            cmp_ok( -s "$tmp/$path", '==', $size, "$tmp/$path = $size bytes" );
67                    }
68            } else {
69                    ok( -e "$from/$path", "on disk $from/$path" );
70                    cmp_ok( -s "$from/$path", '==', $size, "$from/$path = $size bytes" );
71            }
72    
73          ok( -e "$from/$path" || -e "$from/${path}.gz", 'on disk' );          dump_debug('at end');
74    
75          return $content;          return $content;
76  }  }
77    
78  file( '>', 'foo', 'content' );  my $buff = '<<--just a chunk of data-->>';
79  cmp_ok( file( '<', 'foo' ), 'eq', 'content', 'check content' );  
80    for my $i ( 1 .. 3 ) {
81            my $content = $buff x int(3 + $i * rand(15));
82            $content =~ s/\s+/ /gs;
83    
84            my $file = "test.$i";
85    
86            file( '>', $file, $content );
87            file( '<', $file, $content );
88    
89            file( '>>', $file, '+append' );
90            file( '<', $file, $content . '+append' );
91    
92            file( '>', $file, '' );
93            file( '<', $file, '' );
94    
95    #       file( '>', $file, $content );
96    #       file( '<', $file, $content );
97    
98    }
99    
100    diag "multiple read-write";
101    
102  file( '>>', 'foo', '+more' );  ok( my $fh1 = IO::File->new("> $to/m"), 'open 1' );
103  cmp_ok( file( '<', 'foo' ), 'eq', 'content+more', 'check content' );  $fh1->autoflush;
104    ok( print($fh1 "1.1\n"), 'print 1.1' );
105    ok( my $fh2 = IO::File->new(">> $to/m"), 'open 2' );
106    $fh2->autoflush;
107    ok( print($fh2 "2.1\n"), 'print 2.1' );
108    cmp_ok( read_file("$to/m"), 'eq', "1.1\n2.1\n", 'mixed' );
109    ok( print($fh1 "1.2\n"), 'print 1.2' );
110    cmp_ok( read_file("$to/m"), 'eq', "1.1\n1.2\n", 'just 1' );
111    
 file( '>', 'foo', 'new' );  
 cmp_ok( file( '<', 'foo' ), 'eq', 'new', 'check content' );  

Legend:
Removed from v.6  
changed lines
  Added in v.12

  ViewVC Help
Powered by ViewVC 1.1.26