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());
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |