|
17 | 17 |
|
18 | 18 |
|
19 | 19 |
|
| 20 | + |
| 21 | +import static org.junit.Assert.assertEquals; |
| 22 | +import static org.junit.Assert.assertTrue; |
| 23 | + |
20 | 24 | import org.culturegraph.mf.framework.DefaultObjectReceiver;
|
21 |
| -import org.culturegraph.mf.framework.StreamReceiver; |
22 |
| -import org.culturegraph.mf.stream.converter.xml.SimpleXmlEncoder; |
23 |
| -import org.junit.Assert; |
| 25 | +import org.junit.Before; |
24 | 26 | import org.junit.Test;
|
25 | 27 |
|
26 | 28 | /**
|
27 |
| - * Tests {@link SimpleXmlEncoder}. |
| 29 | + * Tests for class {@link SimpleXmlEncoder}. |
28 | 30 | *
|
29 | 31 | * @author Markus Geipel
|
| 32 | + * @author Christoph Böhme |
30 | 33 | *
|
31 | 34 | */
|
32 | 35 | public final class SimpleXmlEncoderTest {
|
33 | 36 |
|
34 |
| - |
35 | 37 | private static final String TAG = "tag";
|
36 | 38 | private static final String VALUE = "value";
|
37 | 39 |
|
38 |
| - //TODO add more tests! |
| 40 | + private SimpleXmlEncoder simpleXmlEncoder; |
| 41 | + |
| 42 | + private StringBuilder resultCollector; |
| 43 | + |
| 44 | + @Before |
| 45 | + public void initSystemUnderTest() { |
| 46 | + simpleXmlEncoder = new SimpleXmlEncoder(); |
| 47 | + simpleXmlEncoder.setReceiver( |
| 48 | + new DefaultObjectReceiver<String>() { |
| 49 | + @Override |
| 50 | + public void process(final String obj) { |
| 51 | + resultCollector.append(obj); |
| 52 | + } |
| 53 | + }); |
| 54 | + resultCollector = new StringBuilder(); |
| 55 | +} |
39 | 56 |
|
| 57 | + @Test |
| 58 | + public void issue249_shouldNotEmitClosingRootTagOnCloseStreamIfNoOutputWasGenerated() { |
| 59 | + simpleXmlEncoder.closeStream(); |
| 60 | + |
| 61 | + assertTrue(getResultXml().isEmpty()); |
| 62 | + } |
40 | 63 |
|
41 | 64 | @Test
|
42 |
| - public void testShouldOnlyEscapeFiveChars() { |
| 65 | + public void shouldOnlyEscapeXmlReservedCharacters() { |
43 | 66 | final StringBuilder builder = new StringBuilder();
|
44 | 67 |
|
45 | 68 | SimpleXmlEncoder.writeEscaped(builder , "&<>'\" üäö");
|
46 | 69 |
|
47 |
| - Assert.assertEquals("&<>'" üäö", builder.toString()); |
| 70 | + assertEquals("&<>'" üäö", builder.toString()); |
48 | 71 | }
|
49 | 72 |
|
50 | 73 | @Test
|
51 |
| - public void testShouldHandleSeparateRoots(){ |
52 |
| - final SimpleXmlEncoder writer = new SimpleXmlEncoder(); |
53 |
| - writer.setRootTag("root"); |
54 |
| - writer.setRecordTag("record"); |
55 |
| - writer.setWriteXmlHeader(false); |
56 |
| - |
57 |
| - //separateRoots=false |
58 |
| - final StringBuilder builder1 = new StringBuilder(); |
59 |
| - writer.setReceiver(new DefaultObjectReceiver<String>() { |
60 |
| - @Override |
61 |
| - public void process(final String obj) { |
62 |
| - builder1.append(obj); |
63 |
| - } |
64 |
| - }); |
65 |
| - |
66 |
| - writer.setSeparateRoots(false); |
| 74 | + public void shouldWrapEachRecordInRootTagIfSeparateRootsIsTrue() { |
| 75 | + simpleXmlEncoder.setSeparateRoots(true); |
67 | 76 |
|
| 77 | + emitTwoRecords(); |
68 | 78 |
|
69 |
| - writeTwoRecords(writer); |
70 |
| - |
71 |
| - Assert.assertEquals("<root><record><tag>value</tag></record><record><tag>value</tag></record></root>", builder1.toString().replaceAll("[\\n\\s]", "")); |
72 |
| - |
73 |
| - //separateRoots=true |
74 |
| - final StringBuilder builder2 = new StringBuilder(); |
75 |
| - writer.setReceiver(new DefaultObjectReceiver<String>() { |
76 |
| - @Override |
77 |
| - public void process(final String obj) { |
78 |
| - builder2.append(obj); |
79 |
| - } |
80 |
| - }); |
81 |
| - |
82 |
| - writer.setSeparateRoots(true); |
83 |
| - |
84 |
| - writeTwoRecords(writer); |
| 79 | + assertEquals("<?xml version=\"1.0\" encoding=\"UTF-8\"?><records><record><tag>value</tag></record></records><?xml version=\"1.0\" encoding=\"UTF-8\"?><records><record><tag>value</tag></record></records>", |
| 80 | + getResultXml()); |
| 81 | + } |
85 | 82 |
|
86 |
| - Assert.assertEquals("<root><record><tag>value</tag></record></root><root><record><tag>value</tag></record></root>", builder2.toString().replaceAll("[\\n\\s]", "")); |
| 83 | + @Test |
| 84 | + public void shouldWrapAllRecordsInOneRootTagtIfSeparateRootsIsFalse() { |
| 85 | + simpleXmlEncoder.setSeparateRoots(false); |
87 | 86 |
|
| 87 | + emitTwoRecords(); |
88 | 88 |
|
| 89 | + assertEquals("<?xml version=\"1.0\" encoding=\"UTF-8\"?><records><record><tag>value</tag></record><record><tag>value</tag></record></records>", |
| 90 | + getResultXml()); |
89 | 91 | }
|
90 | 92 |
|
91 |
| - |
92 |
| - |
93 |
| - private static void writeTwoRecords(final StreamReceiver writer) { |
94 |
| - writer.startRecord("X"); |
95 |
| - writer.literal(TAG, VALUE); |
96 |
| - writer.endRecord(); |
97 |
| - writer.startRecord("Y"); |
98 |
| - writer.literal(TAG, VALUE); |
99 |
| - writer.endRecord(); |
100 |
| - writer.closeStream(); |
| 93 | + private void emitTwoRecords() { |
| 94 | + simpleXmlEncoder.startRecord("X"); |
| 95 | + simpleXmlEncoder.literal(TAG, VALUE); |
| 96 | + simpleXmlEncoder.endRecord(); |
| 97 | + simpleXmlEncoder.startRecord("Y"); |
| 98 | + simpleXmlEncoder.literal(TAG, VALUE); |
| 99 | + simpleXmlEncoder.endRecord(); |
| 100 | + simpleXmlEncoder.closeStream(); |
101 | 101 | }
|
102 | 102 |
|
| 103 | + private String getResultXml() { |
| 104 | + return resultCollector.toString().replaceAll("[\\n\\t]", ""); |
| 105 | + } |
103 | 106 |
|
104 | 107 | }
|
0 commit comments