11 use Digest::MD5 qw(md5 md5_hex md5_base64);
13 # To update the EBCDIC section even on a Latin 1 platform,
14 # run this script with $ENV{EBCDIC_MD5SUM} set to a true value.
15 # (You'll need to have Perl 5.7.3 or later, to have the Encode installed.)
16 # (And remember that under the Perl core distribution you should
17 # also have the $ENV{PERL_CORE} set to a true value.)
18 # Similarly, to update MacOS section, run with $ENV{MAC_MD5SUM} set.
21 if (ord "A" == 193) { # EBCDIC
23 36158997c99f2e1396ee40ddc4634a40 Changes
24 5a591a47e8c40fe4b78c744111511c45 README
25 770a5ef28ab15e66355639f21152afb0 MD5.pm
26 4850753428db9422e8e5f97b401d5a13 MD5.xs
27 276da0aa4e9a08b7fe09430c9c5690aa rfc1321.txt
29 } elsif ("\n" eq "\015") { # MacOS
31 e68b13fe9edf36fe13551bf410b7a745 Changes
32 3519f3d02c7c91158f732f0f00064657 README
33 4113db8afad83eb7c01f1bf2c53e66ee MD5.pm
34 1be293491bba726810f8e87671ee0328 MD5.xs
35 754b9db19f79dbc4992f7166eb0f37ce rfc1321.txt
38 # This is the output of: 'md5sum Changes README MD5.pm MD5.xs rfc1321.txt'
40 e68b13fe9edf36fe13551bf410b7a745 Changes
41 3519f3d02c7c91158f732f0f00064657 README
42 4113db8afad83eb7c01f1bf2c53e66ee MD5.pm
43 1be293491bba726810f8e87671ee0328 MD5.xs
44 754b9db19f79dbc4992f7166eb0f37ce rfc1321.txt
48 if (!(-f "README") && -f "../README") {
49 chdir("..") or die "Can't chdir: $!";
55 eval { require MIME::Base64; };
57 print "# $@: Will not test base64 methods\n";
61 for (split /^/, $EXPECT) {
62 my($md5hex, $file) = split ' ';
64 if ($ENV{PERL_CORE}) {
65 if ($file eq 'rfc1321.txt') { # Don't have it in core.
66 print "ok ", ++$testno, " # Skip: PERL_CORE\n";
70 my @path = qw(ext Digest MD5);
71 my $path = File::Spec->updir;
73 $path = File::Spec->catdir($path, shift @path);
75 $file = File::Spec->catfile($path, $file);
77 # print "# file = $file\n";
79 warn "No such file: $file\n";
82 if ($ENV{EBCDIC_MD5SUM}) {
84 my $data = cat_file($file);
85 Encode::from_to($data, 'latin1', 'cp1047');
86 print md5_hex($data), " $base\n";
89 if ($ENV{MAC_MD5SUM}) {
90 my $data = cat_file($file);
91 print md5_hex($data), " $base\n";
94 my $md5bin = pack("H*", $md5hex);
97 $md5b64 = MIME::Base64::encode($md5bin, "");
98 chop($md5b64); chop($md5b64); # remove padding
103 if (digest_file($file, 'digest') ne $md5bin) {
104 print "$file: Bad digest\n";
108 if (($got = digest_file($file, 'hexdigest')) ne $md5hex) {
109 print "$file: Bad hexdigest: got $got expected $md5hex\n";
113 if ($B64 && digest_file($file, 'b64digest') ne $md5b64) {
114 print "$file: Bad b64digest\n";
118 my $data = cat_file($file);
119 if (md5($data) ne $md5bin) {
120 print "$file: md5() failed\n";
123 if (md5_hex($data) ne $md5hex) {
124 print "$file: md5_hex() failed\n";
127 if ($B64 && md5_base64($data) ne $md5b64) {
128 print "$file: md5_base64() failed\n";
132 if (Digest::MD5->new->add($data)->digest ne $md5bin) {
133 print "$file: MD5->new->add(...)->digest failed\n";
136 if (Digest::MD5->new->add($data)->hexdigest ne $md5hex) {
137 print "$file: MD5->new->add(...)->hexdigest failed\n";
140 if ($B64 && Digest::MD5->new->add($data)->b64digest ne $md5b64) {
141 print "$file: MD5->new->add(...)->b64digest failed\n";
145 my @data = split //, $data;
146 if (md5(@data) ne $md5bin) {
147 print "$file: md5(\@data) failed\n";
150 if (Digest::MD5->new->add(@data)->digest ne $md5bin) {
151 print "$file: MD5->new->add(\@data)->digest failed\n";
154 my $md5 = Digest::MD5->new;
158 if ($md5->digest ne $md5bin) {
159 print "$file: $md5->add()-loop failed\n";
163 print "not " if $failed;
164 print "ok ", ++$testno, "\n";
170 my($file, $method) = @_;
171 $method ||= "digest";
172 #print "$file $method\n";
174 open(FILE, $file) or die "Can't open $file: $!";
175 my $digest = Digest::MD5->new->addfile(*FILE)->$method();
185 open(FILE, $file) or die "Can't open $file: $!";
187 # For PerlIO in case of UTF-8 locales.
188 eval 'binmode(FILE, ":bytes")' if $] >= 5.008;