1a0aab1a4f
There are no changes to code. Additional tests are added, so that the following 6 items now have 100% test coverage: - Comment - DefinedName - DocumentGenerator - IOFactory - NamedFormula - NamedRange
58 lines
1.8 KiB
PHP
58 lines
1.8 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Functional;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
use PhpOffice\PhpSpreadsheet\Style\Alignment;
|
|
|
|
class CommentsTest extends AbstractFunctional
|
|
{
|
|
public function providerFormats()
|
|
{
|
|
return [
|
|
['Html'],
|
|
['Xlsx'],
|
|
['Ods'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Test load file with comment in sheet to load proper
|
|
* count of comments in correct coords.
|
|
*
|
|
* @dataProvider providerFormats
|
|
*
|
|
* @param $format
|
|
*/
|
|
public function testComments($format): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
|
|
$spreadsheet->getActiveSheet()->getCell('E10')->setValue('Comment');
|
|
$spreadsheet->getActiveSheet()
|
|
->getComment('E10')
|
|
->getText()
|
|
->createText('Comment to test');
|
|
|
|
$reloadedSpreadsheet = $this->writeAndReload($spreadsheet, $format);
|
|
|
|
$sheet = $reloadedSpreadsheet->getSheet(0);
|
|
$commentsLoaded = $sheet->getComments();
|
|
self::assertCount(1, $commentsLoaded);
|
|
|
|
$commentCoordinate = key($commentsLoaded);
|
|
self::assertSame('E10', $commentCoordinate);
|
|
$comment = $commentsLoaded[$commentCoordinate];
|
|
self::assertEquals('Comment to test', (string) $comment);
|
|
$commentClone = clone $comment;
|
|
self::assertEquals($comment, $commentClone);
|
|
self::assertNotSame($comment, $commentClone);
|
|
if ($format === 'Xlsx') {
|
|
self::assertEquals('feb0c24b880a8130262dadf801f85e94', $comment->getHashCode());
|
|
self::assertEquals(Alignment::HORIZONTAL_GENERAL, $comment->getAlignment());
|
|
$comment->setAlignment(Alignment::HORIZONTAL_RIGHT);
|
|
self::assertEquals(Alignment::HORIZONTAL_RIGHT, $comment->getAlignment());
|
|
}
|
|
}
|
|
}
|