2020-07-05 14:22:35 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xml;
|
|
|
|
|
|
|
|
use PhpOffice\PhpSpreadsheet\Reader\Xml;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
class PageSetupTest extends TestCase
|
|
|
|
{
|
|
|
|
private const MARGIN_PRECISION = 0.000001;
|
|
|
|
|
|
|
|
private const MARGIN_UNIT_CONVERSION = 2.54; // Inches to cm
|
|
|
|
/**
|
2020-07-05 15:05:44 +00:00
|
|
|
* @var Spreadsheet
|
2020-07-05 14:22:35 +00:00
|
|
|
*/
|
|
|
|
private $spreadsheet;
|
|
|
|
|
2020-07-05 15:05:44 +00:00
|
|
|
protected function setup(): void
|
2020-07-05 14:22:35 +00:00
|
|
|
{
|
|
|
|
$filename = 'tests/data/Reader/Xml/PageSetup.xml';
|
|
|
|
$reader = new Xml();
|
|
|
|
$this->spreadsheet = $reader->load($filename);
|
|
|
|
}
|
|
|
|
|
2020-07-05 15:05:44 +00:00
|
|
|
public function testPageSetup(): void
|
2020-07-05 14:22:35 +00:00
|
|
|
{
|
|
|
|
$assertions = $this->pageSetupAssertions();
|
|
|
|
|
|
|
|
foreach ($this->spreadsheet->getAllSheets() as $worksheet) {
|
|
|
|
if (!array_key_exists($worksheet->getTitle(), $assertions)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sheetAssertions = $assertions[$worksheet->getTitle()];
|
|
|
|
foreach ($sheetAssertions as $test => $expectedResult) {
|
|
|
|
$testMethodName = 'get' . ucfirst($test);
|
|
|
|
$actualResult = $worksheet->getPageSetup()->$testMethodName();
|
2020-07-05 15:05:44 +00:00
|
|
|
self::assertSame(
|
2020-07-05 14:22:35 +00:00
|
|
|
$expectedResult,
|
|
|
|
$actualResult,
|
|
|
|
"Failed assertion for Worksheet '{$worksheet->getTitle()}' {$test}"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-05 15:05:44 +00:00
|
|
|
public function testPageMargins(): void
|
2020-07-05 14:22:35 +00:00
|
|
|
{
|
|
|
|
$assertions = $this->pageMarginAssertions();
|
|
|
|
|
|
|
|
foreach ($this->spreadsheet->getAllSheets() as $worksheet) {
|
|
|
|
if (!array_key_exists($worksheet->getTitle(), $assertions)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$sheetAssertions = $assertions[$worksheet->getTitle()];
|
|
|
|
foreach ($sheetAssertions as $test => $expectedResult) {
|
|
|
|
$testMethodName = 'get' . ucfirst($test);
|
|
|
|
$actualResult = $worksheet->getPageMargins()->$testMethodName();
|
2020-07-05 15:05:44 +00:00
|
|
|
self::assertEqualsWithDelta(
|
2020-07-05 14:22:35 +00:00
|
|
|
$expectedResult,
|
|
|
|
$actualResult,
|
|
|
|
self::MARGIN_PRECISION,
|
|
|
|
"Failed assertion for Worksheet '{$worksheet->getTitle()}' {$test} margin"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function pageSetupAssertions()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'Sheet1' => [
|
|
|
|
'orientation' => PageSetup::ORIENTATION_PORTRAIT,
|
|
|
|
'scale' => 75,
|
|
|
|
'horizontalCentered' => true,
|
|
|
|
'verticalCentered' => false,
|
|
|
|
'pageOrder' => PageSetup::PAGEORDER_DOWN_THEN_OVER,
|
|
|
|
],
|
|
|
|
'Sheet2' => [
|
|
|
|
'orientation' => PageSetup::ORIENTATION_LANDSCAPE,
|
|
|
|
'scale' => 100,
|
|
|
|
'horizontalCentered' => false,
|
|
|
|
'verticalCentered' => true,
|
|
|
|
'pageOrder' => PageSetup::PAGEORDER_OVER_THEN_DOWN,
|
|
|
|
],
|
|
|
|
'Sheet3' => [
|
|
|
|
'orientation' => PageSetup::ORIENTATION_PORTRAIT,
|
|
|
|
'scale' => 90,
|
|
|
|
'horizontalCentered' => true,
|
|
|
|
'verticalCentered' => true,
|
|
|
|
'pageOrder' => PageSetup::PAGEORDER_DOWN_THEN_OVER,
|
|
|
|
],
|
|
|
|
'Sheet4' => [
|
|
|
|
// Default Settings
|
|
|
|
'orientation' => PageSetup::ORIENTATION_DEFAULT,
|
|
|
|
'scale' => 100,
|
|
|
|
'horizontalCentered' => false,
|
|
|
|
'verticalCentered' => false,
|
|
|
|
'pageOrder' => PageSetup::PAGEORDER_DOWN_THEN_OVER,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function pageMarginAssertions()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'Sheet1' => [
|
|
|
|
// Here the values are in cm, so we convert to inches for comparison with internal uom
|
|
|
|
'top' => 2.4 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'header' => 0.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'left' => 1.3 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'right' => 1.3 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'bottom' => 1.9 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'footer' => 0.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
],
|
|
|
|
'Sheet2' => [
|
|
|
|
// Here the values are in cm, so we convert to inches for comparison with internal uom
|
|
|
|
'top' => 1.9 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'header' => 0.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'left' => 1.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'right' => 1.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'bottom' => 1.9 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'footer' => 0.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
],
|
|
|
|
'Sheet3' => [
|
|
|
|
// Here the values are in cm, so we convert to inches for comparison with internal uom
|
|
|
|
'top' => 2.4 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'header' => 1.3 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'left' => 1.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'right' => 1.8 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'bottom' => 2.4 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
'footer' => 1.3 / self::MARGIN_UNIT_CONVERSION,
|
|
|
|
],
|
|
|
|
'Sheet4' => [
|
|
|
|
// Default Settings (already in inches for comparison)
|
|
|
|
'top' => 0.75,
|
|
|
|
'header' => 0.3,
|
|
|
|
'left' => 0.7,
|
|
|
|
'right' => 0.7,
|
|
|
|
'bottom' => 0.75,
|
|
|
|
'footer' => 0.3,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|