aboutsummaryrefslogtreecommitdiffstats
path: root/test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java
diff options
context:
space:
mode:
Diffstat (limited to 'test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java')
-rw-r--r--test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java270
1 files changed, 135 insertions, 135 deletions
diff --git a/test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java b/test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java
index 0ef5171aa..3f84fac2e 100644
--- a/test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java
+++ b/test/java/org/apache/fop/pdf/PDFDictionaryTestCase.java
@@ -1,135 +1,135 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-/* $Id$ */
-
-package org.apache.fop.pdf;
-
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNull;
-import static org.junit.Assert.fail;
-
-import java.io.ByteArrayOutputStream;
-import java.io.IOException;
-
-import org.apache.commons.io.output.CountingOutputStream;
-import org.junit.Before;
-import org.junit.Test;
-
-
-/**
- * Test case for {@link PDFDictionary}.
- */
-public class PDFDictionaryTestCase extends PDFObjectTestCase {
- /** The test subject */
- private PDFDictionary pdfDictUnderTest;
- private PDFArray testArray;
- private PDFNumber testNumber;
- /** The order in which these objects are put into the dictionary MUST be maintained. */
- private String expectedOutput = "<<\n"
- + " /String (TestValue)\n"
- + " /int 10\n"
- + " /double 3.1\n"
- + " /array [1 (two) 20]\n"
- + " /number 20\n"
- + " /null null\n"
- + ">>\n";
-
- @Before
- public void setUp() {
- // A PDFNumber for testing, this DOES have a parent
- testNumber = new PDFNumber();
- testNumber.setParent(parent);
- testNumber.setNumber(20);
- // An array for testing, this DOES NOT have a parent
- testArray = new PDFArray();
- testArray.add(1);
- testArray.add("two");
- testArray.add(testNumber);
- // Populating the dictionary with a parent, document and the various objects
- pdfDictUnderTest = new PDFDictionary(parent);
- pdfDictUnderTest.setDocument(doc);
- pdfDictUnderTest.put("String", "TestValue");
- pdfDictUnderTest.put("int", 10);
- pdfDictUnderTest.put("double", Double.valueOf(3.1));
- pdfDictUnderTest.put("array", testArray);
- pdfDictUnderTest.put("number", testNumber);
- // null is a valid PDF object
- pdfDictUnderTest.put("null", null);
- // test that the interface is maintained
- pdfObjectUnderTest = pdfDictUnderTest;
- }
-
- /**
- * Tests put() - tests that the object is put into the dictionary and it is handled if it is a
- * {@link PDFObject}.
- */
- @Test
- public void testPut() {
- // The "put()" commands have already been done in setUp(), so just test them.
- assertEquals("TestValue", pdfDictUnderTest.get("String"));
- assertEquals(10, pdfDictUnderTest.get("int"));
- assertEquals(3.1, pdfDictUnderTest.get("double"));
- // With PDFObjects, if they DO NOT have a parent, the dict becomes their parent.
- assertEquals(testArray, pdfDictUnderTest.get("array"));
- assertEquals(pdfDictUnderTest, testArray.getParent());
- // With PDFObjects, if they DO have a parent, the dict DOES NOT change the parent object.
- assertEquals(testNumber, pdfDictUnderTest.get("number"));
- // Test it doesn't explode when we try to get a non-existent entry
- assertNull(pdfDictUnderTest.get("Not in dictionary"));
- // Tests that we can over-write objects
- pdfDictUnderTest.put("array", 10);
- assertEquals(10, pdfDictUnderTest.get("array"));
- // Test that nulls are handled appropriately
- assertNull(pdfDictUnderTest.get("null"));
- }
-
- /**
- * Tests get() - tests that objects can be properly retrieved from the dictionary.
- */
- @Test
- public void testGet() {
- // Tested fairly comprehensively in testPut().
- }
-
- /**
- * Tests writeDictionary() - tests that the dictionary is properly written to the output-stream.
- */
- @Test
- public void testWriteDictionary() {
- // Ensure that the objects stored in the dictionary are streamed in the correct format.
- ByteArrayOutputStream outStream = new ByteArrayOutputStream();
- CountingOutputStream cout = new CountingOutputStream(outStream);
- StringBuilder textBuffer = new StringBuilder();
- try {
- pdfDictUnderTest.writeDictionary(cout, textBuffer);
- PDFDocument.flushTextBuffer(textBuffer, cout);
- assertEquals(expectedOutput, outStream.toString());
- } catch (IOException e) {
- fail("IOException: " + e.getMessage());
- }
- }
-
- /**
- * Tests output() - test that this object can write itself to an output stream.
- * @throws IOException error caused by I/O
- */
- @Test
- public void testOutput() throws IOException {
- testOutputStreams(expectedOutput, pdfDictUnderTest);
- }
-}
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+/* $Id$ */
+
+package org.apache.fop.pdf;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertNull;
+import static org.junit.Assert.fail;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+
+import org.apache.commons.io.output.CountingOutputStream;
+import org.junit.Before;
+import org.junit.Test;
+
+
+/**
+ * Test case for {@link PDFDictionary}.
+ */
+public class PDFDictionaryTestCase extends PDFObjectTestCase {
+ /** The test subject */
+ private PDFDictionary pdfDictUnderTest;
+ private PDFArray testArray;
+ private PDFNumber testNumber;
+ /** The order in which these objects are put into the dictionary MUST be maintained. */
+ private String expectedOutput = "<<\n"
+ + " /String (TestValue)\n"
+ + " /int 10\n"
+ + " /double 3.1\n"
+ + " /array [1 (two) 20]\n"
+ + " /number 20\n"
+ + " /null null\n"
+ + ">>\n";
+
+ @Before
+ public void setUp() {
+ // A PDFNumber for testing, this DOES have a parent
+ testNumber = new PDFNumber();
+ testNumber.setParent(parent);
+ testNumber.setNumber(20);
+ // An array for testing, this DOES NOT have a parent
+ testArray = new PDFArray();
+ testArray.add(1);
+ testArray.add("two");
+ testArray.add(testNumber);
+ // Populating the dictionary with a parent, document and the various objects
+ pdfDictUnderTest = new PDFDictionary(parent);
+ pdfDictUnderTest.setDocument(doc);
+ pdfDictUnderTest.put("String", "TestValue");
+ pdfDictUnderTest.put("int", 10);
+ pdfDictUnderTest.put("double", Double.valueOf(3.1));
+ pdfDictUnderTest.put("array", testArray);
+ pdfDictUnderTest.put("number", testNumber);
+ // null is a valid PDF object
+ pdfDictUnderTest.put("null", null);
+ // test that the interface is maintained
+ pdfObjectUnderTest = pdfDictUnderTest;
+ }
+
+ /**
+ * Tests put() - tests that the object is put into the dictionary and it is handled if it is a
+ * {@link PDFObject}.
+ */
+ @Test
+ public void testPut() {
+ // The "put()" commands have already been done in setUp(), so just test them.
+ assertEquals("TestValue", pdfDictUnderTest.get("String"));
+ assertEquals(10, pdfDictUnderTest.get("int"));
+ assertEquals(3.1, pdfDictUnderTest.get("double"));
+ // With PDFObjects, if they DO NOT have a parent, the dict becomes their parent.
+ assertEquals(testArray, pdfDictUnderTest.get("array"));
+ assertEquals(pdfDictUnderTest, testArray.getParent());
+ // With PDFObjects, if they DO have a parent, the dict DOES NOT change the parent object.
+ assertEquals(testNumber, pdfDictUnderTest.get("number"));
+ // Test it doesn't explode when we try to get a non-existent entry
+ assertNull(pdfDictUnderTest.get("Not in dictionary"));
+ // Tests that we can over-write objects
+ pdfDictUnderTest.put("array", 10);
+ assertEquals(10, pdfDictUnderTest.get("array"));
+ // Test that nulls are handled appropriately
+ assertNull(pdfDictUnderTest.get("null"));
+ }
+
+ /**
+ * Tests get() - tests that objects can be properly retrieved from the dictionary.
+ */
+ @Test
+ public void testGet() {
+ // Tested fairly comprehensively in testPut().
+ }
+
+ /**
+ * Tests writeDictionary() - tests that the dictionary is properly written to the output-stream.
+ */
+ @Test
+ public void testWriteDictionary() {
+ // Ensure that the objects stored in the dictionary are streamed in the correct format.
+ ByteArrayOutputStream outStream = new ByteArrayOutputStream();
+ CountingOutputStream cout = new CountingOutputStream(outStream);
+ StringBuilder textBuffer = new StringBuilder();
+ try {
+ pdfDictUnderTest.writeDictionary(cout, textBuffer);
+ PDFDocument.flushTextBuffer(textBuffer, cout);
+ assertEquals(expectedOutput, outStream.toString());
+ } catch (IOException e) {
+ fail("IOException: " + e.getMessage());
+ }
+ }
+
+ /**
+ * Tests output() - test that this object can write itself to an output stream.
+ * @throws IOException error caused by I/O
+ */
+ @Test
+ public void testOutput() throws IOException {
+ testOutputStreams(expectedOutput, pdfDictUnderTest);
+ }
+}