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:
parent
c67634afa0
commit
a238b4b0fd
@ -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
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue
Block a user