diff options
author | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2005-06-14 12:06:40 +0000 |
---|---|---|
committer | Rafael Garcia-Suarez <rgarciasuarez@gmail.com> | 2005-06-14 12:06:40 +0000 |
commit | 8d0ec8cffad6f81a95e1fb954a5337910142389f (patch) | |
tree | 5787169cecd08a3c4fff12eda4c440ab967099bf /lib/IO/Zlib | |
parent | 94f3782b3e86f250f6fc117b09530d4c0ddac4ef (diff) | |
download | perl-8d0ec8cffad6f81a95e1fb954a5337910142389f.tar.gz |
Add IO::Zlib 1.04 to bleadperl
p4raw-id: //depot/perl@24834
Diffstat (limited to 'lib/IO/Zlib')
-rw-r--r-- | lib/IO/Zlib/t/basic.t | 42 | ||||
-rw-r--r-- | lib/IO/Zlib/t/external.t | 141 | ||||
-rw-r--r-- | lib/IO/Zlib/t/getc.t | 32 | ||||
-rw-r--r-- | lib/IO/Zlib/t/getline.t | 53 | ||||
-rw-r--r-- | lib/IO/Zlib/t/import.t | 13 | ||||
-rw-r--r-- | lib/IO/Zlib/t/large.t | 35 | ||||
-rw-r--r-- | lib/IO/Zlib/t/tied.t | 37 | ||||
-rw-r--r-- | lib/IO/Zlib/t/uncomp1.t | 45 | ||||
-rw-r--r-- | lib/IO/Zlib/t/uncomp2.t | 45 |
9 files changed, 443 insertions, 0 deletions
diff --git a/lib/IO/Zlib/t/basic.t b/lib/IO/Zlib/t/basic.t new file mode 100644 index 0000000000..49571317e5 --- /dev/null +++ b/lib/IO/Zlib/t/basic.t @@ -0,0 +1,42 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +$name="test.gz"; + +print "1..15\n"; + +$hello = <<EOM ; +hello world +this is a test +EOM + +ok(1, $file = IO::Zlib->new($name, "wb")); +ok(2, $file->print($hello)); +ok(3, $file->opened()); +ok(4, $file->close()); +ok(5, !$file->opened()); + +ok(6, $file = IO::Zlib->new()); +ok(7, $file->open($name, "rb")); +ok(8, !$file->eof()); +ok(9, $file->read($uncomp, 1024) == length($hello)); +ok(10, $file->eof()); +ok(11, $file->opened()); +ok(12, $file->close()); +ok(13, !$file->opened()); + +unlink($name); + +ok(14, $hello eq $uncomp); + +ok(15, !defined(IO::Zlib->new($name, "rb"))); diff --git a/lib/IO/Zlib/t/external.t b/lib/IO/Zlib/t/external.t new file mode 100644 index 0000000000..13ac306d35 --- /dev/null +++ b/lib/IO/Zlib/t/external.t @@ -0,0 +1,141 @@ +# Test this only iff we have an executable /usr/bin/gzip +# AND we have /usr/bin in our PATH +# AND we have a useable /usr/bin directory. +# This limits the testing to UNIX-like +# systems but that should be enough. + +my $gzip = "/usr/bin/gzip"; + +unless( -x $gzip && + ":$ENV{PATH}:" =~ m!:/usr/bin:! && + -d "/usr/bin" && -x "/usr/bin") { + print "1..0 # Skip: no $gzip\n"; +} + +sub ok +{ + my ($no, $ok) = @_ ; + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +my $hasCompressZlib; + +BEGIN { + eval { require Compress::Zlib }; + $hasCompressZlib = $@ ? 0 : 1; +} + +use IO::Zlib; + +print "1..33\n"; + +# Other export functionality (none) is tested in import.t. + +ok(1, + $hasCompressZlib == IO::Zlib::has_Compress_Zlib()); + +eval "use IO::Zlib qw(:gzip_external)"; +ok(2, + $@ =~ /^IO::Zlib::import: ':gzip_external' requires an argument /); + +eval "use IO::Zlib"; +ok(3, !$@); + +ok(4, + $hasCompressZlib || IO::Zlib::gzip_used()); + +ok(5, + !defined IO::Zlib::gzip_external()); + +ok(6, + IO::Zlib::gzip_read_open() eq 'gzip -dc %s |'); + +ok(7, + IO::Zlib::gzip_write_open() eq '| gzip > %s'); + +ok(8, + ($hasCompressZlib && \&IO::Zlib::gzopen == \&Compress::Zlib::gzopen) || + \&IO::Zlib::gzopen == \&IO::Zlib::gzopen_external); + +eval "use IO::Zlib qw(:gzip_external 0)"; + +ok(9, + !IO::Zlib::gzip_external()); + +ok(10, + ($hasCompressZlib && \&IO::Zlib::gzopen == \&Compress::Zlib::gzopen) || + (!$hasCompressZlib && + $@ =~ /^IO::Zlib::import: no Compress::Zlib and no external gzip /)); + +eval "use IO::Zlib qw(:gzip_external 1)"; + +ok(11, + IO::Zlib::gzip_used()); + +ok(12, + IO::Zlib::gzip_external()); + +ok(13, + \&IO::Zlib::gzopen == \&IO::Zlib::gzopen_external); + +eval 'IO::Zlib->new("foo", "xyz")'; +ok(14, $@ =~ /^IO::Zlib::gzopen_external: mode 'xyz' is illegal /); + +# The following is a copy of the basic.t, shifted up by 14 tests, +# the difference being that now we should be using the external gzip. + +$name="test.gz"; + +$hello = <<EOM ; +hello world +this is a test +EOM + +ok(15, $file = IO::Zlib->new($name, "wb")); +ok(16, $file->print($hello)); +ok(17, $file->opened()); +ok(18, $file->close()); +ok(19, !$file->opened()); + +ok(20, $file = IO::Zlib->new()); +ok(21, $file->open($name, "rb")); +ok(22, !$file->eof()); +ok(23, $file->read($uncomp, 1024) == length($hello)); +ok(24, $file->eof()); +ok(25, $file->opened()); +ok(26, $file->close()); +ok(27, !$file->opened()); + +unlink($name); + +ok(28, $hello eq $uncomp); + +ok(29, !defined(IO::Zlib->new($name, "rb"))); + +# Then finally test modifying the open commands. + +my $new_read = 'gzip.exe /d /c %s |'; + +eval "use IO::Zlib ':gzip_read_open' => '$new_read'"; + +ok(30, + IO::Zlib::gzip_read_open() eq $new_read); + +eval "use IO::Zlib ':gzip_read_open' => 'bad'"; + +ok(31, + $@ =~ /^IO::Zlib::import: ':gzip_read_open' 'bad' is illegal /); + +my $new_write = '| gzip.exe %s'; + +eval "use IO::Zlib ':gzip_write_open' => '$new_write'"; + +ok(32, + IO::Zlib::gzip_write_open() eq $new_write); + +eval "use IO::Zlib ':gzip_write_open' => 'bad'"; + +ok(33, + $@ =~ /^IO::Zlib::import: ':gzip_write_open' 'bad' is illegal /); + diff --git a/lib/IO/Zlib/t/getc.t b/lib/IO/Zlib/t/getc.t new file mode 100644 index 0000000000..2424d5b245 --- /dev/null +++ b/lib/IO/Zlib/t/getc.t @@ -0,0 +1,32 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +$name="test.gz"; + +print "1..10\n"; + +$text = "abcd"; + +ok(1, $file = IO::Zlib->new($name, "wb")); +ok(2, $file->print($text)); +ok(3, $file->close()); + +ok(4, $file = IO::Zlib->new($name, "rb")); +ok(5, $file->getc() eq substr($text,0,1)); +ok(6, $file->getc() eq substr($text,1,1)); +ok(7, $file->getc() eq substr($text,2,1)); +ok(8, $file->getc() eq substr($text,3,1)); +ok(9, $file->getc() eq ""); +ok(10, $file->close()); + +unlink($name); diff --git a/lib/IO/Zlib/t/getline.t b/lib/IO/Zlib/t/getline.t new file mode 100644 index 0000000000..db18088dcd --- /dev/null +++ b/lib/IO/Zlib/t/getline.t @@ -0,0 +1,53 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +$name="test.gz"; + +print "1..19\n"; + +@text = (<<EOM, <<EOM, <<EOM, <<EOM) ; +this is line 1 +EOM +the second line +EOM +the line after the previous line +EOM +the final line +EOM + +$text = join("", @text) ; + +ok(1, $file = IO::Zlib->new($name, "wb")); +ok(2, $file->print($text)); +ok(3, $file->close()); + +ok(4, $file = IO::Zlib->new($name, "rb")); +ok(5, $file->getline() eq $text[0]); +ok(6, $file->getline() eq $text[1]); +ok(7, $file->getline() eq $text[2]); +ok(8, $file->getline() eq $text[3]); +ok(9, !defined($file->getline())); +ok(10, $file->close()); + +ok(11, $file = IO::Zlib->new($name, "rb")); +eval '$file->getlines'; +ok(12, $@ =~ /^IO::Zlib::getlines: must be called in list context /); +ok(13, @lines = $file->getlines()); +ok(14, @lines == @text); +ok(15, $lines[0] eq $text[0]); +ok(16, $lines[1] eq $text[1]); +ok(17, $lines[2] eq $text[2]); +ok(18, $lines[3] eq $text[3]); +ok(19, $file->close()); + +unlink($name); diff --git a/lib/IO/Zlib/t/import.t b/lib/IO/Zlib/t/import.t new file mode 100644 index 0000000000..336d80a943 --- /dev/null +++ b/lib/IO/Zlib/t/import.t @@ -0,0 +1,13 @@ +print "1..1\n"; + +sub ok +{ + my ($no, $ok) = @_ ; + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +# The :gzip tags are tested in external.t. + +eval "use IO::Zlib qw(foo bar)"; +ok(1, $@ =~ /^IO::Zlib::import: 'foo bar' is illegal /); diff --git a/lib/IO/Zlib/t/large.t b/lib/IO/Zlib/t/large.t new file mode 100644 index 0000000000..0203182004 --- /dev/null +++ b/lib/IO/Zlib/t/large.t @@ -0,0 +1,35 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +$name="test.gz"; + +print "1..7\n"; + +$contents = ""; + +foreach (1 .. 5000) +{ + $contents .= chr(int(rand(255))); +} + +ok(1, $file = IO::Zlib->new($name, "wb")); +ok(2, $file->print($contents)); +ok(3, $file->close()); + +ok(4, $file = IO::Zlib->new($name, "rb")); +ok(5, $file->read($uncomp, 8192) == length($contents)); +ok(6, $file->close()); + +unlink($name); + +ok(7, $contents eq $uncomp); diff --git a/lib/IO/Zlib/t/tied.t b/lib/IO/Zlib/t/tied.t new file mode 100644 index 0000000000..029b282721 --- /dev/null +++ b/lib/IO/Zlib/t/tied.t @@ -0,0 +1,37 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +$name="test.gz"; + +print "1..11\n"; + +$hello = <<EOM ; +hello world +this is a test +EOM + +ok(1, tie *OUT, "IO::Zlib", $name, "wb"); +ok(2, printf OUT "%s - %d\n", "hello", 123); +ok(3, print OUT $hello); +ok(4, untie *OUT); + +ok(5, tie *IN, "IO::Zlib", $name, "rb"); +ok(6, !eof IN); +ok(7, <IN> eq "hello - 123\n"); +ok(8, read(IN, $uncomp, 1024) == length($hello)); +ok(9, eof IN); +ok(10, untie *IN); + +unlink($name); + +ok(11, $hello eq $uncomp); diff --git a/lib/IO/Zlib/t/uncomp1.t b/lib/IO/Zlib/t/uncomp1.t new file mode 100644 index 0000000000..7e580ad032 --- /dev/null +++ b/lib/IO/Zlib/t/uncomp1.t @@ -0,0 +1,45 @@ +use IO::Zlib; + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +print "1..10\n"; + +$hello = <<EOM ; +hello world +this is a test +EOM + +$name = "test"; + +if (open(FH, ">$name")) { + binmode FH; + print FH $hello; + close FH; +} else { + die "$name: $!"; +} + +ok(1, $file = IO::Zlib->new()); +ok(2, $file->open($name, "rb")); +ok(3, !$file->eof()); +ok(4, $file->read($uncomp, 1024) == length($hello)); +ok(5, $file->eof()); +ok(6, $file->opened()); +ok(7, $file->close()); +ok(8, !$file->opened()); + +unlink($name); + +ok(9, $hello eq $uncomp); + +ok(10, !defined(IO::Zlib->new($name, "rb"))); + diff --git a/lib/IO/Zlib/t/uncomp2.t b/lib/IO/Zlib/t/uncomp2.t new file mode 100644 index 0000000000..979900dc49 --- /dev/null +++ b/lib/IO/Zlib/t/uncomp2.t @@ -0,0 +1,45 @@ +require IO::Zlib; # uncomp2.t is like uncomp1.t but without 'use' + +sub ok +{ + my ($no, $ok) = @_ ; + + #++ $total ; + #++ $totalBad unless $ok ; + + print "ok $no\n" if $ok ; + print "not ok $no\n" unless $ok ; +} + +print "1..10\n"; + +$hello = <<EOM ; +hello world +this is a test +EOM + +$name = "test"; + +if (open(FH, ">$name")) { + binmode FH; + print FH $hello; + close FH; +} else { + die "$name: $!"; +} + +ok(1, $file = IO::Zlib->new()); +ok(2, $file->open($name, "rb")); +ok(3, !$file->eof()); +ok(4, $file->read($uncomp, 1024) == length($hello)); +ok(5, $file->eof()); +ok(6, $file->opened()); +ok(7, $file->close()); +ok(8, !$file->opened()); + +unlink($name); + +ok(9, $hello eq $uncomp); + +ok(10, !defined(IO::Zlib->new($name, "rb"))); + |