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.

TestMissingRecordAwareHSSFListener.java 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464
  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.hssf.eventusermodel;
  16. import java.io.IOException;
  17. import java.io.InputStream;
  18. import java.util.ArrayList;
  19. import java.util.List;
  20. import junit.framework.AssertionFailedError;
  21. import junit.framework.TestCase;
  22. import org.apache.poi.hssf.HSSFTestDataSamples;
  23. import org.apache.poi.hssf.eventusermodel.dummyrecord.LastCellOfRowDummyRecord;
  24. import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
  25. import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingRowDummyRecord;
  26. import org.apache.poi.hssf.record.BOFRecord;
  27. import org.apache.poi.hssf.record.BlankRecord;
  28. import org.apache.poi.hssf.record.LabelSSTRecord;
  29. import org.apache.poi.hssf.record.MulBlankRecord;
  30. import org.apache.poi.hssf.record.Record;
  31. import org.apache.poi.hssf.record.RowRecord;
  32. import org.apache.poi.hssf.record.SharedFormulaRecord;
  33. import org.apache.poi.poifs.filesystem.POIFSFileSystem;
  34. /**
  35. * Tests for MissingRecordAwareHSSFListener
  36. */
  37. public final class TestMissingRecordAwareHSSFListener extends TestCase {
  38. private Record[] r;
  39. private void readRecords(String sampleFileName) {
  40. HSSFRequest req = new HSSFRequest();
  41. MockHSSFListener mockListen = new MockHSSFListener();
  42. MissingRecordAwareHSSFListener listener = new MissingRecordAwareHSSFListener(mockListen);
  43. req.addListenerForAllRecords(listener);
  44. HSSFEventFactory factory = new HSSFEventFactory();
  45. try {
  46. InputStream is = HSSFTestDataSamples.openSampleFileStream(sampleFileName);
  47. POIFSFileSystem fs = new POIFSFileSystem(is);
  48. factory.processWorkbookEvents(req, fs);
  49. } catch (IOException e) {
  50. throw new RuntimeException(e);
  51. }
  52. r = mockListen.getRecords();
  53. assertTrue(r.length > 100);
  54. }
  55. public void openNormal() {
  56. readRecords("MissingBits.xls");
  57. }
  58. public void testMissingRowRecords() {
  59. openNormal();
  60. // We have rows 0, 1, 2, 20 and 21
  61. int row0 = -1;
  62. for(int i=0; i<r.length; i++) {
  63. if(r[i] instanceof RowRecord) {
  64. RowRecord rr = (RowRecord)r[i];
  65. if(rr.getRowNumber() == 0) { row0 = i; }
  66. }
  67. }
  68. assertTrue(row0 > -1);
  69. // Following row 0, we should have 1, 2, then dummy, then 20+21+22
  70. assertTrue(r[row0] instanceof RowRecord);
  71. assertTrue(r[row0+1] instanceof RowRecord);
  72. assertTrue(r[row0+2] instanceof RowRecord);
  73. assertTrue(r[row0+3] instanceof MissingRowDummyRecord);
  74. assertTrue(r[row0+4] instanceof MissingRowDummyRecord);
  75. assertTrue(r[row0+5] instanceof MissingRowDummyRecord);
  76. assertTrue(r[row0+6] instanceof MissingRowDummyRecord);
  77. // ...
  78. assertTrue(r[row0+18] instanceof MissingRowDummyRecord);
  79. assertTrue(r[row0+19] instanceof MissingRowDummyRecord);
  80. assertTrue(r[row0+20] instanceof RowRecord);
  81. assertTrue(r[row0+21] instanceof RowRecord);
  82. assertTrue(r[row0+22] instanceof RowRecord);
  83. // Check things had the right row numbers
  84. RowRecord rr;
  85. rr = (RowRecord)r[row0+2];
  86. assertEquals(2, rr.getRowNumber());
  87. rr = (RowRecord)r[row0+20];
  88. assertEquals(20, rr.getRowNumber());
  89. rr = (RowRecord)r[row0+21];
  90. assertEquals(21, rr.getRowNumber());
  91. MissingRowDummyRecord mr;
  92. mr = (MissingRowDummyRecord)r[row0+3];
  93. assertEquals(3, mr.getRowNumber());
  94. mr = (MissingRowDummyRecord)r[row0+4];
  95. assertEquals(4, mr.getRowNumber());
  96. mr = (MissingRowDummyRecord)r[row0+5];
  97. assertEquals(5, mr.getRowNumber());
  98. mr = (MissingRowDummyRecord)r[row0+18];
  99. assertEquals(18, mr.getRowNumber());
  100. mr = (MissingRowDummyRecord)r[row0+19];
  101. assertEquals(19, mr.getRowNumber());
  102. }
  103. public void testEndOfRowRecords() {
  104. openNormal();
  105. // Find the cell at 0,0
  106. int cell00 = -1;
  107. for(int i=0; i<r.length; i++) {
  108. if(r[i] instanceof LabelSSTRecord) {
  109. LabelSSTRecord lr = (LabelSSTRecord)r[i];
  110. if(lr.getRow() == 0 && lr.getColumn() == 0) { cell00 = i; }
  111. }
  112. }
  113. assertTrue(cell00 > -1);
  114. // We have rows 0, 1, 2, 20 and 21
  115. // Row 0 has 1 entry
  116. // Row 1 has 4 entries
  117. // Row 2 has 6 entries
  118. // Row 20 has 5 entries
  119. // Row 21 has 7 entries
  120. // Row 22 has 12 entries
  121. // Row 0
  122. assertFalse(r[cell00+0] instanceof LastCellOfRowDummyRecord);
  123. assertTrue(r[cell00+1] instanceof LastCellOfRowDummyRecord);
  124. // Row 1
  125. assertFalse(r[cell00+2] instanceof LastCellOfRowDummyRecord);
  126. assertFalse(r[cell00+3] instanceof LastCellOfRowDummyRecord);
  127. assertFalse(r[cell00+4] instanceof LastCellOfRowDummyRecord);
  128. assertFalse(r[cell00+5] instanceof LastCellOfRowDummyRecord);
  129. assertTrue(r[cell00+6] instanceof LastCellOfRowDummyRecord);
  130. // Row 2
  131. assertFalse(r[cell00+7] instanceof LastCellOfRowDummyRecord);
  132. assertFalse(r[cell00+8] instanceof LastCellOfRowDummyRecord);
  133. assertFalse(r[cell00+9] instanceof LastCellOfRowDummyRecord);
  134. assertFalse(r[cell00+10] instanceof LastCellOfRowDummyRecord);
  135. assertFalse(r[cell00+11] instanceof LastCellOfRowDummyRecord);
  136. assertFalse(r[cell00+12] instanceof LastCellOfRowDummyRecord);
  137. assertTrue(r[cell00+13] instanceof LastCellOfRowDummyRecord);
  138. // Row 3 -> 19
  139. assertTrue(r[cell00+14] instanceof LastCellOfRowDummyRecord);
  140. assertTrue(r[cell00+15] instanceof LastCellOfRowDummyRecord);
  141. assertTrue(r[cell00+16] instanceof LastCellOfRowDummyRecord);
  142. assertTrue(r[cell00+17] instanceof LastCellOfRowDummyRecord);
  143. assertTrue(r[cell00+18] instanceof LastCellOfRowDummyRecord);
  144. assertTrue(r[cell00+19] instanceof LastCellOfRowDummyRecord);
  145. assertTrue(r[cell00+20] instanceof LastCellOfRowDummyRecord);
  146. assertTrue(r[cell00+21] instanceof LastCellOfRowDummyRecord);
  147. assertTrue(r[cell00+22] instanceof LastCellOfRowDummyRecord);
  148. assertTrue(r[cell00+23] instanceof LastCellOfRowDummyRecord);
  149. assertTrue(r[cell00+24] instanceof LastCellOfRowDummyRecord);
  150. assertTrue(r[cell00+25] instanceof LastCellOfRowDummyRecord);
  151. assertTrue(r[cell00+26] instanceof LastCellOfRowDummyRecord);
  152. assertTrue(r[cell00+27] instanceof LastCellOfRowDummyRecord);
  153. assertTrue(r[cell00+28] instanceof LastCellOfRowDummyRecord);
  154. assertTrue(r[cell00+29] instanceof LastCellOfRowDummyRecord);
  155. assertTrue(r[cell00+30] instanceof LastCellOfRowDummyRecord);
  156. // Row 20
  157. assertFalse(r[cell00+31] instanceof LastCellOfRowDummyRecord);
  158. assertFalse(r[cell00+32] instanceof LastCellOfRowDummyRecord);
  159. assertFalse(r[cell00+33] instanceof LastCellOfRowDummyRecord);
  160. assertFalse(r[cell00+34] instanceof LastCellOfRowDummyRecord);
  161. assertFalse(r[cell00+35] instanceof LastCellOfRowDummyRecord);
  162. assertTrue(r[cell00+36] instanceof LastCellOfRowDummyRecord);
  163. // Row 21
  164. assertFalse(r[cell00+37] instanceof LastCellOfRowDummyRecord);
  165. assertFalse(r[cell00+38] instanceof LastCellOfRowDummyRecord);
  166. assertFalse(r[cell00+39] instanceof LastCellOfRowDummyRecord);
  167. assertFalse(r[cell00+40] instanceof LastCellOfRowDummyRecord);
  168. assertFalse(r[cell00+41] instanceof LastCellOfRowDummyRecord);
  169. assertFalse(r[cell00+42] instanceof LastCellOfRowDummyRecord);
  170. assertFalse(r[cell00+43] instanceof LastCellOfRowDummyRecord);
  171. assertTrue(r[cell00+44] instanceof LastCellOfRowDummyRecord);
  172. // Row 22
  173. assertFalse(r[cell00+45] instanceof LastCellOfRowDummyRecord);
  174. assertFalse(r[cell00+46] instanceof LastCellOfRowDummyRecord);
  175. assertFalse(r[cell00+47] instanceof LastCellOfRowDummyRecord);
  176. assertFalse(r[cell00+48] instanceof LastCellOfRowDummyRecord);
  177. assertFalse(r[cell00+49] instanceof LastCellOfRowDummyRecord);
  178. assertFalse(r[cell00+50] instanceof LastCellOfRowDummyRecord);
  179. assertFalse(r[cell00+51] instanceof LastCellOfRowDummyRecord);
  180. assertFalse(r[cell00+52] instanceof LastCellOfRowDummyRecord);
  181. assertFalse(r[cell00+53] instanceof LastCellOfRowDummyRecord);
  182. assertFalse(r[cell00+54] instanceof LastCellOfRowDummyRecord);
  183. assertFalse(r[cell00+55] instanceof LastCellOfRowDummyRecord);
  184. assertFalse(r[cell00+56] instanceof LastCellOfRowDummyRecord);
  185. assertTrue(r[cell00+57] instanceof LastCellOfRowDummyRecord);
  186. // Check the numbers of the last seen columns
  187. LastCellOfRowDummyRecord[] lrs = new LastCellOfRowDummyRecord[24];
  188. int lrscount = 0;
  189. for(int i=0; i<r.length; i++) {
  190. if(r[i] instanceof LastCellOfRowDummyRecord) {
  191. lrs[lrscount] = (LastCellOfRowDummyRecord)r[i];
  192. lrscount++;
  193. }
  194. }
  195. assertEquals(0, lrs[0].getLastColumnNumber());
  196. assertEquals(0, lrs[0].getRow());
  197. assertEquals(3, lrs[1].getLastColumnNumber());
  198. assertEquals(1, lrs[1].getRow());
  199. assertEquals(5, lrs[2].getLastColumnNumber());
  200. assertEquals(2, lrs[2].getRow());
  201. for(int i=3; i<=19; i++) {
  202. assertEquals(-1, lrs[i].getLastColumnNumber());
  203. assertEquals(i, lrs[i].getRow());
  204. }
  205. assertEquals(4, lrs[20].getLastColumnNumber());
  206. assertEquals(20, lrs[20].getRow());
  207. assertEquals(6, lrs[21].getLastColumnNumber());
  208. assertEquals(21, lrs[21].getRow());
  209. assertEquals(11, lrs[22].getLastColumnNumber());
  210. assertEquals(22, lrs[22].getRow());
  211. }
  212. public void testMissingCellRecords() {
  213. openNormal();
  214. // Find the cell at 0,0
  215. int cell00 = -1;
  216. for(int i=0; i<r.length; i++) {
  217. if(r[i] instanceof LabelSSTRecord) {
  218. LabelSSTRecord lr = (LabelSSTRecord)r[i];
  219. if(lr.getRow() == 0 && lr.getColumn() == 0) { cell00 = i; }
  220. }
  221. }
  222. assertTrue(cell00 > -1);
  223. // We have rows 0, 1, 2, 20 and 21
  224. // Row 0 has 1 entry, 0
  225. // Row 1 has 4 entries, 0+3
  226. // Row 2 has 6 entries, 0+5
  227. // Row 20 has 5 entries, 0-5
  228. // Row 21 has 7 entries, 0+1+3+5+6
  229. // Row 22 has 12 entries, 0+3+4+11
  230. // Row 0
  231. assertFalse(r[cell00+0] instanceof MissingCellDummyRecord);
  232. assertFalse(r[cell00+1] instanceof MissingCellDummyRecord);
  233. // Row 1
  234. assertFalse(r[cell00+2] instanceof MissingCellDummyRecord);
  235. assertTrue(r[cell00+3] instanceof MissingCellDummyRecord);
  236. assertTrue(r[cell00+4] instanceof MissingCellDummyRecord);
  237. assertFalse(r[cell00+5] instanceof MissingCellDummyRecord);
  238. assertFalse(r[cell00+6] instanceof MissingCellDummyRecord);
  239. // Row 2
  240. assertFalse(r[cell00+7] instanceof MissingCellDummyRecord);
  241. assertTrue(r[cell00+8] instanceof MissingCellDummyRecord);
  242. assertTrue(r[cell00+9] instanceof MissingCellDummyRecord);
  243. assertTrue(r[cell00+10] instanceof MissingCellDummyRecord);
  244. assertTrue(r[cell00+11] instanceof MissingCellDummyRecord);
  245. assertFalse(r[cell00+12] instanceof MissingCellDummyRecord);
  246. assertFalse(r[cell00+13] instanceof MissingCellDummyRecord);
  247. // Row 3-19
  248. assertFalse(r[cell00+14] instanceof MissingCellDummyRecord);
  249. assertFalse(r[cell00+15] instanceof MissingCellDummyRecord);
  250. // Row 20
  251. assertFalse(r[cell00+31] instanceof MissingCellDummyRecord);
  252. assertFalse(r[cell00+32] instanceof MissingCellDummyRecord);
  253. assertFalse(r[cell00+33] instanceof MissingCellDummyRecord);
  254. assertFalse(r[cell00+34] instanceof MissingCellDummyRecord);
  255. assertFalse(r[cell00+35] instanceof MissingCellDummyRecord);
  256. assertFalse(r[cell00+36] instanceof MissingCellDummyRecord);
  257. // Row 21
  258. assertFalse(r[cell00+37] instanceof MissingCellDummyRecord);
  259. assertFalse(r[cell00+38] instanceof MissingCellDummyRecord);
  260. assertTrue(r[cell00+39] instanceof MissingCellDummyRecord);
  261. assertFalse(r[cell00+40] instanceof MissingCellDummyRecord);
  262. assertTrue(r[cell00+41] instanceof MissingCellDummyRecord);
  263. assertFalse(r[cell00+42] instanceof MissingCellDummyRecord);
  264. assertFalse(r[cell00+43] instanceof MissingCellDummyRecord);
  265. assertFalse(r[cell00+44] instanceof MissingCellDummyRecord);
  266. // Row 22
  267. assertFalse(r[cell00+45] instanceof MissingCellDummyRecord);
  268. assertTrue(r[cell00+46] instanceof MissingCellDummyRecord);
  269. assertTrue(r[cell00+47] instanceof MissingCellDummyRecord);
  270. assertFalse(r[cell00+48] instanceof MissingCellDummyRecord);
  271. assertFalse(r[cell00+49] instanceof MissingCellDummyRecord);
  272. assertTrue(r[cell00+50] instanceof MissingCellDummyRecord);
  273. assertTrue(r[cell00+51] instanceof MissingCellDummyRecord);
  274. assertTrue(r[cell00+52] instanceof MissingCellDummyRecord);
  275. assertTrue(r[cell00+53] instanceof MissingCellDummyRecord);
  276. assertTrue(r[cell00+54] instanceof MissingCellDummyRecord);
  277. assertTrue(r[cell00+55] instanceof MissingCellDummyRecord);
  278. assertFalse(r[cell00+56] instanceof MissingCellDummyRecord);
  279. assertFalse(r[cell00+57] instanceof MissingCellDummyRecord);
  280. // Check some numbers
  281. MissingCellDummyRecord mc;
  282. mc = (MissingCellDummyRecord)r[cell00+3];
  283. assertEquals(1, mc.getRow());
  284. assertEquals(1, mc.getColumn());
  285. mc = (MissingCellDummyRecord)r[cell00+4];
  286. assertEquals(1, mc.getRow());
  287. assertEquals(2, mc.getColumn());
  288. mc = (MissingCellDummyRecord)r[cell00+8];
  289. assertEquals(2, mc.getRow());
  290. assertEquals(1, mc.getColumn());
  291. mc = (MissingCellDummyRecord)r[cell00+9];
  292. assertEquals(2, mc.getRow());
  293. assertEquals(2, mc.getColumn());
  294. mc = (MissingCellDummyRecord)r[cell00+55];
  295. assertEquals(22, mc.getRow());
  296. assertEquals(10, mc.getColumn());
  297. }
  298. // Make sure we don't put in any extra new lines
  299. // that aren't already there
  300. public void testNoExtraNewLines() {
  301. // Load a different file
  302. // This file has has something in lines 1-33
  303. readRecords("MRExtraLines.xls");
  304. int rowCount=0;
  305. for(int i=0; i<r.length; i++) {
  306. if(r[i] instanceof LastCellOfRowDummyRecord) {
  307. LastCellOfRowDummyRecord eor = (LastCellOfRowDummyRecord) r[i];
  308. assertEquals(rowCount, eor.getRow());
  309. rowCount++;
  310. }
  311. }
  312. // Check we got the 33 rows
  313. assertEquals(33, rowCount);
  314. }
  315. private static final class MockHSSFListener implements HSSFListener {
  316. public MockHSSFListener() {}
  317. private final List _records = new ArrayList();
  318. private boolean logToStdOut = false;
  319. public void processRecord(Record record) {
  320. _records.add(record);
  321. if(record instanceof MissingRowDummyRecord) {
  322. MissingRowDummyRecord mr = (MissingRowDummyRecord)record;
  323. log("Got dummy row " + mr.getRowNumber());
  324. }
  325. if(record instanceof MissingCellDummyRecord) {
  326. MissingCellDummyRecord mc = (MissingCellDummyRecord)record;
  327. log("Got dummy cell " + mc.getRow() + " " + mc.getColumn());
  328. }
  329. if(record instanceof LastCellOfRowDummyRecord) {
  330. LastCellOfRowDummyRecord lc = (LastCellOfRowDummyRecord)record;
  331. log("Got end-of row, row was " + lc.getRow() + ", last column was " + lc.getLastColumnNumber());
  332. }
  333. if(record instanceof BOFRecord) {
  334. BOFRecord r = (BOFRecord)record;
  335. if(r.getType() == BOFRecord.TYPE_WORKSHEET) {
  336. log("On new sheet");
  337. }
  338. }
  339. if(record instanceof RowRecord) {
  340. RowRecord rr = (RowRecord)record;
  341. log("Starting row #" + rr.getRowNumber());
  342. }
  343. }
  344. private void log(String msg) {
  345. if(logToStdOut) {
  346. System.out.println(msg);
  347. }
  348. }
  349. public Record[] getRecords() {
  350. Record[] result = new Record[_records.size()];
  351. _records.toArray(result);
  352. return result;
  353. }
  354. }
  355. /**
  356. * Make sure that the presence of shared formulas does not cause extra
  357. * end-of-row records.
  358. */
  359. public void testEndOfRow_bug45672() {
  360. readRecords("ex45672.xls");
  361. Record[] rr = r;
  362. int eorCount=0;
  363. int sfrCount=0;
  364. for (int i = 0; i < rr.length; i++) {
  365. Record record = rr[i];
  366. if (record instanceof SharedFormulaRecord) {
  367. sfrCount++;
  368. }
  369. if (record instanceof LastCellOfRowDummyRecord) {
  370. eorCount++;
  371. }
  372. }
  373. if (eorCount == 2) {
  374. throw new AssertionFailedError("Identified bug 45672");
  375. }
  376. assertEquals(1, eorCount);
  377. assertEquals(1, sfrCount);
  378. }
  379. /**
  380. * MulBlank records hold multiple blank cells. Check we
  381. * can handle them correctly.
  382. */
  383. public void testMulBlankHandling() {
  384. readRecords("45672.xls");
  385. // Check that we don't have any MulBlankRecords, but do
  386. // have lots of BlankRecords
  387. Record[] rr = r;
  388. int eorCount=0;
  389. int mbrCount=0;
  390. int brCount=0;
  391. for (int i = 0; i < rr.length; i++) {
  392. Record record = rr[i];
  393. if (record instanceof MulBlankRecord) {
  394. mbrCount++;
  395. }
  396. if (record instanceof BlankRecord) {
  397. brCount++;
  398. }
  399. if (record instanceof LastCellOfRowDummyRecord) {
  400. eorCount++;
  401. }
  402. }
  403. if (mbrCount > 0) {
  404. throw new AssertionFailedError("Identified bug 45672");
  405. }
  406. if (brCount < 20) {
  407. throw new AssertionFailedError("Identified bug 45672");
  408. }
  409. if (eorCount != 2) {
  410. throw new AssertionFailedError("Identified bug 45672");
  411. }
  412. assertEquals(2, eorCount);
  413. }
  414. }