Start on details tests for bug #53433
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1614786 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
78c4a8168a
commit
bdb9bbccc1
@ -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.LastCellOfRowDummyRecord;
|
||||||
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
|
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingCellDummyRecord;
|
||||||
import org.apache.poi.hssf.eventusermodel.dummyrecord.MissingRowDummyRecord;
|
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
|
* <p>A HSSFListener which tracks rows and columns, and will
|
||||||
|
@ -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.eventusermodel.dummyrecord.MissingRowDummyRecord;
|
||||||
import org.apache.poi.hssf.record.BOFRecord;
|
import org.apache.poi.hssf.record.BOFRecord;
|
||||||
import org.apache.poi.hssf.record.BlankRecord;
|
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.LabelSSTRecord;
|
||||||
import org.apache.poi.hssf.record.MulBlankRecord;
|
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.Record;
|
||||||
import org.apache.poi.hssf.record.RowRecord;
|
import org.apache.poi.hssf.record.RowRecord;
|
||||||
import org.apache.poi.hssf.record.SharedFormulaRecord;
|
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;
|
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
||||||
/**
|
/**
|
||||||
* Tests for MissingRecordAwareHSSFListener
|
* Tests for MissingRecordAwareHSSFListener
|
||||||
@ -358,7 +364,7 @@ public final class TestMissingRecordAwareHSSFListener extends TestCase {
|
|||||||
|
|
||||||
private static final class MockHSSFListener implements HSSFListener {
|
private static final class MockHSSFListener implements HSSFListener {
|
||||||
public MockHSSFListener() {}
|
public MockHSSFListener() {}
|
||||||
private final List _records = new ArrayList();
|
private final List<Record> _records = new ArrayList<Record>();
|
||||||
private boolean logToStdOut = false;
|
private boolean logToStdOut = false;
|
||||||
|
|
||||||
public void processRecord(Record record) {
|
public void processRecord(Record record) {
|
||||||
@ -479,4 +485,402 @@ public final class TestMissingRecordAwareHSSFListener extends TestCase {
|
|||||||
assertEquals(1, missingCount);
|
assertEquals(1, missingCount);
|
||||||
assertEquals(1, lastCount);
|
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());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
BIN
test-data/spreadsheet/53433.xls
Normal file
BIN
test-data/spreadsheet/53433.xls
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user