DateValueTest.php 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\DateTime;
  3. use DateTimeImmutable;
  4. use DateTimeInterface;
  5. use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
  6. use PhpOffice\PhpSpreadsheet\Calculation\DateTimeExcel\DateValue;
  7. class DateValueTest extends AllSetupTeardown
  8. {
  9. /**
  10. * @dataProvider providerDATEVALUE
  11. *
  12. * @param mixed $expectedResult
  13. */
  14. public function testDATEVALUE($expectedResult, string $dateValue): void
  15. {
  16. $this->getSheet()->getCell('B1')->setValue('1954-07-20');
  17. // Loop to avoid extraordinarily rare edge case where first calculation
  18. // and second do not take place on same day.
  19. $row = 0;
  20. do {
  21. ++$row;
  22. $dtStart = new DateTimeImmutable();
  23. $startDay = $dtStart->format('d');
  24. if (is_string($expectedResult)) {
  25. $replYMD = str_replace('Y', date('Y'), $expectedResult);
  26. if ($replYMD !== $expectedResult) {
  27. $expectedResult = DateValue::fromString($replYMD);
  28. }
  29. }
  30. $this->getSheet()->getCell("A$row")->setValue("=DATEVALUE($dateValue)");
  31. $result = $this->getSheet()->getCell("A$row")->getCalculatedValue();
  32. $dtEnd = new DateTimeImmutable();
  33. $endDay = $dtEnd->format('d');
  34. } while ($startDay !== $endDay);
  35. self::assertEqualsWithDelta($expectedResult, $result, 1E-8);
  36. }
  37. public function providerDATEVALUE(): array
  38. {
  39. return require 'tests/data/Calculation/DateTime/DATEVALUE.php';
  40. }
  41. public function testDATEVALUEtoUnixTimestamp(): void
  42. {
  43. self::setUnixReturn();
  44. $result = DateValue::fromString('2012-1-31');
  45. self::assertEquals(1327968000, $result);
  46. self::assertEqualsWithDelta(1327968000, $result, 1E-8);
  47. }
  48. public function testDATEVALUEtoDateTimeObject(): void
  49. {
  50. self::setObjectReturn();
  51. $result = DateValue::fromString('2012-1-31');
  52. // Must return an object...
  53. self::assertIsObject($result);
  54. // ... of the correct type
  55. self::assertTrue(is_a($result, DateTimeInterface::class));
  56. // ... with the correct value
  57. self::assertEquals($result->format('d-M-Y'), '31-Jan-2012');
  58. }
  59. public function testDATEVALUEwith1904Calendar(): void
  60. {
  61. self::setMac1904();
  62. self::assertEquals(5428, DateValue::fromString('1918-11-11'));
  63. self::assertEquals(0, DateValue::fromString('1904-01-01'));
  64. self::assertEquals('#VALUE!', DateValue::fromString('1903-12-31'));
  65. self::assertEquals('#VALUE!', DateValue::fromString('1900-02-29'));
  66. }
  67. /**
  68. * @dataProvider providerDateValueArray
  69. */
  70. public function testDateValueArray(array $expectedResult, string $array): void
  71. {
  72. $calculation = Calculation::getInstance();
  73. $formula = "=DATEVALUE({$array})";
  74. $result = $calculation->_calculateFormulaValue($formula);
  75. self::assertEqualsWithDelta($expectedResult, $result, 1.0e-14);
  76. }
  77. public function providerDateValueArray(): array
  78. {
  79. return [
  80. 'row vector' => [[[44562, 44724, 45129]], '{"2022-01-01", "2022-06-12", "2023-07-22"}'],
  81. 'column vector' => [[[44562], [44564], [44567]], '{"2022-01-01"; "2022-01-03"; "2022-01-06"}'],
  82. 'matrix' => [[[44562, 44571], [44788, 44926]], '{"2022-01-01", "2022-01-10"; "2022-08-15", "2022-12-31"}'],
  83. ];
  84. }
  85. }