summaryrefslogtreecommitdiff
path: root/cpan/Tie-File/t/04_splice.t
diff options
context:
space:
mode:
Diffstat (limited to 'cpan/Tie-File/t/04_splice.t')
-rw-r--r--cpan/Tie-File/t/04_splice.t264
1 files changed, 0 insertions, 264 deletions
diff --git a/cpan/Tie-File/t/04_splice.t b/cpan/Tie-File/t/04_splice.t
deleted file mode 100644
index b3880b758c..0000000000
--- a/cpan/Tie-File/t/04_splice.t
+++ /dev/null
@@ -1,264 +0,0 @@
-#!/usr/bin/perl
-
-#
-# Check SPLICE function's effect on the file
-# (07_rv_splice.t checks its return value)
-#
-# Each call to 'check_contents' actually performs two tests.
-# First, it calls the tied object's own 'check_integrity' method,
-# which makes sure that the contents of the read cache and offset tables
-# accurately reflect the contents of the file.
-# Then, it checks the actual contents of the file against the expected
-# contents.
-
-
-$| = 1;
-my $file = "tf$$.txt";
-$: = Tie::File::_default_recsep();
-my $data = "rec0$:rec1$:rec2$:";
-print "1..118\n";
-
-init_file($data);
-
-my $N = 1;
-use Tie::File;
-print "ok $N\n"; $N++; # partial credit just for showing up
-
-my $o = tie @a, 'Tie::File', $file;
-print $o ? "ok $N\n" : "not ok $N\n";
-$N++;
-
-$: = $o->{recsep};
-my $n;
-
-# (3-22) splicing at the beginning
-splice(@a, 0, 0, "rec4");
-check_contents("rec4$:$data");
-splice(@a, 0, 1, "rec5"); # same length
-check_contents("rec5$:$data");
-splice(@a, 0, 1, "record5"); # longer
-check_contents("record5$:$data");
-
-splice(@a, 0, 1, "r5"); # shorter
-check_contents("r5$:$data");
-splice(@a, 0, 1); # removal
-check_contents("$data");
-splice(@a, 0, 0); # no-op
-check_contents("$data");
-splice(@a, 0, 0, 'r7', 'rec8'); # insert more than one
-check_contents("r7$:rec8$:$data");
-splice(@a, 0, 2, 'rec7', 'record8', 'rec9'); # insert more than delete
-check_contents("rec7$:record8$:rec9$:$data");
-
-splice(@a, 0, 3, 'record9', 'rec10'); # delete more than insert
-check_contents("record9$:rec10$:$data");
-splice(@a, 0, 2); # delete more than one
-check_contents("$data");
-
-
-# (23-42) splicing in the middle
-splice(@a, 1, 0, "rec4");
-check_contents("rec0$:rec4$:rec1$:rec2$:");
-splice(@a, 1, 1, "rec5"); # same length
-check_contents("rec0$:rec5$:rec1$:rec2$:");
-splice(@a, 1, 1, "record5"); # longer
-check_contents("rec0$:record5$:rec1$:rec2$:");
-
-splice(@a, 1, 1, "r5"); # shorter
-check_contents("rec0$:r5$:rec1$:rec2$:");
-splice(@a, 1, 1); # removal
-check_contents("$data");
-splice(@a, 1, 0); # no-op
-check_contents("$data");
-splice(@a, 1, 0, 'r7', 'rec8'); # insert more than one
-check_contents("rec0$:r7$:rec8$:rec1$:rec2$:");
-splice(@a, 1, 2, 'rec7', 'record8', 'rec9'); # insert more than delete
-check_contents("rec0$:rec7$:record8$:rec9$:rec1$:rec2$:");
-
-splice(@a, 1, 3, 'record9', 'rec10'); # delete more than insert
-check_contents("rec0$:record9$:rec10$:rec1$:rec2$:");
-splice(@a, 1, 2); # delete more than one
-check_contents("$data");
-
-# (43-62) splicing at the end
-splice(@a, 3, 0, "rec4");
-check_contents("$ {data}rec4$:");
-splice(@a, 3, 1, "rec5"); # same length
-check_contents("$ {data}rec5$:");
-splice(@a, 3, 1, "record5"); # longer
-check_contents("$ {data}record5$:");
-
-splice(@a, 3, 1, "r5"); # shorter
-check_contents("$ {data}r5$:");
-splice(@a, 3, 1); # removal
-check_contents("$data");
-splice(@a, 3, 0); # no-op
-check_contents("$data");
-splice(@a, 3, 0, 'r7', 'rec8'); # insert more than one
-check_contents("$ {data}r7$:rec8$:");
-splice(@a, 3, 2, 'rec7', 'record8', 'rec9'); # insert more than delete
-check_contents("$ {data}rec7$:record8$:rec9$:");
-
-splice(@a, 3, 3, 'record9', 'rec10'); # delete more than insert
-check_contents("$ {data}record9$:rec10$:");
-splice(@a, 3, 2); # delete more than one
-check_contents("$data");
-
-# (63-82) splicing with negative subscript
-splice(@a, -1, 0, "rec4");
-check_contents("rec0$:rec1$:rec4$:rec2$:");
-splice(@a, -1, 1, "rec5"); # same length
-check_contents("rec0$:rec1$:rec4$:rec5$:");
-splice(@a, -1, 1, "record5"); # longer
-check_contents("rec0$:rec1$:rec4$:record5$:");
-
-splice(@a, -1, 1, "r5"); # shorter
-check_contents("rec0$:rec1$:rec4$:r5$:");
-splice(@a, -1, 1); # removal
-check_contents("rec0$:rec1$:rec4$:");
-splice(@a, -1, 0); # no-op
-check_contents("rec0$:rec1$:rec4$:");
-splice(@a, -1, 0, 'r7', 'rec8'); # insert more than one
-check_contents("rec0$:rec1$:r7$:rec8$:rec4$:");
-splice(@a, -1, 2, 'rec7', 'record8', 'rec9'); # insert more than delete
-check_contents("rec0$:rec1$:r7$:rec8$:rec7$:record8$:rec9$:");
-
-splice(@a, -3, 3, 'record9', 'rec10'); # delete more than insert
-check_contents("rec0$:rec1$:r7$:rec8$:record9$:rec10$:");
-splice(@a, -4, 3); # delete more than one
-check_contents("rec0$:rec1$:rec10$:");
-
-# (83-84) scrub it all out
-splice(@a, 0, 3);
-check_contents("");
-
-# (85-86) put some back in
-splice(@a, 0, 0, "rec0", "rec1");
-check_contents("rec0$:rec1$:");
-
-# (87-88) what if we remove too many records?
-splice(@a, 0, 17);
-check_contents("");
-
-# (89-92) In the past, splicing past the end was not correctly detected
-# (1.14)
-splice(@a, 89, 3);
-check_contents("");
-splice(@a, @a, 3);
-check_contents("");
-
-# (93-96) Also we did not emulate splice's freaky behavior when inserting
-# past the end of the array (1.14)
-splice(@a, 89, 0, "I", "like", "pie");
-check_contents("I$:like$:pie$:");
-splice(@a, 89, 0, "pie pie pie");
-check_contents("I$:like$:pie$:pie pie pie$:");
-
-# (97) Splicing with too large a negative number should be fatal
-# This test ignored because it causes 5.6.1 and 5.7.3 to dump core
-# It also garbles the stack under 5.005_03 (20020401)
-# NOT MY FAULT
-if ($] > 5.007003) {
- eval { splice(@a, -7, 0) };
- print $@ =~ /^Modification of non-creatable array value attempted, subscript -7/
- ? "ok $N\n" : "not ok $N \# \$\@ was '$@'\n";
-} else {
- print "ok $N \# skipped (versions through 5.7.3 dump core here.)\n";
-}
-$N++;
-
-# (98-101) Test default arguments
-splice @a, 0, 0, (0..11);
-splice @a, 4;
-check_contents("0$:1$:2$:3$:");
-splice @a;
-check_contents("");
-
-# (102-103) I think there's a bug here---it will fail to clear the EOF flag
-@a = (0..11);
-splice @a, -1, 1000;
-check_contents("0$:1$:2$:3$:4$:5$:6$:7$:8$:9$:10$:");
-
-# (104-106) make sure that undefs are treated correctly---they should
-# be converted to empty records, and should not raise any warnings.
-# (Some of these failed in 0.90. The change to _fixrec fixed them.)
-# 20020331
-{
- my $good = 1; my $warn;
- # If any of these raise warnings, we have a problem.
- local $SIG{__WARN__} = sub { $good = 0; $warn = shift(); ctrlfix($warn)};
- local $^W = 1;
- @a = (1);
- splice @a, 1, 0, undef, undef, undef;
- print $good ? "ok $N\n" : "not ok $N # $warn\n";
- $N++; $good = 1;
- print defined($a[2]) ? "ok $N\n" : "not ok $N\n";
- $N++; $good = 1;
- my @r = splice @a, 2;
- print defined($r[0]) ? "ok $N\n" : "not ok $N\n";
- $N++; $good = 1;
-}
-
-# (107-118) splice with negative length was treated wrong
-# 20020402 Reported by Juerd Waalboer
-@a = (0..8) ;
-splice @a, 0, -3;
-check_contents("6$:7$:8$:");
-@a = (0..8) ;
-splice @a, 1, -3;
-check_contents("0$:6$:7$:8$:");
-@a = (0..8) ;
-splice @a, 7, -3;
-check_contents("0$:1$:2$:3$:4$:5$:6$:7$:8$:");
-@a = (0..2) ;
-splice @a, 0, -3;
-check_contents("0$:1$:2$:");
-@a = (0..2) ;
-splice @a, 1, -3;
-check_contents("0$:1$:2$:");
-@a = (0..2) ;
-splice @a, 7, -3;
-check_contents("0$:1$:2$:");
-
-sub init_file {
- my $data = shift;
- open F, "> $file" or die $!;
- binmode F;
- print F $data;
- close F;
-}
-
-use POSIX 'SEEK_SET';
-sub check_contents {
- my $x = shift;
- my $integrity = $o->_check_integrity($file, $ENV{INTEGRITY});
- local *FH = $o->{fh};
- seek FH, 0, SEEK_SET;
- print $integrity ? "ok $N\n" : "not ok $N\n";
- $N++;
- my $a;
- { local $/; $a = <FH> }
- $a = "" unless defined $a;
- if ($a eq $x) {
- print "ok $N\n";
- } else {
- ctrlfix($a, $x);
- print "not ok $N\n# expected <$x>, got <$a>\n";
- }
- $N++;
-}
-
-
-sub ctrlfix {
- for (@_) {
- s/\n/\\n/g;
- s/\r/\\r/g;
- }
-}
-
-END {
- undef $o;
- untie @a;
- 1 while unlink $file;
-}
-