This commit introduces Row and Cell entities, that will replace the arrays passed in previously. It also adds support for Cell styling (instead of Row styling only).
139 lines
4.4 KiB
PHP
139 lines
4.4 KiB
PHP
<?php
|
|
|
|
namespace Box\Spout\Writer\XLSX;
|
|
|
|
use Box\Spout\Common\Type;
|
|
use Box\Spout\TestUsingResource;
|
|
use Box\Spout\Writer\Common\Entity\Sheet;
|
|
use Box\Spout\Writer\RowCreationHelper;
|
|
use Box\Spout\Writer\WriterFactory;
|
|
|
|
/**
|
|
* Class SheetTest
|
|
*/
|
|
class SheetTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
use TestUsingResource;
|
|
use RowCreationHelper;
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testGetSheetIndex()
|
|
{
|
|
$sheets = $this->writeDataToMulitpleSheetsAndReturnSheets('test_get_sheet_index.xlsx');
|
|
|
|
$this->assertEquals(2, count($sheets), '2 sheets should have been created');
|
|
$this->assertEquals(0, $sheets[0]->getIndex(), 'The first sheet should be index 0');
|
|
$this->assertEquals(1, $sheets[1]->getIndex(), 'The second sheet should be index 1');
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testGetSheetName()
|
|
{
|
|
$sheets = $this->writeDataToMulitpleSheetsAndReturnSheets('test_get_sheet_name.xlsx');
|
|
|
|
$this->assertEquals(2, count($sheets), '2 sheets should have been created');
|
|
$this->assertEquals('Sheet1', $sheets[0]->getName(), 'Invalid name for the first sheet');
|
|
$this->assertEquals('Sheet2', $sheets[1]->getName(), 'Invalid name for the second sheet');
|
|
}
|
|
|
|
/**
|
|
* @return void
|
|
*/
|
|
public function testSetSheetNameShouldCreateSheetWithCustomName()
|
|
{
|
|
$fileName = 'test_set_name_should_create_sheet_with_custom_name.xlsx';
|
|
$customSheetName = 'CustomName';
|
|
$this->writeDataAndReturnSheetWithCustomName($fileName, $customSheetName);
|
|
|
|
$this->assertSheetNameEquals($customSheetName, $fileName, "The sheet name should have been changed to '$customSheetName'");
|
|
}
|
|
|
|
/**
|
|
* @expectedException \Box\Spout\Writer\Exception\InvalidSheetNameException
|
|
* @return void
|
|
*/
|
|
public function testSetSheetNameShouldThrowWhenNameIsAlreadyUsed()
|
|
{
|
|
$fileName = 'test_set_name_with_non_unique_name.xlsx';
|
|
$this->createGeneratedFolderIfNeeded($fileName);
|
|
$resourcePath = $this->getGeneratedResourcePath($fileName);
|
|
|
|
/** @var \Box\Spout\Writer\XLSX\Writer $writer */
|
|
$writer = WriterFactory::create(Type::XLSX);
|
|
$writer->openToFile($resourcePath);
|
|
|
|
$customSheetName = 'Sheet name';
|
|
|
|
$sheet = $writer->getCurrentSheet();
|
|
$sheet->setName($customSheetName);
|
|
|
|
$writer->addNewSheetAndMakeItCurrent();
|
|
$sheet = $writer->getCurrentSheet();
|
|
$sheet->setName($customSheetName);
|
|
}
|
|
|
|
/**
|
|
* @param string $fileName
|
|
* @param string $sheetName
|
|
* @return Sheet
|
|
*/
|
|
private function writeDataAndReturnSheetWithCustomName($fileName, $sheetName)
|
|
{
|
|
$this->createGeneratedFolderIfNeeded($fileName);
|
|
$resourcePath = $this->getGeneratedResourcePath($fileName);
|
|
|
|
/** @var \Box\Spout\Writer\XLSX\Writer $writer */
|
|
$writer = WriterFactory::create(Type::XLSX);
|
|
$writer->openToFile($resourcePath);
|
|
|
|
$sheet = $writer->getCurrentSheet();
|
|
$sheet->setName($sheetName);
|
|
|
|
$writer->addRow($this->createRowFromValues(['xlsx--11', 'xlsx--12']));
|
|
$writer->close();
|
|
|
|
return $sheet;
|
|
}
|
|
|
|
/**
|
|
* @param string $fileName
|
|
* @return Sheet[]
|
|
*/
|
|
private function writeDataToMulitpleSheetsAndReturnSheets($fileName)
|
|
{
|
|
$this->createGeneratedFolderIfNeeded($fileName);
|
|
$resourcePath = $this->getGeneratedResourcePath($fileName);
|
|
|
|
/** @var \Box\Spout\Writer\XLSX\Writer $writer */
|
|
$writer = WriterFactory::create(Type::XLSX);
|
|
$writer->openToFile($resourcePath);
|
|
|
|
$writer->addRow($this->createRowFromValues(['xlsx--sheet1--11', 'xlsx--sheet1--12']));
|
|
$writer->addNewSheetAndMakeItCurrent();
|
|
$writer->addRow($this->createRowFromValues(['xlsx--sheet2--11', 'xlsx--sheet2--12', 'xlsx--sheet2--13']));
|
|
|
|
$writer->close();
|
|
|
|
return $writer->getSheets();
|
|
}
|
|
|
|
/**
|
|
* @param string $expectedName
|
|
* @param string $fileName
|
|
* @param string $message
|
|
* @return void
|
|
*/
|
|
private function assertSheetNameEquals($expectedName, $fileName, $message = '')
|
|
{
|
|
$resourcePath = $this->getGeneratedResourcePath($fileName);
|
|
$pathToWorkbookFile = $resourcePath . '#xl/workbook.xml';
|
|
$xmlContents = file_get_contents('zip://' . $pathToWorkbookFile);
|
|
|
|
$this->assertContains("<sheet name=\"$expectedName\"", $xmlContents, $message);
|
|
}
|
|
}
|