9 use Digest::MD5 qw(md5 md5_hex);
12 # This is the output of: 'md5sum MD5.pm MD5.xs'
16 if (ord('A' == 193) { # EBCDIC
18 9e1d1183ff41717c91a563c41e08d672 ext/Digest/MD5/MD5.pm
19 61debd0ec12e131e1ba220e2f3ad2d26 ext/Digest/MD5/MD5.xs
23 9e1d1183ff41717c91a563c41e08d672 ext/Digest/MD5/MD5.pm
24 61debd0ec12e131e1ba220e2f3ad2d26 ext/Digest/MD5/MD5.xs
31 for (split /^/, $EXPECT) {
32 my($md5hex, $file) = split ' ';
33 my @path = split(m:/:, $file);
35 my $path = File::Spec->updir;
37 $path = File::Spec->catdir($path, shift @path);
39 $file = File::Spec->catfile($path, $last);
40 my $md5bin = pack("H*", $md5hex);
43 if (digest_file($file, 'digest') ne $md5bin) {
44 print "$file: Bad digest\n";
48 if (digest_file($file, 'hexdigest') ne $md5hex) {
49 print "$file: Bad hexdigest\n";
53 my $data = cat_file($file);
54 if (md5($data) ne $md5bin) {
55 print "$file: md5() failed\n";
58 if (md5_hex($data) ne $md5hex) {
59 print "$file: md5_hex() failed\n";
63 if (Digest::MD5->new->add($data)->digest ne $md5bin) {
64 print "$file: MD5->new->add(...)->digest failed\n";
67 if (Digest::MD5->new->add($data)->hexdigest ne $md5hex) {
68 print "$file: MD5->new->add(...)->hexdigest failed\n";
72 my @data = split //, $data;
73 if (md5(@data) ne $md5bin) {
74 print "$file: md5(\@data) failed\n";
77 if (Digest::MD5->new->add(@data)->digest ne $md5bin) {
78 print "$file: MD5->new->add(\@data)->digest failed\n";
81 my $md5 = Digest::MD5->new;
85 if ($md5->digest ne $md5bin) {
86 print "$file: $md5->add()-loop failed\n";
90 print "not " if $failed;
91 print "ok ", ++$testno, "\n";
97 my($file, $method) = @_;
99 #print "$file $method\n";
101 open(FILE, $file) or die "Can't open $file: $!";
103 my $digest = Digest::MD5->new->addfile(*FILE)->$method();
113 open(FILE, $file) or die "Can't open $file: $!";