2955397b73d51657a5a8eb65d44f305d94f2af8e
[p5sagit/p5-mst-13.2.git] / t / lib / syslfs.t
1 # NOTE: this file tests how large files (>2GB) work with raw system IO.
2 # open(), tell(), seek(), print(), read() are tested in t/op/lfs.t.
3 # If you modify/add tests here, remember to update also t/op/lfs.t.
4
5 BEGIN {
6         # Don't bother if there are no quads.
7         eval { my $q = pack "q", 0 };
8         if ($@) {
9                 print "1..0\n# no 64-bit types\n";
10                 exit(0);
11         }
12         chdir 't' if -d 't';
13         unshift @INC, '../lib';
14         require Config; import Config;
15         # Don't bother if there are no quad offsets.
16         if ($Config{lseeksize} < 8) {
17                 print "1..0\n# no 64-bit file offsets\n";
18                 exit(0);
19         }
20         require Fcntl; import Fcntl;
21 }
22
23 sub bye {
24     close(BIG);
25     unlink "big";
26     exit(0);
27 }
28
29 # Known have-nots.
30 if ($^O eq 'win32' || $^O eq 'vms') {
31     print "1..0\n# no sparse files\n";
32     bye();
33 }
34
35 # Then try to deduce whether we have sparse files.
36
37 # We'll start off by creating a one megabyte file which has
38 # only three "true" bytes.  If we have sparseness, we should
39 # consume less blocks than one megabyte (assuming nobody has
40 # one megabyte blocks...)
41
42 sysopen(BIG, "big", O_WRONLY|O_CREAT|O_TRUNC) or
43         do { warn "sysopen failed: $!\n"; bye };
44 sysseek(BIG, 1_000_000, SEEK_SET);
45 syswrite(BIG, "big");
46 close(BIG);
47
48 my @s;
49
50 @s = stat("big");
51
52 print "# @s\n";
53
54 my $BLOCKSIZE = 512; # is this really correct everywhere?
55
56 unless (@s == 13 &&
57         $s[7] == 1_000_003 &&
58         defined $s[12] &&
59         $BLOCKSIZE * $s[12] < 1_000_003) {
60     print "1..0\n# no sparse files?\n";
61     bye();
62 }
63
64 # By now we better be sure that we do have sparse files:
65 # if we are not, the following will hog 5 gigabytes of disk.  Ooops.
66
67 print "1..8\n";
68
69 my $fail = 0;
70
71 sysopen(BIG, "big", O_WRONLY|O_CREAT|O_TRUNC) or
72         do { warn "sysopen failed: $!\n"; bye };
73 sysseek(BIG, 5_000_000_000, SEEK_SET);
74 syswrite(BIG, "big");
75 close BIG;
76
77 @s = stat("big");
78
79 print "# @s\n";
80
81 sub fail () {
82     print "not ";
83     $fail++;
84 }
85
86 fail unless $s[7] == 5_000_000_003;     # exercizes pp_stat
87 print "ok 1\n";
88
89 fail unless -s "big" == 5_000_000_003;  # exercizes pp_ftsize
90 print "ok 2\n";
91
92 sysopen(BIG, "big", O_RDONLY) or do { warn "sysopen failed: $!\n"; bye };
93
94 sysseek(BIG, 4_500_000_000, SEEK_SET);
95
96 fail unless sysseek(BIG, 0, SEEK_CUR) == 4_500_000_000;
97 print "ok 3\n";
98
99 sysseek(BIG, 1, SEEK_CUR);
100
101 fail unless sysseek(BIG, 0, SEEK_CUR) == 4_500_000_001;
102 print "ok 4\n";
103
104 sysseek(BIG, -1, SEEK_CUR);
105
106 fail unless sysseek(BIG, 0, SEEK_CUR) == 4_500_000_000;
107 print "ok 5\n";
108
109 sysseek(BIG, -3, SEEK_END);
110
111 fail unless sysseek(BIG, 0, SEEK_CUR) == 5_000_000_000;
112 print "ok 6\n";
113
114 my $big;
115
116 fail unless sysread(BIG, $big, 3) == 3;
117 print "ok 7\n";
118
119 fail unless $big eq "big";
120 print "ok 8\n";
121
122 bye();
123
124 if ($fail) {
125     print STDERR <<EOM;
126 #
127 # If the lfs (large file support) tests fail, it means that
128 # the *file system* you are running the tests on doesn't support
129 # large files (files larger than two gigabytes).  Perl may still
130 # be able to support such files, once you have such a file system.
131 #
132 EOM
133 }
134
135 # eof