| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests\Reader\Csv;
- use PhpOffice\PhpSpreadsheet\Cell\DataType;
- use PhpOffice\PhpSpreadsheet\Reader\Csv;
- use PHPUnit\Framework\TestCase;
- class CsvNumberFormatLocaleTest extends TestCase
- {
- /**
- * @var bool
- */
- private $localeAdjusted;
- /**
- * @var false|string
- */
- private $currentLocale;
- /**
- * @var string
- */
- protected $filename;
- /**
- * @var Csv
- */
- protected $csvReader;
- protected function setUp(): void
- {
- $this->currentLocale = setlocale(LC_ALL, '0');
- if (!setlocale(LC_ALL, 'de_DE.UTF-8', 'deu_deu')) {
- $this->localeAdjusted = false;
- return;
- }
- $this->localeAdjusted = true;
- $this->filename = 'tests/data/Reader/CSV/NumberFormatTest.de.csv';
- $this->csvReader = new Csv();
- }
- protected function tearDown(): void
- {
- if ($this->localeAdjusted && is_string($this->currentLocale)) {
- setlocale(LC_ALL, $this->currentLocale);
- }
- }
- /**
- * @dataProvider providerNumberFormatNoConversionTest
- *
- * @param mixed $expectedValue
- */
- public function testNumberFormatNoConversion($expectedValue, string $expectedFormat, string $cellAddress): void
- {
- if (!$this->localeAdjusted) {
- self::markTestSkipped('Unable to set locale for testing.');
- }
- $spreadsheet = $this->csvReader->load($this->filename);
- $worksheet = $spreadsheet->getActiveSheet();
- $cell = $worksheet->getCell($cellAddress);
- self::assertSame($expectedValue, $cell->getValue(), 'Expected value check');
- self::assertSame($expectedFormat, $cell->getFormattedValue(), 'Format mask check');
- }
- public function providerNumberFormatNoConversionTest(): array
- {
- return [
- [
- -123,
- '-123',
- 'A1',
- ],
- [
- '12.345,67',
- '12.345,67',
- 'C1',
- ],
- [
- '-1.234,567',
- '-1.234,567',
- 'A3',
- ],
- ];
- }
- /**
- * @dataProvider providerNumberValueConversionTest
- *
- * @param mixed $expectedValue
- *
- * @runInSeparateProcess
- */
- public function testNumberValueConversion($expectedValue, string $cellAddress): void
- {
- if (!$this->localeAdjusted) {
- self::markTestSkipped('Unable to set locale for testing.');
- }
- $this->csvReader->castFormattedNumberToNumeric(true);
- $spreadsheet = $this->csvReader->load($this->filename);
- $worksheet = $spreadsheet->getActiveSheet();
- $cell = $worksheet->getCell($cellAddress);
- self::assertSame(DataType::TYPE_NUMERIC, $cell->getDataType(), 'Datatype check');
- self::assertSame($expectedValue, $cell->getValue(), 'Expected value check');
- }
- public function providerNumberValueConversionTest(): array
- {
- return [
- 'A1' => [
- -123,
- 'A1',
- ],
- 'B1' => [
- 1234,
- 'B1',
- ],
- 'C1' => [
- 12345.67,
- 'C1',
- ],
- 'A2' => [
- 123.4567,
- 'A2',
- ],
- 'B2' => [
- 123.456789012,
- 'B2',
- ],
- 'A3' => [
- -1234.567,
- 'A3',
- ],
- ];
- }
- }
|