Tests and benchmark
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1,4 +1,4 @@
|
||||
.idea
|
||||
*.pdf
|
||||
*.pdf.*
|
||||
!benchmark.pdf
|
||||
!testfile*.pdf
|
@@ -118,7 +118,7 @@ func TestWritePartFromSourceFileToTargetFile(t *testing.T) {
|
||||
var b bytes.Buffer
|
||||
writer := bufio.NewWriter(&b)
|
||||
|
||||
input_file, err := os.Open("../testfiles/benchmark.pdf")
|
||||
input_file, err := os.Open("../testfiles/testfile20.pdf")
|
||||
if err != nil {
|
||||
t.Errorf("Failed to load test PDF")
|
||||
return
|
||||
@@ -162,7 +162,7 @@ func TestWritePartFromSourceFileToTargetFile(t *testing.T) {
|
||||
}
|
||||
|
||||
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 {
|
||||
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)
|
||||
|
||||
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{
|
||||
Info: SignDataSignatureInfo{
|
||||
Name: "Jeroen Bobbeldijk",
|
||||
@@ -213,10 +213,10 @@ func BenchmarkSignPDF(b *testing.B) {
|
||||
RevocationFunction: DefaultEmbedRevocationStatusFunction,
|
||||
})
|
||||
|
||||
os.Remove("../testfiles/benchmark.pdf.tmp")
|
||||
os.Remove("../testfiles/testfile20.pdf.tmp")
|
||||
|
||||
if err != nil {
|
||||
b.Errorf("%s: %s", "benchmark.pdf", err.Error())
|
||||
b.Errorf("%s: %s", "testfile20.pdf", err.Error())
|
||||
return
|
||||
}
|
||||
}
|
||||
|
BIN
testfiles/testfile12.pdf
Normal file
BIN
testfiles/testfile12.pdf
Normal file
Binary file not shown.
Reference in New Issue
Block a user