getActiveSheet(); $sheet->fromArray(self::CELL_VALUES); return $sheet; } public function testIteratorFullRange(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $iterator = new RowIterator($sheet); $rowIndexResult = 1; self::assertEquals($rowIndexResult, $iterator->key()); $counter = 0; foreach ($iterator as $key => $row) { ++$counter; self::assertEquals($rowIndexResult++, $key); self::assertInstanceOf(Row::class, $row); } self::assertCount($counter, self::CELL_VALUES); $spreadsheet->disconnectWorksheets(); } public function testIteratorStartEndRange(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $iterator = new RowIterator($sheet, 2, 4); $rowIndexResult = 2; self::assertEquals($rowIndexResult, $iterator->key()); $counter = 0; foreach ($iterator as $key => $row) { ++$counter; self::assertEquals($rowIndexResult++, $key); self::assertInstanceOf(Row::class, $row); } self::assertSame(3, $counter); $spreadsheet->disconnectWorksheets(); } public function testIteratorSeekAndPrev(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $iterator = new RowIterator($sheet, 2, 4); $columnIndexResult = 4; $iterator->seek(4); self::assertEquals($columnIndexResult, $iterator->key()); $counter = 0; while ($iterator->valid() !== false) { ++$counter; self::assertEquals($columnIndexResult, $iterator->key()); --$columnIndexResult; $iterator->prev(); } self::assertSame(3, $counter); $spreadsheet->disconnectWorksheets(); } public function testIteratorResetStart(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $iterator = new RowIterator($sheet, 2, 4); $iterator->resetStart(5); $key = $iterator->key(); self::assertSame(5, $key); $lastRow = $iterator->key(); while ($iterator->valid() !== false) { $iterator->next(); $lastRow = $iterator->key(); } self::assertSame(6, $lastRow); $spreadsheet->disconnectWorksheets(); } public function testSeekOutOfRange(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $this->expectException(Except::class); $iterator = new RowIterator($sheet, 2, 4); $iterator->seek(1); } public function testPrevOutOfRange(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $iterator = new RowIterator($sheet, 2, 4); $iterator->prev(); self::assertFalse($iterator->valid()); } public function testResetStartOutOfRange(): void { $spreadsheet = new Spreadsheet(); $sheet = self::getPopulatedSheet($spreadsheet); $this->expectException(Except::class); $iterator = new RowIterator($sheet, 2, 4); $iterator->resetStart(10); } }