diff options
author | Thomas <> | 2024-02-14 16:23:17 +0100 |
---|---|---|
committer | Thomas <> | 2024-02-14 16:23:17 +0100 |
commit | 5f33e4dbafae204a3d9610c268d050068c096105 (patch) | |
tree | 56791478c355a5ba96a60340dad0e55f295709eb /pdf-as-tests/src/test/java/at/gv/egiz | |
parent | 368df3db93f29e594393b81c6ab193bbea758744 (diff) | |
parent | 8e3a9848138798b079a5e4cdc5ee717a76f1389b (diff) | |
download | pdf-as-4-5f33e4dbafae204a3d9610c268d050068c096105.tar.gz pdf-as-4-5f33e4dbafae204a3d9610c268d050068c096105.tar.bz2 pdf-as-4-5f33e4dbafae204a3d9610c268d050068c096105.zip |
Merge branch 'development' of gitlab.iaik.tugraz.at:egiz/pdf-as-4 into development
Diffstat (limited to 'pdf-as-tests/src/test/java/at/gv/egiz')
-rw-r--r-- | pdf-as-tests/src/test/java/at/gv/egiz/param_tests/SignaturePositionTest.java | 62 |
1 files changed, 29 insertions, 33 deletions
diff --git a/pdf-as-tests/src/test/java/at/gv/egiz/param_tests/SignaturePositionTest.java b/pdf-as-tests/src/test/java/at/gv/egiz/param_tests/SignaturePositionTest.java index cb06b669..84d12cfb 100644 --- a/pdf-as-tests/src/test/java/at/gv/egiz/param_tests/SignaturePositionTest.java +++ b/pdf-as-tests/src/test/java/at/gv/egiz/param_tests/SignaturePositionTest.java @@ -1,6 +1,9 @@ package at.gv.egiz.param_tests; -import static org.junit.Assert.*; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertTrue; +import static org.junit.Assert.fail; import java.awt.Color; import java.awt.Graphics; @@ -16,10 +19,8 @@ import java.util.List; import javax.imageio.ImageIO; -import org.icepdf.core.pobjects.Document; -import org.icepdf.core.pobjects.PDimension; -import org.icepdf.core.pobjects.Page; -import org.icepdf.core.util.GraphicsRenderingHints; +import org.apache.pdfbox.pdmodel.PDDocument; +import org.apache.pdfbox.rendering.PDFRenderer; import org.junit.Assume; import org.junit.BeforeClass; import org.junit.Test; @@ -222,8 +223,16 @@ public class SignaturePositionTest extends SignatureTest { BufferedImage sigPageImage = captureImage(baseTestData.getOutputFile(), sigPageNumber); assertNotNull("Could not get image of page", sigPageImage); + + /* + * Re-classify. + * Only use this after manually check all signature block results that currently fail! + * + * <code>ImageIO.write(sigPageImage, "png", new File(refImageFileName));</code> + */ + BufferedImage refImage = ImageIO.read(new File(refImageFileName)); - assertNotNull("Could not get reference image", sigPageImage); + assertNotNull("Could not get reference image", refImage); assertEquals("Width of image differs from reference", refImage.getWidth(), sigPageImage.getWidth()); @@ -235,7 +244,7 @@ public class SignaturePositionTest extends SignatureTest { int imageHeight = sigPageImage.getHeight(); ignoreAreas(sigPageGraphics, imageHeight); ignoreAreas(refImageGraphics, imageHeight); - + String refImageIgnored = extractDirectoryString(baseTestData .getOutputFile()) + "refImage_ignored.png"; ImageIO.write(refImage, "png", new File(refImageIgnored)); @@ -303,8 +312,7 @@ public class SignaturePositionTest extends SignatureTest { } /** - * This method captures an image of a page of a PDF document. This is done - * using the rendering capabilities of ICEPDF. + * This method captures an image of a page of a PDF document. * * @param fileName * the name of the PDF file @@ -313,30 +321,18 @@ public class SignaturePositionTest extends SignatureTest { * @return the captured image * @throws InterruptedException */ - private BufferedImage captureImage(String fileName, int pageNumber) throws InterruptedException { - Document document = new Document(); - try { - document.setFile(fileName); - } catch (Exception e) { - document.dispose(); - fail(String - .format("Not possible to capture page %d of file %s, because of %s.", - pageNumber, fileName, e.getMessage())); - } - Page page = document.getPageTree().getPage(pageNumber - 1); - page.init(); - PDimension sz = page.getSize(Page.BOUNDARY_CROPBOX, 0, ZOOM); - - int pageWidth = (int) sz.getWidth(); - int pageHeight = (int) sz.getHeight(); - - BufferedImage image = new BufferedImage(pageWidth, pageHeight, - BufferedImage.TYPE_4BYTE_ABGR); - Graphics g = image.createGraphics(); - page.paint(g, GraphicsRenderingHints.PRINT, Page.BOUNDARY_CROPBOX, 0, - ZOOM); - document.dispose(); - return image; + private BufferedImage captureImage(String fileName, int pageNumber) throws InterruptedException { + try { + PDDocument signedPdf = PDDocument.load(new File(fileName)); + PDFRenderer renderer = new PDFRenderer(signedPdf); + return renderer.renderImage(pageNumber - 1, ZOOM); + + } catch (IOException e) { + fail(String + .format("Not possible to capture page %d of file %s, because of %s.", + pageNumber, fileName, e.getMessage())); + return null; + } } } |