blob: 0867720f79ec3c60d8d527a476fb45a43fcff821 [file] [log] [blame]
/* ====================================================================
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==================================================================== */
package org.apache.poi.hssf.eventusermodel;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import junit.framework.AssertionFailedError;
import junit.framework.TestCase;
import org.apache.poi.hssf.HSSFTestDataSamples;
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.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
*/
public final class TestMissingRecordAwareHSSFListener extends TestCase {
private Record[] r;
private void readRecords(String sampleFileName) {
HSSFRequest req = new HSSFRequest();
MockHSSFListener mockListen = new MockHSSFListener();
MissingRecordAwareHSSFListener listener = new MissingRecordAwareHSSFListener(mockListen);
req.addListenerForAllRecords(listener);
HSSFEventFactory factory = new HSSFEventFactory();
try {
InputStream is = HSSFTestDataSamples.openSampleFileStream(sampleFileName);
POIFSFileSystem fs = new POIFSFileSystem(is);
factory.processWorkbookEvents(req, fs);
} catch (IOException e) {
throw new RuntimeException(e);
}
r = mockListen.getRecords();
assertTrue(r.length > 100);
}
public void openNormal() {
readRecords("MissingBits.xls");
}
public void testMissingRowRecords() {
openNormal();
// We have rows 0, 1, 2, 20 and 21
int row0 = -1;
for(int i=0; i<r.length; i++) {
if(r[i] instanceof RowRecord) {
RowRecord rr = (RowRecord)r[i];
if(rr.getRowNumber() == 0) { row0 = i; }
}
}
assertTrue(row0 > -1);
// Following row 0, we should have 1, 2, then dummy, then 20+21+22
assertTrue(r[row0] instanceof RowRecord);
assertTrue(r[row0+1] instanceof RowRecord);
assertTrue(r[row0+2] instanceof RowRecord);
assertTrue(r[row0+3] instanceof MissingRowDummyRecord);
assertTrue(r[row0+4] instanceof MissingRowDummyRecord);
assertTrue(r[row0+5] instanceof MissingRowDummyRecord);
assertTrue(r[row0+6] instanceof MissingRowDummyRecord);
// ...
assertTrue(r[row0+18] instanceof MissingRowDummyRecord);
assertTrue(r[row0+19] instanceof MissingRowDummyRecord);
assertTrue(r[row0+20] instanceof RowRecord);
assertTrue(r[row0+21] instanceof RowRecord);
assertTrue(r[row0+22] instanceof RowRecord);
// Check things had the right row numbers
RowRecord rr;
rr = (RowRecord)r[row0+2];
assertEquals(2, rr.getRowNumber());
rr = (RowRecord)r[row0+20];
assertEquals(20, rr.getRowNumber());
rr = (RowRecord)r[row0+21];
assertEquals(21, rr.getRowNumber());
MissingRowDummyRecord mr;
mr = (MissingRowDummyRecord)r[row0+3];
assertEquals(3, mr.getRowNumber());
mr = (MissingRowDummyRecord)r[row0+4];
assertEquals(4, mr.getRowNumber());
mr = (MissingRowDummyRecord)r[row0+5];
assertEquals(5, mr.getRowNumber());
mr = (MissingRowDummyRecord)r[row0+18];
assertEquals(18, mr.getRowNumber());
mr = (MissingRowDummyRecord)r[row0+19];
assertEquals(19, mr.getRowNumber());
}
public void testEndOfRowRecords() {
openNormal();
// Find the cell at 0,0
int cell00 = -1;
for(int i=0; i<r.length; i++) {
if(r[i] instanceof LabelSSTRecord) {
LabelSSTRecord lr = (LabelSSTRecord)r[i];
if(lr.getRow() == 0 && lr.getColumn() == 0) { cell00 = i; }
}
}
assertTrue(cell00 > -1);
// We have rows 0, 1, 2, 20 and 21
// Row 0 has 1 entry
// Row 1 has 4 entries
// Row 2 has 6 entries
// Row 20 has 5 entries
// Row 21 has 7 entries
// Row 22 has 12 entries
// Row 0
assertFalse(r[cell00+0] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+1] instanceof LastCellOfRowDummyRecord);
// Row 1
assertFalse(r[cell00+2] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+3] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+4] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+5] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+6] instanceof LastCellOfRowDummyRecord);
// Row 2
assertFalse(r[cell00+7] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+8] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+9] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+10] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+11] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+12] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+13] instanceof LastCellOfRowDummyRecord);
// Row 3 -> 19
assertTrue(r[cell00+14] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+15] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+16] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+17] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+18] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+19] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+20] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+21] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+22] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+23] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+24] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+25] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+26] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+27] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+28] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+29] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+30] instanceof LastCellOfRowDummyRecord);
// Row 20
assertFalse(r[cell00+31] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+32] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+33] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+34] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+35] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+36] instanceof LastCellOfRowDummyRecord);
// Row 21
assertFalse(r[cell00+37] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+38] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+39] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+40] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+41] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+42] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+43] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+44] instanceof LastCellOfRowDummyRecord);
// Row 22
assertFalse(r[cell00+45] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+46] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+47] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+48] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+49] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+50] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+51] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+52] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+53] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+54] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+55] instanceof LastCellOfRowDummyRecord);
assertFalse(r[cell00+56] instanceof LastCellOfRowDummyRecord);
assertTrue(r[cell00+57] instanceof LastCellOfRowDummyRecord);
// Check the numbers of the last seen columns
LastCellOfRowDummyRecord[] lrs = new LastCellOfRowDummyRecord[24];
int lrscount = 0;
for (final Record rec : r) {
if(rec instanceof LastCellOfRowDummyRecord) {
lrs[lrscount] = (LastCellOfRowDummyRecord)rec;
lrscount++;
}
}
assertEquals(0, lrs[0].getLastColumnNumber());
assertEquals(0, lrs[0].getRow());
assertEquals(3, lrs[1].getLastColumnNumber());
assertEquals(1, lrs[1].getRow());
assertEquals(5, lrs[2].getLastColumnNumber());
assertEquals(2, lrs[2].getRow());
for(int i=3; i<=19; i++) {
assertEquals(-1, lrs[i].getLastColumnNumber());
assertEquals(i, lrs[i].getRow());
}
assertEquals(4, lrs[20].getLastColumnNumber());
assertEquals(20, lrs[20].getRow());
assertEquals(6, lrs[21].getLastColumnNumber());
assertEquals(21, lrs[21].getRow());
assertEquals(11, lrs[22].getLastColumnNumber());
assertEquals(22, lrs[22].getRow());
}
public void testMissingCellRecords() {
openNormal();
// Find the cell at 0,0
int cell00 = -1;
for(int i=0; i<r.length; i++) {
if(r[i] instanceof LabelSSTRecord) {
LabelSSTRecord lr = (LabelSSTRecord)r[i];
if(lr.getRow() == 0 && lr.getColumn() == 0) { cell00 = i; }
}
}
assertTrue(cell00 > -1);
// We have rows 0, 1, 2, 20 and 21
// Row 0 has 1 entry, 0
// Row 1 has 4 entries, 0+3
// Row 2 has 6 entries, 0+5
// Row 20 has 5 entries, 0-5
// Row 21 has 7 entries, 0+1+3+5+6
// Row 22 has 12 entries, 0+3+4+11
// Row 0
assertFalse(r[cell00+0] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+1] instanceof MissingCellDummyRecord);
// Row 1
assertFalse(r[cell00+2] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+3] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+4] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+5] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+6] instanceof MissingCellDummyRecord);
// Row 2
assertFalse(r[cell00+7] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+8] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+9] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+10] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+11] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+12] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+13] instanceof MissingCellDummyRecord);
// Row 3-19
assertFalse(r[cell00+14] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+15] instanceof MissingCellDummyRecord);
// Row 20
assertFalse(r[cell00+31] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+32] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+33] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+34] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+35] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+36] instanceof MissingCellDummyRecord);
// Row 21
assertFalse(r[cell00+37] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+38] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+39] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+40] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+41] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+42] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+43] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+44] instanceof MissingCellDummyRecord);
// Row 22
assertFalse(r[cell00+45] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+46] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+47] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+48] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+49] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+50] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+51] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+52] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+53] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+54] instanceof MissingCellDummyRecord);
assertTrue(r[cell00+55] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+56] instanceof MissingCellDummyRecord);
assertFalse(r[cell00+57] instanceof MissingCellDummyRecord);
// Check some numbers
MissingCellDummyRecord mc;
mc = (MissingCellDummyRecord)r[cell00+3];
assertEquals(1, mc.getRow());
assertEquals(1, mc.getColumn());
mc = (MissingCellDummyRecord)r[cell00+4];
assertEquals(1, mc.getRow());
assertEquals(2, mc.getColumn());
mc = (MissingCellDummyRecord)r[cell00+8];
assertEquals(2, mc.getRow());
assertEquals(1, mc.getColumn());
mc = (MissingCellDummyRecord)r[cell00+9];
assertEquals(2, mc.getRow());
assertEquals(2, mc.getColumn());
mc = (MissingCellDummyRecord)r[cell00+55];
assertEquals(22, mc.getRow());
assertEquals(10, mc.getColumn());
}
// Make sure we don't put in any extra new lines
// that aren't already there
public void testNoExtraNewLines() {
// Load a different file
// This file has has something in lines 1-33
readRecords("MRExtraLines.xls");
int rowCount=0;
for (Record rec : r) {
if(rec instanceof LastCellOfRowDummyRecord) {
LastCellOfRowDummyRecord eor = (LastCellOfRowDummyRecord) rec;
assertEquals(rowCount, eor.getRow());
rowCount++;
}
}
// Check we got the 33 rows
assertEquals(33, rowCount);
}
private static final class MockHSSFListener implements HSSFListener {
public MockHSSFListener() {}
private final List<Record> _records = new ArrayList<Record>();
private final boolean logToStdOut = false;
@Override
public void processRecord(Record record) {
_records.add(record);
if(record instanceof MissingRowDummyRecord) {
MissingRowDummyRecord mr = (MissingRowDummyRecord)record;
log("Got dummy row " + mr.getRowNumber());
}
if(record instanceof MissingCellDummyRecord) {
MissingCellDummyRecord mc = (MissingCellDummyRecord)record;
log("Got dummy cell " + mc.getRow() + " " + mc.getColumn());
}
if(record instanceof LastCellOfRowDummyRecord) {
LastCellOfRowDummyRecord lc = (LastCellOfRowDummyRecord)record;
log("Got end-of row, row was " + lc.getRow() + ", last column was " + lc.getLastColumnNumber());
}
if(record instanceof BOFRecord) {
BOFRecord r = (BOFRecord)record;
if(r.getType() == BOFRecord.TYPE_WORKSHEET) {
log("On new sheet");
}
}
if(record instanceof RowRecord) {
RowRecord rr = (RowRecord)record;
log("Starting row #" + rr.getRowNumber());
}
}
private void log(String msg) {
if(logToStdOut) {
System.out.println(msg);
}
}
public Record[] getRecords() {
Record[] result = new Record[_records.size()];
_records.toArray(result);
return result;
}
}
/**
* Make sure that the presence of shared formulas does not cause extra
* end-of-row records.
*/
public void testEndOfRow_bug45672() {
readRecords("ex45672.xls");
Record[] rr = r;
int eorCount=0;
int sfrCount=0;
for (Record record : rr) {
if (record instanceof SharedFormulaRecord) {
sfrCount++;
}
if (record instanceof LastCellOfRowDummyRecord) {
eorCount++;
}
}
if (eorCount == 2) {
throw new AssertionFailedError("Identified bug 45672");
}
assertEquals(1, eorCount);
assertEquals(1, sfrCount);
}
/**
* MulBlank records hold multiple blank cells. Check we
* can handle them correctly.
*/
public void testMulBlankHandling() {
readRecords("45672.xls");
// Check that we don't have any MulBlankRecords, but do
// have lots of BlankRecords
Record[] rr = r;
int eorCount=0;
int mbrCount=0;
int brCount=0;
for (Record record : rr) {
if (record instanceof MulBlankRecord) {
mbrCount++;
}
if (record instanceof BlankRecord) {
brCount++;
}
if (record instanceof LastCellOfRowDummyRecord) {
eorCount++;
}
}
if (mbrCount > 0) {
throw new AssertionFailedError("Identified bug 45672");
}
if (brCount < 20) {
throw new AssertionFailedError("Identified bug 45672");
}
if (eorCount != 2) {
throw new AssertionFailedError("Identified bug 45672");
}
assertEquals(2, eorCount);
}
public void testStringRecordHandling(){
readRecords("53588.xls");
Record[] rr = r;
int missingCount=0;
int lastCount=0;
for (Record record : rr) {
if (record instanceof MissingCellDummyRecord) {
missingCount++;
}
if (record instanceof LastCellOfRowDummyRecord) {
lastCount++;
}
}
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
assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
assertEquals(0, ((LastCellOfRowDummyRecord)r[pos]).getRow());
assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
pos++;
assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
assertEquals(1, ((LastCellOfRowDummyRecord)r[pos]).getRow());
assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
pos++;
assertEquals(LastCellOfRowDummyRecord.class, r[pos].getClass());
assertEquals(2, ((LastCellOfRowDummyRecord)r[pos]).getRow());
assertEquals(-1, ((LastCellOfRowDummyRecord)r[pos]).getLastColumnNumber());
pos++;
// 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());
}
}