aboutsummaryrefslogtreecommitdiffstats
path: root/libtests/qtest
diff options
context:
space:
mode:
authorJay Berkenbilt <ejb@ql.org>2019-11-06 03:29:34 +0100
committerJay Berkenbilt <ejb@ql.org>2019-11-09 15:53:42 +0100
commit1639d972ea0b30711b9a762fe4475cdb2b229be1 (patch)
treeabbbaf84565b729e7b535a21692db39235264a09 /libtests/qtest
parent127a957aee7bf7ae242a606d035e9e3d9b300307 (diff)
downloadqpdf-1639d972ea0b30711b9a762fe4475cdb2b229be1.tar.zst
Run libtests for crypto with all available providers
If QPDF_CRYPTO_PROVIDER is set, just run the tests for the given provider. This is to support cases of running the entire test suite for each provider. If QPDF_CRYPTO_PROVIDER is not set, run the tests that exercise the cyrpto provider for each available provider.
Diffstat (limited to 'libtests/qtest')
-rw-r--r--libtests/qtest/aes.test115
-rw-r--r--libtests/qtest/md5.test32
-rw-r--r--libtests/qtest/rc4.test76
-rw-r--r--libtests/qtest/sha2.test32
4 files changed, 168 insertions, 87 deletions
diff --git a/libtests/qtest/aes.test b/libtests/qtest/aes.test
index 7e48840a..a468b0b4 100644
--- a/libtests/qtest/aes.test
+++ b/libtests/qtest/aes.test
@@ -10,60 +10,81 @@ require TestDriver;
my $td = new TestDriver('AES');
-cleanup();
-
-my $key = '000102030405060708090a0b0c0d0e0f';
-$td->runtest("encrypt test vector",
- {$td->COMMAND => "aes -cbc -encrypt $key test-vector.clear tmp1"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
-$td->runtest("check output",
- {$td->FILE => "tmp1"},
- {$td->FILE => "test-vector.cipher"});
-$td->runtest("decrypt test vector",
- {$td->COMMAND => "aes -cbc -decrypt $key tmp1 tmp2"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
-$td->runtest("check output",
- {$td->FILE => "tmp2"},
- {$td->FILE => "test-vector.clear"});
-
-$key = '243f6a8885243f6a8885243f6a888524';
-foreach my $d (['data1', 17072], ['data2', 16032])
+my @providers = ();
+if (exists $ENV{'QPDF_CRYPTO_PROVIDER'})
+{
+ push(@providers, $ENV{'QPDF_CRYPTO_PROVIDER'});
+}
+else
{
- my ($file, $size) = @$d;
- $td->runtest("encrypt $file",
- {$td->COMMAND => "aes +cbc -encrypt $key $file tmp1"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
- # sleep one second so random number will get a different seed
- sleep(1);
- $td->runtest("encrypt $file again",
- {$td->COMMAND => "aes +cbc -encrypt $key $file tmp2"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
- foreach my $f (qw(tmp1 tmp2))
+ open(Q, "qpdf --show-crypto|") or die;
+ while (<Q>)
{
- $td->runtest("check size",
- {$td->STRING => sprintf("%d\n", stat($f)->size)},
- {$td->STRING => "$size\n"});
+ s/\s+$//s;
+ push(@providers, $_);
}
- $td->runtest("verify files are different",
- {$td->COMMAND => "cmp tmp1 tmp2"},
- {$td->REGEXP => '.*', $td->EXIT_STATUS => '!0'});
- $td->runtest("decrypt $file",
- {$td->COMMAND => "aes +cbc -decrypt $key tmp1 tmp3"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
- $td->runtest("decrypt $file again",
- {$td->COMMAND => "aes +cbc -decrypt $key tmp2 tmp4"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
+ close(Q);
+}
+foreach my $p (@providers)
+{
+ $ENV{'QPDF_CRYPTO_PROVIDER'} = $p;
+
+ cleanup();
+
+ my $key = '000102030405060708090a0b0c0d0e0f';
+ $td->runtest("encrypt test vector ($p)",
+ {$td->COMMAND =>
+ "aes -cbc -encrypt $key test-vector.clear tmp1"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
$td->runtest("check output",
- {$td->FILE => "tmp3"},
- {$td->FILE => $file});
+ {$td->FILE => "tmp1"},
+ {$td->FILE => "test-vector.cipher"});
+ $td->runtest("decrypt test vector ($p)",
+ {$td->COMMAND => "aes -cbc -decrypt $key tmp1 tmp2"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
$td->runtest("check output",
- {$td->FILE => "tmp4"},
- {$td->FILE => $file});
-}
+ {$td->FILE => "tmp2"},
+ {$td->FILE => "test-vector.clear"});
+
+ $key = '243f6a8885243f6a8885243f6a888524';
+ foreach my $d (['data1', 17072], ['data2', 16032])
+ {
+ my ($file, $size) = @$d;
+ $td->runtest("encrypt $file ($p)",
+ {$td->COMMAND => "aes +cbc -encrypt $key $file tmp1"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ # sleep one second so random number will get a different seed
+ sleep(1);
+ $td->runtest("encrypt $file again ($p)",
+ {$td->COMMAND => "aes +cbc -encrypt $key $file tmp2"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ foreach my $f (qw(tmp1 tmp2))
+ {
+ $td->runtest("check size",
+ {$td->STRING => sprintf("%d\n", stat($f)->size)},
+ {$td->STRING => "$size\n"});
+ }
+ $td->runtest("verify files are different",
+ {$td->COMMAND => "cmp tmp1 tmp2"},
+ {$td->REGEXP => '.*', $td->EXIT_STATUS => '!0'});
+ $td->runtest("decrypt $file ($p)",
+ {$td->COMMAND => "aes +cbc -decrypt $key tmp1 tmp3"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ $td->runtest("decrypt $file again ($p)",
+ {$td->COMMAND => "aes +cbc -decrypt $key tmp2 tmp4"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ $td->runtest("check output",
+ {$td->FILE => "tmp3"},
+ {$td->FILE => $file});
+ $td->runtest("check output",
+ {$td->FILE => "tmp4"},
+ {$td->FILE => $file});
+ }
-cleanup();
+ cleanup();
+}
-$td->report(22);
+$td->report(22 * scalar(@providers));
sub cleanup
{
diff --git a/libtests/qtest/md5.test b/libtests/qtest/md5.test
index 076a37ec..1cf57727 100644
--- a/libtests/qtest/md5.test
+++ b/libtests/qtest/md5.test
@@ -9,10 +9,30 @@ require TestDriver;
my $td = new TestDriver('md5');
-$td->runtest("md5",
- {$td->COMMAND => "md5"},
- {$td->FILE => "md5.out",
- $td->EXIT_STATUS => 0},
- $td->NORMALIZE_NEWLINES);
+my @providers = ();
+if (exists $ENV{'QPDF_CRYPTO_PROVIDER'})
+{
+ push(@providers, $ENV{'QPDF_CRYPTO_PROVIDER'});
+}
+else
+{
+ open(Q, "qpdf --show-crypto|") or die;
+ while (<Q>)
+ {
+ s/\s+$//s;
+ push(@providers, $_);
+ }
+ close(Q);
+}
+foreach my $p (@providers)
+{
+ $ENV{'QPDF_CRYPTO_PROVIDER'} = $p;
-$td->report(1);
+ $td->runtest("md5 ($p)",
+ {$td->COMMAND => "md5"},
+ {$td->FILE => "md5.out",
+ $td->EXIT_STATUS => 0},
+ $td->NORMALIZE_NEWLINES);
+}
+
+$td->report(scalar(@providers));
diff --git a/libtests/qtest/rc4.test b/libtests/qtest/rc4.test
index 25a5ab45..e718478b 100644
--- a/libtests/qtest/rc4.test
+++ b/libtests/qtest/rc4.test
@@ -9,40 +9,60 @@ require TestDriver;
my $td = new TestDriver('RC4');
-cleanup();
-
+my @providers = ();
+if (exists $ENV{'QPDF_CRYPTO_PROVIDER'})
+{
+ push(@providers, $ENV{'QPDF_CRYPTO_PROVIDER'});
+}
+else
+{
+ open(Q, "qpdf --show-crypto|") or die;
+ while (<Q>)
+ {
+ s/\s+$//s;
+ push(@providers, $_);
+ }
+ close(Q);
+}
my @tests = ('0123456789abcdef',
- '0123456789abcdef',
- '0000000000000000',
- 'ef012345',
- '0123456789abcdef');
+ '0123456789abcdef',
+ '0000000000000000',
+ 'ef012345',
+ '0123456789abcdef');
-my $n = 0;
-foreach my $key (@tests)
+foreach my $p (@providers)
{
- ++$n;
- $td->runtest("test $n",
- {$td->COMMAND => "rc4 $key test$n.in tmp1-$n.out"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
- $td->runtest("check output",
- {$td->FILE => "tmp1-$n.out"},
- {$td->FILE => "test$n.out"});
- $td->runtest("test $n reverse",
- {$td->COMMAND => "rc4 $key test$n.out tmp2-$n.out"},
- {$td->STRING => "", $td->EXIT_STATUS => 0});
- $td->runtest("check output",
- {$td->FILE => "tmp2-$n.out"},
- {$td->FILE => "test$n.in"});
-}
+ $ENV{'QPDF_CRYPTO_PROVIDER'} = $p;
+
+ cleanup();
-$td->runtest("other tests",
- {$td->COMMAND => "rc4 other"},
- {$td->STRING => "passed\n", $td->EXIT_STATUS => 0},
- $td->NORMALIZE_NEWLINES);
+ my $n = 0;
+ foreach my $key (@tests)
+ {
+ ++$n;
+ $td->runtest("test $n ($p)",
+ {$td->COMMAND => "rc4 $key test$n.in tmp1-$n.out"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ $td->runtest("check output",
+ {$td->FILE => "tmp1-$n.out"},
+ {$td->FILE => "test$n.out"});
+ $td->runtest("test $n reverse ($p)",
+ {$td->COMMAND => "rc4 $key test$n.out tmp2-$n.out"},
+ {$td->STRING => "", $td->EXIT_STATUS => 0});
+ $td->runtest("check output",
+ {$td->FILE => "tmp2-$n.out"},
+ {$td->FILE => "test$n.in"});
+ }
-cleanup();
+ $td->runtest("other tests ($p)",
+ {$td->COMMAND => "rc4 other"},
+ {$td->STRING => "passed\n", $td->EXIT_STATUS => 0},
+ $td->NORMALIZE_NEWLINES);
+
+ cleanup();
+}
-$td->report(1 + (4 * scalar(@tests)));
+$td->report((1 + (4 * scalar(@tests))) * scalar(@providers));
sub cleanup
{
diff --git a/libtests/qtest/sha2.test b/libtests/qtest/sha2.test
index 34d668f7..432f7157 100644
--- a/libtests/qtest/sha2.test
+++ b/libtests/qtest/sha2.test
@@ -9,10 +9,30 @@ require TestDriver;
my $td = new TestDriver('sha2');
-$td->runtest("sha2",
- {$td->COMMAND => "sha2"},
- {$td->FILE => "sha2.out",
- $td->EXIT_STATUS => 0},
- $td->NORMALIZE_NEWLINES);
+my @providers = ();
+if (exists $ENV{'QPDF_CRYPTO_PROVIDER'})
+{
+ push(@providers, $ENV{'QPDF_CRYPTO_PROVIDER'});
+}
+else
+{
+ open(Q, "qpdf --show-crypto|") or die;
+ while (<Q>)
+ {
+ s/\s+$//s;
+ push(@providers, $_);
+ }
+ close(Q);
+}
+foreach my $p (@providers)
+{
+ $ENV{'QPDF_CRYPTO_PROVIDER'} = $p;
-$td->report(1);
+ $td->runtest("sha2 ($p)",
+ {$td->COMMAND => "sha2"},
+ {$td->FILE => "sha2.out",
+ $td->EXIT_STATUS => 0},
+ $td->NORMALIZE_NEWLINES);
+}
+
+$td->report(scalar(@providers));