Tests and benchmark
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,4 +1,4 @@
|
|||||||
.idea
|
.idea
|
||||||
*.pdf
|
*.pdf
|
||||||
*.pdf.*
|
*.pdf.*
|
||||||
!benchmark.pdf
|
!testfile*.pdf
|
@@ -118,7 +118,7 @@ func TestWritePartFromSourceFileToTargetFile(t *testing.T) {
|
|||||||
var b bytes.Buffer
|
var b bytes.Buffer
|
||||||
writer := bufio.NewWriter(&b)
|
writer := bufio.NewWriter(&b)
|
||||||
|
|
||||||
input_file, err := os.Open("../testfiles/benchmark.pdf")
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("Failed to load test PDF")
|
t.Errorf("Failed to load test PDF")
|
||||||
return
|
return
|
||||||
@@ -162,7 +162,7 @@ func TestWritePartFromSourceFileToTargetFile(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func loadHelpersTestPDF() (*os.File, *pdf.Reader) {
|
func loadHelpersTestPDF() (*os.File, *pdf.Reader) {
|
||||||
input_file, err := os.Open("../testfiles/benchmark.pdf")
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
56
sign/pdfcatalog_test.go
Normal file
56
sign/pdfcatalog_test.go
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
package sign
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"bitbucket.org/digitorus/pdf"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestCreateCatalog(t *testing.T) {
|
||||||
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finfo, err := input_file.Stat()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
size := finfo.Size()
|
||||||
|
|
||||||
|
rdr, err := pdf.NewReader(input_file, size)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
context := SignContext{
|
||||||
|
Filesize: size + 1,
|
||||||
|
PDFReader: rdr,
|
||||||
|
InputFile: input_file,
|
||||||
|
VisualSignData: VisualSignData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount),
|
||||||
|
},
|
||||||
|
CatalogData: CatalogData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 1,
|
||||||
|
},
|
||||||
|
InfoData: InfoData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 2,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
catalog, err := context.createCatalog()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("%s", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
expected_catalog := "11 0 obj\n<< /Type /Catalog /Version /2.0 /Pages 3 0 R /AcroForm << /Fields [10 0 R] /NeedAppearances false /SigFlags 1 >> /Perms << /UR3 0 0 R >> >>\nendobj\n"
|
||||||
|
|
||||||
|
if catalog != expected_catalog {
|
||||||
|
t.Errorf("Catalog mismatch, expected %s, but got %s", expected_catalog, catalog)
|
||||||
|
}
|
||||||
|
}
|
138
sign/pdfinfo_test.go
Normal file
138
sign/pdfinfo_test.go
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
package sign
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"bitbucket.org/digitorus/pdf"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestCreateInfoEmpty(t *testing.T) {
|
||||||
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finfo, err := input_file.Stat()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
size := finfo.Size()
|
||||||
|
|
||||||
|
rdr, err := pdf.NewReader(input_file, size)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data := SignData{
|
||||||
|
Signature: SignDataSignature{
|
||||||
|
Info: SignDataSignatureInfo{
|
||||||
|
Name: "Jeroen Bobbeldijk",
|
||||||
|
Location: "Rotterdam",
|
||||||
|
Reason: "Test",
|
||||||
|
ContactInfo: "Geen",
|
||||||
|
Date: time.Now().Local(),
|
||||||
|
},
|
||||||
|
CertType: 2,
|
||||||
|
Approval: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data.ObjectId = uint32(rdr.XrefInformation.ItemCount) + 3
|
||||||
|
|
||||||
|
context := SignContext{
|
||||||
|
Filesize: size + 1,
|
||||||
|
PDFReader: rdr,
|
||||||
|
InputFile: input_file,
|
||||||
|
VisualSignData: VisualSignData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount),
|
||||||
|
},
|
||||||
|
CatalogData: CatalogData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 1,
|
||||||
|
},
|
||||||
|
InfoData: InfoData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 2,
|
||||||
|
},
|
||||||
|
SignData: sign_data,
|
||||||
|
}
|
||||||
|
|
||||||
|
info, err := context.createInfo()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("%s", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
expected_info := "12 0 obj\n<<>>\nendobj\n"
|
||||||
|
if info != expected_info {
|
||||||
|
t.Errorf("Info mismatch, expected %s, but got %s", expected_info, info)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestCreateInfo(t *testing.T) {
|
||||||
|
input_file, err := os.Open("../testfiles/testfile12.pdf")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finfo, err := input_file.Stat()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
size := finfo.Size()
|
||||||
|
|
||||||
|
rdr, err := pdf.NewReader(input_file, size)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data := SignData{
|
||||||
|
Signature: SignDataSignature{
|
||||||
|
Info: SignDataSignatureInfo{
|
||||||
|
Name: "Jeroen Bobbeldijk",
|
||||||
|
Location: "Rotterdam",
|
||||||
|
Reason: "Test",
|
||||||
|
ContactInfo: "Geen",
|
||||||
|
Date: time.Now().Local(),
|
||||||
|
},
|
||||||
|
CertType: 2,
|
||||||
|
Approval: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data.ObjectId = uint32(rdr.XrefInformation.ItemCount) + 3
|
||||||
|
|
||||||
|
context := SignContext{
|
||||||
|
Filesize: size + 1,
|
||||||
|
PDFReader: rdr,
|
||||||
|
InputFile: input_file,
|
||||||
|
VisualSignData: VisualSignData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount),
|
||||||
|
},
|
||||||
|
CatalogData: CatalogData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 1,
|
||||||
|
},
|
||||||
|
InfoData: InfoData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 2,
|
||||||
|
},
|
||||||
|
SignData: sign_data,
|
||||||
|
}
|
||||||
|
|
||||||
|
info, err := context.createInfo()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("%s", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
expected_info := "18 0 obj\n<</Author(User: Isamu Ohzawa [isamu])/CreationDate(D:19981025161109)/Creator(FastIO Systems: cover.c)/Keywords(ClibPDF, ANSI C Library, Acrobat, PDF, Dynamic Web, Graph, Plot)/Producer([ClibPDF Library 0.96] NEXTSTEP or OPENSTEP)/Subject(ANSI C Library for Direct PDF Generation)/Title(ClibPDF Reference Manual)>>\nendobj\n"
|
||||||
|
|
||||||
|
if info != expected_info {
|
||||||
|
t.Errorf("Info mismatch, expected %s, but got %s", expected_info, info)
|
||||||
|
}
|
||||||
|
}
|
81
sign/pdfsignature_test.go
Normal file
81
sign/pdfsignature_test.go
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
package sign
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"bitbucket.org/digitorus/pdf"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestCreateSignature(t *testing.T) {
|
||||||
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finfo, err := input_file.Stat()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
size := finfo.Size()
|
||||||
|
|
||||||
|
rdr, err := pdf.NewReader(input_file, size)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
timezone, _ := time.LoadLocation("Europe/Tallinn")
|
||||||
|
now := time.Date(2017, 9, 23, 14, 39, 0, 0, timezone)
|
||||||
|
|
||||||
|
sign_data := SignData{
|
||||||
|
Signature: SignDataSignature{
|
||||||
|
Info: SignDataSignatureInfo{
|
||||||
|
Name: "Jeroen Bobbeldijk",
|
||||||
|
Location: "Rotterdam",
|
||||||
|
Reason: "Test",
|
||||||
|
ContactInfo: "Geen",
|
||||||
|
Date: now,
|
||||||
|
},
|
||||||
|
CertType: 2,
|
||||||
|
Approval: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data.ObjectId = uint32(rdr.XrefInformation.ItemCount) + 3
|
||||||
|
|
||||||
|
context := SignContext{
|
||||||
|
Filesize: size + 1,
|
||||||
|
PDFReader: rdr,
|
||||||
|
InputFile: input_file,
|
||||||
|
VisualSignData: VisualSignData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount),
|
||||||
|
},
|
||||||
|
CatalogData: CatalogData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 1,
|
||||||
|
},
|
||||||
|
InfoData: InfoData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 2,
|
||||||
|
},
|
||||||
|
SignData: sign_data,
|
||||||
|
}
|
||||||
|
|
||||||
|
expected_signature := "13 0 obj\n<< /Type /Sig /Filter /Adobe.PPKLite /SubFilter /adbe.pkcs7.detached /ByteRange[0 ********** ********** **********] /Contents<> /Reference [ << /Type /SigRef /TransformMethod /DocMDP /TransformParams << /Type /TransformParams /P 2 /V /1.2 >> >> ] /Name (Jeroen Bobbeldijk) /Location (Rotterdam) /Reason (Test) /ContactInfo (Geen) /M (D:20170923143900+03'00') >>\nendobj\n"
|
||||||
|
|
||||||
|
signature, byte_range_start_byte, signature_contents_start_byte := context.createSignaturePlaceholder()
|
||||||
|
|
||||||
|
if signature != expected_signature {
|
||||||
|
t.Errorf("Signature mismatch, expected %s, but got %s", expected_signature, signature)
|
||||||
|
}
|
||||||
|
|
||||||
|
if byte_range_start_byte != 78 {
|
||||||
|
t.Errorf("Byte range start mismatch, expected %d, but got %d", 78, byte_range_start_byte)
|
||||||
|
}
|
||||||
|
|
||||||
|
if signature_contents_start_byte != 135 {
|
||||||
|
t.Errorf("Signature contents start byte mismatch, expected %d, but got %d", 135, signature_contents_start_byte)
|
||||||
|
}
|
||||||
|
}
|
77
sign/pdfvisualsignature_test.go
Normal file
77
sign/pdfvisualsignature_test.go
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
package sign
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"bitbucket.org/digitorus/pdf"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestVisualSignature(t *testing.T) {
|
||||||
|
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
finfo, err := input_file.Stat()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
size := finfo.Size()
|
||||||
|
|
||||||
|
rdr, err := pdf.NewReader(input_file, size)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Failed to load test PDF")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
timezone, _ := time.LoadLocation("Europe/Tallinn")
|
||||||
|
now := time.Date(2017, 9, 23, 14, 39, 0, 0, timezone)
|
||||||
|
|
||||||
|
sign_data := SignData{
|
||||||
|
Signature: SignDataSignature{
|
||||||
|
Info: SignDataSignatureInfo{
|
||||||
|
Name: "Jeroen Bobbeldijk",
|
||||||
|
Location: "Rotterdam",
|
||||||
|
Reason: "Test",
|
||||||
|
ContactInfo: "Geen",
|
||||||
|
Date: now,
|
||||||
|
},
|
||||||
|
CertType: 2,
|
||||||
|
Approval: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
sign_data.ObjectId = uint32(rdr.XrefInformation.ItemCount) + 3
|
||||||
|
|
||||||
|
context := SignContext{
|
||||||
|
Filesize: size + 1,
|
||||||
|
PDFReader: rdr,
|
||||||
|
InputFile: input_file,
|
||||||
|
VisualSignData: VisualSignData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount),
|
||||||
|
},
|
||||||
|
CatalogData: CatalogData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 1,
|
||||||
|
},
|
||||||
|
InfoData: InfoData{
|
||||||
|
ObjectId: uint32(rdr.XrefInformation.ItemCount) + 2,
|
||||||
|
},
|
||||||
|
SignData: sign_data,
|
||||||
|
}
|
||||||
|
|
||||||
|
expected_visual_signature := "10 0 obj\n<< /Type /Annot /Subtype /Widget /Rect [0 0 0 0] /P 4 0 R /F 132 /FT /Sig /T (Signature) /Ff 0 /V 13 0 R >>\nendobj\n"
|
||||||
|
|
||||||
|
visual_signature, err := context.createVisualSignature()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("%s", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if visual_signature != expected_visual_signature {
|
||||||
|
t.Errorf("Visual signature mismatch, expected %s, but got %s", expected_visual_signature, visual_signature)
|
||||||
|
}
|
||||||
|
}
|
@@ -191,7 +191,7 @@ func BenchmarkSignPDF(b *testing.B) {
|
|||||||
certificate_chains := make([][]*x509.Certificate, 0)
|
certificate_chains := make([][]*x509.Certificate, 0)
|
||||||
|
|
||||||
for n := 0; n < b.N; n++ {
|
for n := 0; n < b.N; n++ {
|
||||||
err := SignFile("../testfiles/benchmark.pdf", "../testfiles/benchmark.pdf.tmp", SignData{
|
err := SignFile("../testfiles/testfile20.pdf", "../testfiles/testfile20.pdf.tmp", SignData{
|
||||||
Signature: SignDataSignature{
|
Signature: SignDataSignature{
|
||||||
Info: SignDataSignatureInfo{
|
Info: SignDataSignatureInfo{
|
||||||
Name: "Jeroen Bobbeldijk",
|
Name: "Jeroen Bobbeldijk",
|
||||||
@@ -213,10 +213,10 @@ func BenchmarkSignPDF(b *testing.B) {
|
|||||||
RevocationFunction: DefaultEmbedRevocationStatusFunction,
|
RevocationFunction: DefaultEmbedRevocationStatusFunction,
|
||||||
})
|
})
|
||||||
|
|
||||||
os.Remove("../testfiles/benchmark.pdf.tmp")
|
os.Remove("../testfiles/testfile20.pdf.tmp")
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
b.Errorf("%s: %s", "benchmark.pdf", err.Error())
|
b.Errorf("%s: %s", "testfile20.pdf", err.Error())
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
BIN
testfiles/testfile12.pdf
Normal file
BIN
testfiles/testfile12.pdf
Normal file
Binary file not shown.
Reference in New Issue
Block a user