2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-03 15:17:29 +00:00

Ensure there is a meaningful deterministic ID test

If we ignore /ID[1], we need to make sure deterministic IDs are
tested properly.
This commit is contained in:
Jay Berkenbilt 2023-12-20 06:50:44 -05:00
parent c67634afa0
commit a238b4b0fd
5 changed files with 50 additions and 1863 deletions

View File

@ -2,6 +2,7 @@
require 5.008; require 5.008;
use warnings; use warnings;
use strict; use strict;
use File::Copy;
unshift(@INC, '.'); unshift(@INC, '.');
require qpdf_test_helpers; require qpdf_test_helpers;
@ -14,23 +15,41 @@ cleanup();
my $td = new TestDriver('deterministic-id'); my $td = new TestDriver('deterministic-id');
my $n_tests = 11; my $n_tests = 19;
# Do not use qpdf-test-compare in this test suite since it ignores
# /ID[1].
foreach my $d ('nn', 'ny', 'yn', 'yy') foreach my $d ('nn', 'ny', 'yn', 'yy')
{ {
my $linearize = ($d =~ m/^y/); my $linearize = ($d =~ m/^y/);
my $ostream = ($d =~ m/y$/); my $ostream = ($d =~ m/y$/);
$td->runtest("deterministic ID: linearize/ostream=$d", # The deterministic ID is a function of all the data in the file.
{$td->COMMAND => # As such, it is affected by which zlib implementation is in use.
"qpdf -deterministic-id" . # The important thing is that the ID is the same if a file is
($linearize ? " -linearize" : "") . # generated the same way more than once, so rather than comparing
" -object-streams=" . ($ostream ? "generate" : "disable") . # the output file to a known output, compare subsequent outputs
" deterministic-id-in.pdf a.pdf"}, # with each other.
{$td->STRING => "", foreach my $out ('a.pdf', 'b.pdf')
$td->EXIT_STATUS => 0}); {
$td->runtest("deterministic ID: linearize/ostream=$d",
{$td->COMMAND =>
"qpdf -deterministic-id" .
($linearize ? " -linearize" : "") .
" -object-streams=" . ($ostream ? "generate" : "disable") .
" deterministic-id-in.pdf $out"},
{$td->STRING => "",
$td->EXIT_STATUS => 0});
}
$td->runtest("compare files", $td->runtest("compare files",
{$td->FILE => "a.pdf"}, {$td->FILE => "a.pdf"},
{$td->FILE => "deterministic-id-$d.pdf"}); {$td->FILE => "b.pdf"});
check_id('a.pdf');
if ($d eq 'nn')
{
# Save for the C API test
copy("a.pdf", 'c.pdf');
}
} }
$td->runtest("deterministic ID with encryption", $td->runtest("deterministic ID with encryption",
@ -49,7 +68,27 @@ $td->runtest("deterministic ID (C API)",
$td->NORMALIZE_NEWLINES); $td->NORMALIZE_NEWLINES);
$td->runtest("compare files", $td->runtest("compare files",
{$td->FILE => "a.pdf"}, {$td->FILE => "a.pdf"},
{$td->FILE => "deterministic-id-nn.pdf"}); {$td->FILE => "c.pdf"});
cleanup(); cleanup();
$td->report($n_tests); $td->report($n_tests);
sub check_id
{
my $f = shift;
chomp(my $id = `qpdf --show-object=trailer $f`);
if ($id =~ m,.*/ID \[ <(9b1c69409fc9a5f50e44b9588e3e60f8)> <(.{32})>,)
{
my $id0 = $1;
my $id1 = $2;
$td->runtest("ID fields differ",
{$td->STRING => $id0 ne $id1 ? "YES\n" : "$id0 $id1\n"},
{$td->STRING => "YES\n"});
}
else
{
$td->runtest("checked ID",
{$td->STRING => "YES\n"},
{$td->STRING => "$id\n"});
}
}

File diff suppressed because it is too large Load Diff