CsvNumberFormatLocaleTest.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Reader\Csv;
  3. use PhpOffice\PhpSpreadsheet\Cell\DataType;
  4. use PhpOffice\PhpSpreadsheet\Reader\Csv;
  5. use PHPUnit\Framework\TestCase;
  6. class CsvNumberFormatLocaleTest extends TestCase
  7. {
  8. /**
  9. * @var bool
  10. */
  11. private $localeAdjusted;
  12. /**
  13. * @var false|string
  14. */
  15. private $currentLocale;
  16. /**
  17. * @var string
  18. */
  19. protected $filename;
  20. /**
  21. * @var Csv
  22. */
  23. protected $csvReader;
  24. protected function setUp(): void
  25. {
  26. $this->currentLocale = setlocale(LC_ALL, '0');
  27. if (!setlocale(LC_ALL, 'de_DE.UTF-8', 'deu_deu')) {
  28. $this->localeAdjusted = false;
  29. return;
  30. }
  31. $this->localeAdjusted = true;
  32. $this->filename = 'tests/data/Reader/CSV/NumberFormatTest.de.csv';
  33. $this->csvReader = new Csv();
  34. }
  35. protected function tearDown(): void
  36. {
  37. if ($this->localeAdjusted && is_string($this->currentLocale)) {
  38. setlocale(LC_ALL, $this->currentLocale);
  39. }
  40. }
  41. /**
  42. * @dataProvider providerNumberFormatNoConversionTest
  43. *
  44. * @param mixed $expectedValue
  45. */
  46. public function testNumberFormatNoConversion($expectedValue, string $expectedFormat, string $cellAddress): void
  47. {
  48. if (!$this->localeAdjusted) {
  49. self::markTestSkipped('Unable to set locale for testing.');
  50. }
  51. $spreadsheet = $this->csvReader->load($this->filename);
  52. $worksheet = $spreadsheet->getActiveSheet();
  53. $cell = $worksheet->getCell($cellAddress);
  54. self::assertSame($expectedValue, $cell->getValue(), 'Expected value check');
  55. self::assertSame($expectedFormat, $cell->getFormattedValue(), 'Format mask check');
  56. }
  57. public function providerNumberFormatNoConversionTest(): array
  58. {
  59. return [
  60. [
  61. -123,
  62. '-123',
  63. 'A1',
  64. ],
  65. [
  66. '12.345,67',
  67. '12.345,67',
  68. 'C1',
  69. ],
  70. [
  71. '-1.234,567',
  72. '-1.234,567',
  73. 'A3',
  74. ],
  75. ];
  76. }
  77. /**
  78. * @dataProvider providerNumberValueConversionTest
  79. *
  80. * @param mixed $expectedValue
  81. *
  82. * @runInSeparateProcess
  83. */
  84. public function testNumberValueConversion($expectedValue, string $cellAddress): void
  85. {
  86. if (!$this->localeAdjusted) {
  87. self::markTestSkipped('Unable to set locale for testing.');
  88. }
  89. $this->csvReader->castFormattedNumberToNumeric(true);
  90. $spreadsheet = $this->csvReader->load($this->filename);
  91. $worksheet = $spreadsheet->getActiveSheet();
  92. $cell = $worksheet->getCell($cellAddress);
  93. self::assertSame(DataType::TYPE_NUMERIC, $cell->getDataType(), 'Datatype check');
  94. self::assertSame($expectedValue, $cell->getValue(), 'Expected value check');
  95. }
  96. public function providerNumberValueConversionTest(): array
  97. {
  98. return [
  99. 'A1' => [
  100. -123,
  101. 'A1',
  102. ],
  103. 'B1' => [
  104. 1234,
  105. 'B1',
  106. ],
  107. 'C1' => [
  108. 12345.67,
  109. 'C1',
  110. ],
  111. 'A2' => [
  112. 123.4567,
  113. 'A2',
  114. ],
  115. 'B2' => [
  116. 123.456789012,
  117. 'B2',
  118. ],
  119. 'A3' => [
  120. -1234.567,
  121. 'A3',
  122. ],
  123. ];
  124. }
  125. }