aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/org/apache/poi/hssf/eventusermodel/MissingRecordAwareHSSFListener.java11
-rw-r--r--src/testcases/org/apache/poi/hssf/eventusermodel/TestMissingRecordAwareHSSFListener.java406
-rw-r--r--test-data/spreadsheet/53433.xlsbin0 -> 13824 bytes
3 files changed, 415 insertions, 2 deletions
diff --git a/src/java/org/apache/poi/hssf/eventusermodel/MissingRecordAwareHSSFListener.java b/src/java/org/apache/poi/hssf/eventusermodel/MissingRecordAwareHSSFListener.java
index 15206bd218..ef15ea7ce7 100644
--- a/src/java/org/apache/poi/hssf/eventusermodel/MissingRecordAwareHSSFListener.java
+++ b/src/java/org/apache/poi/hssf/eventusermodel/MissingRecordAwareHSSFListener.java
@@ -20,7 +20,16 @@ package org.apache.poi.hssf.eventusermodel;
import org.apache.poi.hssf.eventusermodel.dummyrecord.LastCellOfRowDummyRecord;
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingRowDummyRecord;
-import org.apache.poi.hssf.record.*;
+import org.apache.poi.hssf.record.BOFRecord;
+import org.apache.poi.hssf.record.CellValueRecordInterface;
+import org.apache.poi.hssf.record.MulBlankRecord;
+import org.apache.poi.hssf.record.MulRKRecord;
+import org.apache.poi.hssf.record.NoteRecord;
+import org.apache.poi.hssf.record.Record;
+import org.apache.poi.hssf.record.RecordFactory;
+import org.apache.poi.hssf.record.RowRecord;
+import org.apache.poi.hssf.record.SharedFormulaRecord;
+import org.apache.poi.hssf.record.StringRecord;
/**
* <p>A HSSFListener which tracks rows and columns, and will
diff --git a/src/testcases/org/apache/poi/hssf/eventusermodel/TestMissingRecordAwareHSSFListener.java b/src/testcases/org/apache/poi/hssf/eventusermodel/TestMissingRecordAwareHSSFListener.java
index 6a60f94546..5b834ad3d5 100644
--- a/src/testcases/org/apache/poi/hssf/eventusermodel/TestMissingRecordAwareHSSFListener.java
+++ b/src/testcases/org/apache/poi/hssf/eventusermodel/TestMissingRecordAwareHSSFListener.java
@@ -30,11 +30,17 @@ import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingRowDummyRecord;
import org.apache.poi.hssf.record.BOFRecord;
import org.apache.poi.hssf.record.BlankRecord;
+import org.apache.poi.hssf.record.CellValueRecordInterface;
+import org.apache.poi.hssf.record.DimensionsRecord;
+import org.apache.poi.hssf.record.FormulaRecord;
import org.apache.poi.hssf.record.LabelSSTRecord;
import org.apache.poi.hssf.record.MulBlankRecord;
+import org.apache.poi.hssf.record.NumberRecord;
import org.apache.poi.hssf.record.Record;
import org.apache.poi.hssf.record.RowRecord;
import org.apache.poi.hssf.record.SharedFormulaRecord;
+import org.apache.poi.hssf.record.StringRecord;
+import org.apache.poi.hssf.record.WindowTwoRecord;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
/**
* Tests for MissingRecordAwareHSSFListener
@@ -358,7 +364,7 @@ public final class TestMissingRecordAwareHSSFListener extends TestCase {
private static final class MockHSSFListener implements HSSFListener {
public MockHSSFListener() {}
- private final List _records = new ArrayList();
+ private final List<Record> _records = new ArrayList<Record>();
private boolean logToStdOut = false;
public void processRecord(Record record) {
@@ -479,4 +485,402 @@ public final class TestMissingRecordAwareHSSFListener extends TestCase {
assertEquals(1, missingCount);
assertEquals(1, lastCount);
}
+
+ public void testFormulasWithStringResultsHandling() {
+ readRecords("53433.xls");
+
+ int pos = 95;
+
+ // First three rows are blank
+ assertEquals(DimensionsRecord.class, r[pos++].getClass());
+
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(0, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(1, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(2, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+
+ // Then rows 4-10 are defined
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(3, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(4, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(5, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(6, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(7, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(8, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(9, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+
+ // 5 more blank rows
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(10, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(11, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(12, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(13, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(14, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+
+ // 2 defined rows
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(15, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(16, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+
+ // one blank row
+ assertEquals(MissingRowDummyRecord.class, r[pos].getClass());
+ assertEquals(17, ((MissingRowDummyRecord)r[pos]).getRowNumber());
+ pos++;
+
+ // one last real row
+ assertEquals(RowRecord.class, r[pos].getClass());
+ assertEquals(18, ((RowRecord)r[pos]).getRowNumber());
+ pos++;
+
+
+
+ // Now onto the cells
+
+ // Because the 3 first rows are missing, should have last-of-row records first
+ // TODO Fix!
+
+
+ // Onto row 4 (=3)
+
+ // Now we have blank cell A4
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(3, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+
+ // Now 4 real cells, all strings
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(1, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(2, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+
+ // Final dummy cell for the end-of-row
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(3, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 5 has string, formula of string, number, formula of string
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(4, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(1, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(2, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(StringRecord.class, r[pos].getClass());
+ assertEquals("s1", ((StringRecord)r[pos]).getString());
+ pos++;
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(StringRecord.class, r[pos].getClass());
+ assertEquals("s3845", ((StringRecord)r[pos]).getString());
+ pos++;
+
+ // Final dummy cell for the end-of-row
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 6 is blank / string formula / number / number / string formula
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(5, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(5, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(1, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(StringRecord.class, r[pos].getClass());
+ assertEquals("s4", ((StringRecord)r[pos]).getString());
+ pos++;
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(5, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(2, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(5, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(5, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(StringRecord.class, r[pos].getClass());
+ assertEquals("s3845", ((StringRecord)r[pos]).getString());
+ pos++;
+
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(5, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 7 is blank / blank / number / number / number
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(6, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(6, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(6, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(2, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(6, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(NumberRecord.class, r[pos].getClass());
+ assertEquals(6, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(6, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 8 is blank / string / number formula / string formula / blank
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(7, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(7, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(1, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(7, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(2, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(FormulaRecord.class, r[pos].getClass());
+ assertEquals(7, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(StringRecord.class, r[pos].getClass());
+ assertEquals("s4", ((StringRecord)r[pos]).getString());
+ pos++;
+ assertEquals(BlankRecord.class, r[pos].getClass());
+ assertEquals(7, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(7, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 9 is empty, but with a blank at E9
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(8, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(8, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(8, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(2, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(8, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(3, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(BlankRecord.class, r[pos].getClass());
+ assertEquals(8, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(8, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 10 has a string in D10
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(9, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(9, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(9, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(2, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(9, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(9, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(3, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Now 5 blank rows
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(10, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(11, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(12, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(13, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(14, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 16 has a single string in B16
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(15, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(15, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(1, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(15, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 17 has a single string in D17
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(16, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(16, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(16, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(2, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(16, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(3, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(16, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(3, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 18 is blank
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(17, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // Row 19 has a single string in E19
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(18, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(0, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(18, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(1, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(18, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(2, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(MissingCellDummyRecord.class, r[pos].getClass());
+ assertEquals(18, ((MissingCellDummyRecord)r[pos]).getRow());
+ assertEquals(3, ((MissingCellDummyRecord)r[pos]).getColumn());
+ pos++;
+ assertEquals(LabelSSTRecord.class, r[pos].getClass());
+ assertEquals(18, ((CellValueRecordInterface)r[pos]).getRow());
+ assertEquals(4, ((CellValueRecordInterface)r[pos]).getColumn());
+ pos++;
+ assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
+ assertEquals(18, ((LastCellOfRowDummyRecord)r[pos]).getRow());
+ assertEquals(4, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
+ pos++;
+
+
+ // And that's it!
+ assertEquals(WindowTwoRecord.class, r[pos++].getClass());
+ }
}
diff --git a/test-data/spreadsheet/53433.xls b/test-data/spreadsheet/53433.xls
new file mode 100644
index 0000000000..c31c3a8772
--- /dev/null
+++ b/test-data/spreadsheet/53433.xls
Binary files differ