You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

FileIDGeneratorTestCase.java 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /* $Id$ */
  18. package org.apache.fop.pdf;
  19. import java.util.ArrayList;
  20. import java.util.Arrays;
  21. import java.util.Collection;
  22. import org.junit.Before;
  23. import org.junit.Test;
  24. import org.junit.runner.RunWith;
  25. import org.junit.runners.Parameterized;
  26. import org.junit.runners.Parameterized.Parameters;
  27. import static org.junit.Assert.assertEquals;
  28. import static org.junit.Assert.assertNotNull;
  29. import static org.junit.Assert.assertTrue;
  30. /**
  31. * Tests the {@link FileIDGenerator} class.
  32. */
  33. @RunWith(Parameterized.class)
  34. public class FileIDGeneratorTestCase {
  35. /** The generator under test. */
  36. protected FileIDGenerator fileIDGenerator;
  37. private TestGetter initializer;
  38. @Parameters
  39. public static Collection<TestGetter[]> getParameters() {
  40. ArrayList<TestGetter[]> params = new ArrayList<TestGetter[]>();
  41. params.add(new TestGetter[] { new RandomFileIDGeneratorTest() });
  42. params.add(new TestGetter[] { new DigestFileIDGeneratorTest() });
  43. return params;
  44. }
  45. public FileIDGeneratorTestCase(TestGetter initializer) {
  46. this.initializer = initializer;
  47. }
  48. @Before
  49. public void setUp() throws Exception {
  50. fileIDGenerator = initializer.getSut();
  51. }
  52. /** Tests that the getOriginalFileID method generates valid output. */
  53. @Test
  54. public void testOriginal() {
  55. byte[] fileID = fileIDGenerator.getOriginalFileID();
  56. fileIDMustBeValid(fileID);
  57. }
  58. /** Tests that the getUpdatedFileID method generates valid output. */
  59. @Test
  60. public void testUpdated() {
  61. byte[] fileID = fileIDGenerator.getUpdatedFileID();
  62. fileIDMustBeValid(fileID);
  63. }
  64. private void fileIDMustBeValid(byte[] fileID) {
  65. assertNotNull(fileID);
  66. assertEquals(16, fileID.length);
  67. }
  68. /** Tests that multiple calls to getOriginalFileID method always return the same value. */
  69. @Test
  70. public void testOriginalMultipleCalls() {
  71. byte[] fileID1 = fileIDGenerator.getUpdatedFileID();
  72. byte[] fileID2 = fileIDGenerator.getUpdatedFileID();
  73. assertTrue(Arrays.equals(fileID1, fileID2));
  74. }
  75. /** Tests that getUpdatedFileID returns the same value as getOriginalFileID. */
  76. @Test
  77. public void testUpdateEqualsOriginal() {
  78. byte[] originalFileID = fileIDGenerator.getOriginalFileID();
  79. byte[] updatedFileID = fileIDGenerator.getUpdatedFileID();
  80. assertTrue(Arrays.equals(originalFileID, updatedFileID));
  81. }
  82. private interface TestGetter {
  83. FileIDGenerator getSut() throws Exception;
  84. }
  85. /**
  86. * Tests the random file ID generator.
  87. */
  88. private static class RandomFileIDGeneratorTest implements TestGetter {
  89. public FileIDGenerator getSut() throws Exception {
  90. return FileIDGenerator.getRandomFileIDGenerator();
  91. }
  92. }
  93. /**
  94. * Tests the file ID generator based on an MD5 digest.
  95. */
  96. private static class DigestFileIDGeneratorTest implements TestGetter {
  97. public FileIDGenerator getSut() throws Exception {
  98. return FileIDGenerator.getDigestFileIDGenerator(
  99. new PDFDocument("Apache FOP"));
  100. }
  101. }
  102. }