Issue2542Test.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
  3. use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
  4. use PhpOffice\PhpSpreadsheet\RichText\RichText;
  5. use PHPUnit\Framework\TestCase;
  6. class Issue2542Test extends TestCase
  7. {
  8. /**
  9. * @var string
  10. */
  11. private static $testbook = 'tests/data/Reader/XLSX/issue.2542.xlsx';
  12. public function testPreliminaries(): void
  13. {
  14. // Rich text without 'sz' tag
  15. $file = 'zip://';
  16. $file .= self::$testbook;
  17. $file .= '#xl/sharedStrings.xml';
  18. $data = file_get_contents($file);
  19. // confirm that file contains expected namespaced xml tag
  20. if ($data === false) {
  21. self::fail('Unable to read file sharedStrings.xml');
  22. } else {
  23. self::assertStringContainsString('<si><r><rPr><rFont val="Arial"/><b/><color theme="1"/></rPr><t xml:space="preserve">Factor group
  24. </t></r><r><rPr><rFont val="Arial"/><b val="0"/><color theme="1"/></rPr><t>(for Rental items only)</t></r></si>', $data);
  25. }
  26. }
  27. public function testIssue2542(): void
  28. {
  29. $filename = self::$testbook;
  30. $reader = new Xlsx();
  31. $spreadsheet = $reader->load($filename);
  32. $sheet = $spreadsheet->getActiveSheet();
  33. $value = $sheet->getCell('P1')->getValue();
  34. if ($value instanceof RichText) {
  35. self::assertSame("Factor group\n(for Rental items only)", $value->getPlainText());
  36. } else {
  37. self::fail('Cell P1 is not RichText');
  38. }
  39. $spreadsheet->disconnectWorksheets();
  40. }
  41. }