|
Packit |
fa4fcc |
use strict;
|
|
Packit |
fa4fcc |
use FileHandle;
|
|
Packit |
fa4fcc |
use Digest::SHA;
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my @out = (
|
|
Packit |
fa4fcc |
"ungWv48Bz+pBQUDeXa4iI7ADYaOWF3qctBD/YfIAFa0",
|
|
Packit |
fa4fcc |
"248d6a61d20638b8e5c026930c3e6039a33ce45964ff2167f6ecedd419db06c1",
|
|
Packit |
fa4fcc |
);
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $numtests = 6 + scalar @out;
|
|
Packit |
fa4fcc |
print "1..$numtests\n";
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# attempt to use an invalid algorithm, and check for failure
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $testnum = 1;
|
|
Packit |
fa4fcc |
my $NSA = "SHA-42"; # No Such Algorithm
|
|
Packit |
fa4fcc |
print "not " if Digest::SHA->new($NSA);
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $tempfile = "methods.tmp";
|
|
Packit |
fa4fcc |
END { unlink $tempfile if $tempfile }
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test OO methods using first two SHA-256 vectors from NIST
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $fh = FileHandle->new($tempfile, "w");
|
|
Packit |
fa4fcc |
binmode($fh);
|
|
Packit |
fa4fcc |
print $fh "bcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq";
|
|
Packit |
fa4fcc |
$fh->close;
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $sha = Digest::SHA->new()->reset("SHA-256")->new();
|
|
Packit |
fa4fcc |
$sha->add_bits("a", 5)->add_bits("001");
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $rsp = shift(@out);
|
|
Packit |
fa4fcc |
print "not " unless $sha->clone->add("b", "c")->b64digest eq $rsp;
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
$rsp = shift(@out);
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test addfile with bareword filehandle
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
open(FILE, "<$tempfile");
|
|
Packit |
fa4fcc |
binmode(FILE);
|
|
Packit |
fa4fcc |
print "not " unless
|
|
Packit |
fa4fcc |
$sha->clone->addfile(*FILE)->hexdigest eq $rsp;
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
close(FILE);
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test addfile with indirect filehandle
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
$fh = FileHandle->new($tempfile, "r");
|
|
Packit |
fa4fcc |
binmode($fh);
|
|
Packit |
fa4fcc |
print "not " unless $sha->clone->addfile($fh)->hexdigest eq $rsp;
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
$fh->close;
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test addfile using file name instead of handle
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
print "not " unless $sha->addfile($tempfile, "b")->hexdigest eq $rsp;
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test addfile "universal newlines" mode
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
$fh = FileHandle->new($tempfile, "w");
|
|
Packit |
fa4fcc |
binmode($fh);
|
|
Packit |
fa4fcc |
print $fh "MacOS\r" . "MSDOS\r\n" . "UNIX\n" . "Quirky\r\r\n";
|
|
Packit |
fa4fcc |
$fh->close;
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
my $d = $sha->new(1)->addfile($tempfile, "U")->hexdigest;
|
|
Packit |
fa4fcc |
if ($d eq "f4c6855783c737c7e224873c90e80a9df5c2bc97") {
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
}
|
|
Packit |
fa4fcc |
elsif ($d eq "42335d4a517a5e31399e948e9d842bafd9194d8f") {
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, " # skip: flaky -T\n";
|
|
Packit |
fa4fcc |
}
|
|
Packit |
fa4fcc |
else {
|
|
Packit |
fa4fcc |
print "not ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
}
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
# test addfile BITS mode
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
$fh = FileHandle->new($tempfile, "w");
|
|
Packit |
fa4fcc |
print $fh "0100010"; # using NIST 7-bit test vector
|
|
Packit |
fa4fcc |
$fh->close;
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
print "not " unless $sha->new(1)->addfile($tempfile, "0")->hexdigest eq
|
|
Packit |
fa4fcc |
"04f31807151181ad0db278a1660526b0aeef64c2";
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
$fh = FileHandle->new($tempfile, "w");
|
|
Packit |
fa4fcc |
binmode($fh);
|
|
Packit |
fa4fcc |
print $fh map(chr, (0..127)); # this is actually NIST 2-bit test
|
|
Packit |
fa4fcc |
$fh->close; # vector "01" (other chars ignored)
|
|
Packit |
fa4fcc |
|
|
Packit |
fa4fcc |
print "not " unless $sha->new(1)->addfile($tempfile, "0")->hexdigest eq
|
|
Packit |
fa4fcc |
"ec6b39952e1a3ec3ab3507185cf756181c84bbe2";
|
|
Packit |
fa4fcc |
print "ok ", $testnum++, "\n";
|