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.

TestProblems.java 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385
  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. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. ==================================================================== */
  15. package org.apache.poi.hwpf.usermodel;
  16. import org.apache.poi.EncryptedDocumentException;
  17. import org.apache.poi.hwpf.HWPFDocument;
  18. import org.apache.poi.hwpf.HWPFTestCase;
  19. import org.apache.poi.hwpf.HWPFTestDataSamples;
  20. import org.apache.poi.hwpf.model.StyleSheet;
  21. /**
  22. * Test various problem documents
  23. *
  24. * @author Nick Burch (nick at torchbox dot com)
  25. */
  26. public final class TestProblems extends HWPFTestCase {
  27. /**
  28. * ListEntry passed no ListTable
  29. */
  30. public void testListEntryNoListTable() {
  31. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("ListEntryNoListTable.doc");
  32. Range r = doc.getRange();
  33. StyleSheet styleSheet = doc.getStyleSheet();
  34. for (int x = 0; x < r.numSections(); x++) {
  35. Section s = r.getSection(x);
  36. for (int y = 0; y < s.numParagraphs(); y++) {
  37. Paragraph paragraph = s.getParagraph(y);
  38. // System.out.println(paragraph.getCharacterRun(0).text());
  39. }
  40. }
  41. }
  42. /**
  43. * AIOOB for TableSprmUncompressor.unCompressTAPOperation
  44. */
  45. public void testSprmAIOOB() {
  46. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("AIOOB-Tap.doc");
  47. Range r = doc.getRange();
  48. StyleSheet styleSheet = doc.getStyleSheet();
  49. for (int x = 0; x < r.numSections(); x++) {
  50. Section s = r.getSection(x);
  51. for (int y = 0; y < s.numParagraphs(); y++) {
  52. Paragraph paragraph = s.getParagraph(y);
  53. // System.out.println(paragraph.getCharacterRun(0).text());
  54. }
  55. }
  56. }
  57. /**
  58. * Test for TableCell not skipping the last paragraph. Bugs #45062 and
  59. * #44292
  60. */
  61. public void testTableCellLastParagraph() {
  62. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("Bug44292.doc");
  63. Range r = doc.getRange();
  64. assertEquals(6, r.numParagraphs());
  65. assertEquals(0, r.getStartOffset());
  66. assertEquals(87, r.getEndOffset());
  67. // Paragraph with table
  68. Paragraph p = r.getParagraph(0);
  69. assertEquals(0, p.getStartOffset());
  70. assertEquals(20, p.getEndOffset());
  71. // Check a few bits of the table directly
  72. assertEquals("One paragraph is ok\7", r.getParagraph(0).text());
  73. assertEquals("First para is ok\r", r.getParagraph(1).text());
  74. assertEquals("Second paragraph is skipped\7", r.getParagraph(2).text());
  75. assertEquals("One paragraph is ok\7", r.getParagraph(3).text());
  76. assertEquals("\7", r.getParagraph(4).text());
  77. assertEquals("\r", r.getParagraph(5).text());
  78. for(int i=0; i<=5; i++) {
  79. assertFalse(r.getParagraph(i).usesUnicode());
  80. }
  81. // Get the table
  82. Table t = r.getTable(p);
  83. // get the only row
  84. assertEquals(1, t.numRows());
  85. TableRow row = t.getRow(0);
  86. // sanity check our row
  87. assertEquals(5, row.numParagraphs());
  88. assertEquals(0, row._parStart);
  89. assertEquals(5, row._parEnd);
  90. assertEquals(0, row.getStartOffset());
  91. assertEquals(87, row.getEndOffset());
  92. // get the first cell
  93. TableCell cell = row.getCell(0);
  94. // First cell should have one paragraph
  95. assertEquals(1, cell.numParagraphs());
  96. assertEquals("One paragraph is ok\7", cell.getParagraph(0).text());
  97. assertEquals(0, cell._parStart);
  98. assertEquals(1, cell._parEnd);
  99. assertEquals(0, cell.getStartOffset());
  100. assertEquals(20, cell.getEndOffset());
  101. // get the second
  102. cell = row.getCell(1);
  103. // Second cell should be detected as having two paragraphs
  104. assertEquals(2, cell.numParagraphs());
  105. assertEquals("First para is ok\r", cell.getParagraph(0).text());
  106. assertEquals("Second paragraph is skipped\7", cell.getParagraph(1).text());
  107. assertEquals(1, cell._parStart);
  108. assertEquals(3, cell._parEnd);
  109. assertEquals(20, cell.getStartOffset());
  110. assertEquals(65, cell.getEndOffset());
  111. // get the last cell
  112. cell = row.getCell(2);
  113. // Last cell should have one paragraph
  114. assertEquals(1, cell.numParagraphs());
  115. assertEquals("One paragraph is ok\7", cell.getParagraph(0).text());
  116. assertEquals(3, cell._parStart);
  117. assertEquals(4, cell._parEnd);
  118. assertEquals(65, cell.getStartOffset());
  119. assertEquals(85, cell.getEndOffset());
  120. }
  121. public void testRangeDelete() {
  122. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("Bug28627.doc");
  123. Range range = doc.getRange();
  124. int numParagraphs = range.numParagraphs();
  125. int totalLength = 0, deletedLength = 0;
  126. for (int i = 0; i < numParagraphs; i++) {
  127. Paragraph para = range.getParagraph(i);
  128. String text = para.text();
  129. totalLength += text.length();
  130. if (text.indexOf("{delete me}") > -1) {
  131. para.delete();
  132. deletedLength = text.length();
  133. }
  134. }
  135. // check the text length after deletion
  136. int newLength = 0;
  137. range = doc.getRange();
  138. numParagraphs = range.numParagraphs();
  139. for (int i = 0; i < numParagraphs; i++) {
  140. Paragraph para = range.getParagraph(i);
  141. String text = para.text();
  142. newLength += text.length();
  143. }
  144. assertEquals(newLength, totalLength - deletedLength);
  145. }
  146. /**
  147. * With an encrypted file, we should give a suitable exception, and not OOM
  148. */
  149. public void testEncryptedFile() {
  150. try {
  151. HWPFTestDataSamples.openSampleFile("PasswordProtected.doc");
  152. fail();
  153. } catch (EncryptedDocumentException e) {
  154. // Good
  155. }
  156. }
  157. public void testWriteProperties() {
  158. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("SampleDoc.doc");
  159. assertEquals("Nick Burch", doc.getSummaryInformation().getAuthor());
  160. // Write and read
  161. HWPFDocument doc2 = writeOutAndRead(doc);
  162. assertEquals("Nick Burch", doc2.getSummaryInformation().getAuthor());
  163. }
  164. /**
  165. * Test for reading paragraphs from Range after replacing some
  166. * text in this Range.
  167. * Bug #45269
  168. */
  169. public void testReadParagraphsAfterReplaceText()throws Exception{
  170. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("Bug45269.doc");
  171. Range range = doc.getRange();
  172. String toFind = "campo1";
  173. String longer = " foi porraaaaa ";
  174. String shorter = " foi ";
  175. //check replace with longer text
  176. for (int x = 0; x < range.numParagraphs(); x++) {
  177. Paragraph para = range.getParagraph(x);
  178. int offset = para.text().indexOf(toFind);
  179. if (offset >= 0) {
  180. para.replaceText(toFind, longer, offset);
  181. assertEquals(offset, para.text().indexOf(longer));
  182. }
  183. }
  184. doc = HWPFTestDataSamples.openSampleFile("Bug45269.doc");
  185. range = doc.getRange();
  186. //check replace with shorter text
  187. for (int x = 0; x < range.numParagraphs(); x++) {
  188. Paragraph para = range.getParagraph(x);
  189. int offset = para.text().indexOf(toFind);
  190. if (offset >= 0) {
  191. para.replaceText(toFind, shorter, offset);
  192. assertEquals(offset, para.text().indexOf(shorter));
  193. }
  194. }
  195. }
  196. /**
  197. * Bug #48245 - don't include the text from the
  198. * next cell in the current one
  199. */
  200. public void testTableIterator() throws Exception {
  201. HWPFDocument doc = HWPFTestDataSamples.openSampleFile("simple-table2.doc");
  202. Range r = doc.getRange();
  203. // Check the text is as we'd expect
  204. assertEquals(13, r.numParagraphs());
  205. assertEquals("Row 1/Cell 1\u0007", r.getParagraph(0).text());
  206. assertEquals("Row 1/Cell 2\u0007", r.getParagraph(1).text());
  207. assertEquals("Row 1/Cell 3\u0007", r.getParagraph(2).text());
  208. assertEquals("\u0007", r.getParagraph(3).text());
  209. assertEquals("Row 2/Cell 1\u0007", r.getParagraph(4).text());
  210. assertEquals("Row 2/Cell 2\u0007", r.getParagraph(5).text());
  211. assertEquals("Row 2/Cell 3\u0007", r.getParagraph(6).text());
  212. assertEquals("\u0007", r.getParagraph(7).text());
  213. assertEquals("Row 3/Cell 1\u0007", r.getParagraph(8).text());
  214. assertEquals("Row 3/Cell 2\u0007", r.getParagraph(9).text());
  215. assertEquals("Row 3/Cell 3\u0007", r.getParagraph(10).text());
  216. assertEquals("\u0007", r.getParagraph(11).text());
  217. assertEquals("\r", r.getParagraph(12).text());
  218. for(int i=0; i<=12; i++) {
  219. assertFalse(r.getParagraph(i).usesUnicode());
  220. }
  221. Paragraph p;
  222. // Take a look in detail at the first couple of
  223. // paragraphs
  224. p = r.getParagraph(0);
  225. assertEquals(1, p.numParagraphs());
  226. assertEquals(0, p.getStartOffset());
  227. assertEquals(13, p.getEndOffset());
  228. assertEquals(0, p._parStart);
  229. assertEquals(1, p._parEnd);
  230. p = r.getParagraph(1);
  231. assertEquals(1, p.numParagraphs());
  232. assertEquals(13, p.getStartOffset());
  233. assertEquals(26, p.getEndOffset());
  234. assertEquals(1, p._parStart);
  235. assertEquals(2, p._parEnd);
  236. p = r.getParagraph(2);
  237. assertEquals(1, p.numParagraphs());
  238. assertEquals(26, p.getStartOffset());
  239. assertEquals(39, p.getEndOffset());
  240. assertEquals(2, p._parStart);
  241. assertEquals(3, p._parEnd);
  242. // Now look at the table
  243. Table table = r.getTable(r.getParagraph(0));
  244. assertEquals(3, table.numRows());
  245. TableRow row;
  246. TableCell cell;
  247. row = table.getRow(0);
  248. assertEquals(0, row._parStart);
  249. assertEquals(4, row._parEnd);
  250. cell = row.getCell(0);
  251. assertEquals(1, cell.numParagraphs());
  252. assertEquals(0, cell._parStart);
  253. assertEquals(1, cell._parEnd);
  254. assertEquals(0, cell.getStartOffset());
  255. assertEquals(13, cell.getEndOffset());
  256. assertEquals("Row 1/Cell 1\u0007", cell.text());
  257. cell = row.getCell(1);
  258. assertEquals(1, cell.numParagraphs());
  259. assertEquals(1, cell._parStart);
  260. assertEquals(2, cell._parEnd);
  261. assertEquals(13, cell.getStartOffset());
  262. assertEquals(26, cell.getEndOffset());
  263. assertEquals("Row 1/Cell 2\u0007", cell.text());
  264. cell = row.getCell(2);
  265. assertEquals(1, cell.numParagraphs());
  266. assertEquals(2, cell._parStart);
  267. assertEquals(3, cell._parEnd);
  268. assertEquals(26, cell.getStartOffset());
  269. assertEquals(39, cell.getEndOffset());
  270. assertEquals("Row 1/Cell 3\u0007", cell.text());
  271. // Onto row #2
  272. row = table.getRow(1);
  273. assertEquals(4, row._parStart);
  274. assertEquals(8, row._parEnd);
  275. cell = row.getCell(0);
  276. assertEquals(1, cell.numParagraphs());
  277. assertEquals(4, cell._parStart);
  278. assertEquals(5, cell._parEnd);
  279. assertEquals(40, cell.getStartOffset());
  280. assertEquals(53, cell.getEndOffset());
  281. assertEquals("Row 2/Cell 1\u0007", cell.text());
  282. cell = row.getCell(1);
  283. assertEquals(1, cell.numParagraphs());
  284. assertEquals(5, cell._parStart);
  285. assertEquals(6, cell._parEnd);
  286. assertEquals(53, cell.getStartOffset());
  287. assertEquals(66, cell.getEndOffset());
  288. assertEquals("Row 2/Cell 2\u0007", cell.text());
  289. cell = row.getCell(2);
  290. assertEquals(1, cell.numParagraphs());
  291. assertEquals(6, cell._parStart);
  292. assertEquals(7, cell._parEnd);
  293. assertEquals(66, cell.getStartOffset());
  294. assertEquals(79, cell.getEndOffset());
  295. assertEquals("Row 2/Cell 3\u0007", cell.text());
  296. // Finally row 3
  297. row = table.getRow(2);
  298. assertEquals(8, row._parStart);
  299. assertEquals(12, row._parEnd);
  300. cell = row.getCell(0);
  301. assertEquals(1, cell.numParagraphs());
  302. assertEquals(8, cell._parStart);
  303. assertEquals(9, cell._parEnd);
  304. assertEquals(80, cell.getStartOffset());
  305. assertEquals(93, cell.getEndOffset());
  306. assertEquals("Row 3/Cell 1\u0007", cell.text());
  307. cell = row.getCell(1);
  308. assertEquals(1, cell.numParagraphs());
  309. assertEquals(9, cell._parStart);
  310. assertEquals(10, cell._parEnd);
  311. assertEquals(93, cell.getStartOffset());
  312. assertEquals(106, cell.getEndOffset());
  313. assertEquals("Row 3/Cell 2\u0007", cell.text());
  314. cell = row.getCell(2);
  315. assertEquals(1, cell.numParagraphs());
  316. assertEquals(10, cell._parStart);
  317. assertEquals(11, cell._parEnd);
  318. assertEquals(106, cell.getStartOffset());
  319. assertEquals(119, cell.getEndOffset());
  320. assertEquals("Row 3/Cell 3\u0007", cell.text());
  321. }
  322. }