| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests\Reader\Csv;
- use PhpOffice\PhpSpreadsheet\Cell\DataType;
- use PhpOffice\PhpSpreadsheet\Reader\Csv;
- use PHPUnit\Framework\TestCase;
- class CsvNumberFormatTest extends TestCase
- {
- /**
- * @var string
- */
- protected $filename;
- /**
- * @var Csv
- */
- protected $csvReader;
- protected function setUp(): void
- {
- $this->filename = 'tests/data/Reader/CSV/NumberFormatTest.csv';
- $this->csvReader = new Csv();
- }
- /**
- * @dataProvider providerNumberFormatNoConversionTest
- *
- * @param mixed $expectedValue
- */
- public function testNumberFormatNoConversion($expectedValue, string $expectedFormat, string $cellAddress): void
- {
- $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
- */
- public function testNumberValueConversion($expectedValue, string $cellAddress): void
- {
- $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',
- ],
- 'B3' => [
- 1234.567,
- 'B3',
- ],
- ];
- }
- /**
- * @dataProvider providerNumberFormatConversionTest
- *
- * @param mixed $expectedValue
- */
- public function testNumberFormatConversion($expectedValue, string $expectedFormat, string $cellAddress): void
- {
- $this->csvReader->castFormattedNumberToNumeric(true, 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');
- self::assertSame($expectedFormat, $cell->getFormattedValue(), 'Format mask check');
- }
- public function providerNumberFormatConversionTest(): array
- {
- return [
- 'A1' => [
- -123,
- '-123',
- 'A1',
- ],
- 'B1' => [
- 1234,
- '1,234',
- 'B1',
- ],
- 'C1' => [
- 12345.67,
- '12,345.67',
- 'C1',
- ],
- 'A2' => [
- 123.4567,
- '123.4567',
- 'A2',
- ],
- 'B2' => [
- 123.456789012,
- '123.456789',
- 'B2',
- ],
- 'A3' => [
- -1234.567,
- '-1,234.567',
- 'A3',
- ],
- 'B3' => [
- 1234.567,
- '1234.567',
- 'B3',
- ],
- ];
- }
- }
|