Commit | Line | Data |
9508959b |
1 | BEGIN { |
2 | if ($ENV{PERL_CORE}) { |
3 | chdir 't' if -d 't'; |
4 | @INC = '../lib'; |
5 | } |
6 | } |
7 | |
5a046520 |
8 | print "1..5\n"; |
3357b1b1 |
9 | |
10 | use strict; |
4d5cc332 |
11 | use Digest::MD5 qw(md5 md5_hex md5_base64); |
3357b1b1 |
12 | |
13 | # |
5a046520 |
14 | # This is the output of: 'md5sum Changes README MD5.pm MD5.xs rfc1321.txt' |
3357b1b1 |
15 | # |
9508959b |
16 | my $EXPECT; |
17 | |
8ff693ee |
18 | # To update the EBCDIC section even on a Latin 1 platform, |
19 | # run this script with $ENV{EBCDIC_MD5SUM} set to a true value. |
20 | # (You'll need to have Perl 5.7.3 or later, to have the Encode installed.) |
21 | # (And remember that under the Perl core distribution you should |
22 | # also have the $ENV{PERL_CORE} set to a true value.) |
23 | |
9508959b |
24 | if (ord "A" == 193) { # EBCDIC |
25 | $EXPECT = <<EOT; |
8ff693ee |
26 | a1ee2b18d1e05bdde3a93009e7f9dfda Changes |
27 | 5a591a47e8c40fe4b78c744111511c45 README |
28 | c9c83e6dbad5f41722338e67d4428077 MD5.pm |
29 | 4850753428db9422e8e5f97b401d5a13 MD5.xs |
30 | 276da0aa4e9a08b7fe09430c9c5690aa rfc1321.txt |
fed3f325 |
31 | EOT |
9508959b |
32 | } else { |
33 | $EXPECT = <<EOT; |
7e2b0cd5 |
34 | 3866f3543ef41421c6aed3f198e2e9f5 Changes |
9508959b |
35 | 3519f3d02c7c91158f732f0f00064657 README |
7e2b0cd5 |
36 | 01cd8fd24bd46ce1db53074d2af6001a MD5.pm |
9508959b |
37 | 1be293491bba726810f8e87671ee0328 MD5.xs |
38 | 754b9db19f79dbc4992f7166eb0f37ce rfc1321.txt |
39 | EOT |
40 | } |
5a046520 |
41 | |
42 | if (!(-f "README") && -f "../README") { |
43 | chdir("..") or die "Can't chdir: $!"; |
fed3f325 |
44 | } |
8c42d64c |
45 | |
5a046520 |
46 | my $testno = 0; |
47 | |
4d5cc332 |
48 | my $B64 = 1; |
49 | eval { require MIME::Base64; }; |
50 | if ($@) { |
9508959b |
51 | print "# $@: Will not test base64 methods\n"; |
4d5cc332 |
52 | $B64 = 0; |
53 | } |
54 | |
3357b1b1 |
55 | for (split /^/, $EXPECT) { |
56 | my($md5hex, $file) = split ' '; |
8ff693ee |
57 | my $base = $file; |
9508959b |
58 | if ($ENV{PERL_CORE}) { |
8ff693ee |
59 | if ($file eq 'rfc1x321.txt') { # Don't have it in core. |
9508959b |
60 | print "ok ", ++$testno, " # Skip: PERL_CORE\n"; |
61 | next; |
62 | } |
63 | use File::Spec; |
64 | my @path = qw(ext Digest MD5); |
65 | my $path = File::Spec->updir; |
66 | while (@path) { |
67 | $path = File::Spec->catdir($path, shift @path); |
68 | } |
69 | $file = File::Spec->catfile($path, $file); |
70 | } |
71 | # print "# file = $file\n"; |
8ff693ee |
72 | unless (-f $file) { |
73 | warn "No such file: $file\n"; |
74 | next; |
75 | } |
76 | if ($ENV{EBCDIC_MD5SUM}) { |
77 | use Encode 'from_to'; |
78 | my $data = cat_file($file); |
79 | from_to($data, 'latin1', 'cp1047'); |
80 | print md5_hex($data), " $base\n"; |
81 | next; |
82 | } |
3357b1b1 |
83 | my $md5bin = pack("H*", $md5hex); |
4d5cc332 |
84 | my $md5b64; |
85 | if ($B64) { |
86 | $md5b64 = MIME::Base64::encode($md5bin, ""); |
87 | chop($md5b64); chop($md5b64); # remove padding |
88 | } |
3357b1b1 |
89 | my $failed; |
9508959b |
90 | my $got; |
3357b1b1 |
91 | |
92 | if (digest_file($file, 'digest') ne $md5bin) { |
93 | print "$file: Bad digest\n"; |
94 | $failed++; |
95 | } |
96 | |
9508959b |
97 | if (($got = digest_file($file, 'hexdigest')) ne $md5hex) { |
98 | print "$file: Bad hexdigest: got $got expected $md5hex\n"; |
3357b1b1 |
99 | $failed++; |
100 | } |
101 | |
4d5cc332 |
102 | if ($B64 && digest_file($file, 'b64digest') ne $md5b64) { |
103 | print "$file: Bad b64digest\n"; |
104 | $failed++; |
105 | } |
106 | |
3357b1b1 |
107 | my $data = cat_file($file); |
108 | if (md5($data) ne $md5bin) { |
109 | print "$file: md5() failed\n"; |
110 | $failed++; |
111 | } |
112 | if (md5_hex($data) ne $md5hex) { |
113 | print "$file: md5_hex() failed\n"; |
114 | $failed++; |
115 | } |
4d5cc332 |
116 | if ($B64 && md5_base64($data) ne $md5b64) { |
117 | print "$file: md5_base64() failed\n"; |
118 | $failed++; |
119 | } |
3357b1b1 |
120 | |
121 | if (Digest::MD5->new->add($data)->digest ne $md5bin) { |
122 | print "$file: MD5->new->add(...)->digest failed\n"; |
123 | $failed++; |
124 | } |
125 | if (Digest::MD5->new->add($data)->hexdigest ne $md5hex) { |
126 | print "$file: MD5->new->add(...)->hexdigest failed\n"; |
127 | $failed++; |
128 | } |
4d5cc332 |
129 | if ($B64 && Digest::MD5->new->add($data)->b64digest ne $md5b64) { |
130 | print "$file: MD5->new->add(...)->b64digest failed\n"; |
131 | $failed++; |
132 | } |
3357b1b1 |
133 | |
134 | my @data = split //, $data; |
135 | if (md5(@data) ne $md5bin) { |
136 | print "$file: md5(\@data) failed\n"; |
137 | $failed++; |
138 | } |
139 | if (Digest::MD5->new->add(@data)->digest ne $md5bin) { |
140 | print "$file: MD5->new->add(\@data)->digest failed\n"; |
141 | $failed++; |
142 | } |
143 | my $md5 = Digest::MD5->new; |
144 | for (@data) { |
145 | $md5->add($_); |
146 | } |
147 | if ($md5->digest ne $md5bin) { |
148 | print "$file: $md5->add()-loop failed\n"; |
149 | $failed++; |
150 | } |
151 | |
152 | print "not " if $failed; |
153 | print "ok ", ++$testno, "\n"; |
154 | } |
155 | |
156 | |
157 | sub digest_file |
158 | { |
159 | my($file, $method) = @_; |
160 | $method ||= "digest"; |
161 | #print "$file $method\n"; |
162 | |
163 | open(FILE, $file) or die "Can't open $file: $!"; |
3357b1b1 |
164 | my $digest = Digest::MD5->new->addfile(*FILE)->$method(); |
165 | close(FILE); |
166 | |
167 | $digest; |
168 | } |
169 | |
170 | sub cat_file |
171 | { |
172 | my($file) = @_; |
173 | local $/; # slurp |
174 | open(FILE, $file) or die "Can't open $file: $!"; |
3357b1b1 |
175 | my $tmp = <FILE>; |
176 | close(FILE); |
177 | $tmp; |
178 | } |
179 | |