PhpSpreadsheet/tests/PhpSpreadsheetTests/Calculation/Functions/DateTime/MovedFunctionsTest.php

64 lines
2.9 KiB
PHP

<?php
namespace PhpOffice\PhpSpreadsheetTests\Calculation\Functions\DateTime;
use DateTimeImmutable;
use PhpOffice\PhpSpreadsheet\Calculation\DateTime;
use PhpOffice\PhpSpreadsheet\Calculation\Functions;
use PHPUnit\Framework\TestCase;
/**
* Sanity tests for functions which have been moved out of DateTime
* to their own classes. A deprecated version remains in DateTime;
* this class contains cursory tests to ensure that those work properly.
* If Scrutinizer fails the PR because of these deprecations, I will
* remove this class from the PR.
*
* @covers \PhpOffice\PhpSpreadsheet\Calculation\DateTime
*/
class MovedFunctionsTest extends TestCase
{
public function testMovedFunctions(): void
{
self::assertTrue(DateTime::isLeapYear(1904));
self::assertSame('#VALUE!', DateTime::getDateValue('XYZ'));
self::assertSame(61.0, DateTime::getDateValue('1900-03-01'));
self::assertSame(61.0, DateTime::DATE(1900, 3, 1));
self::assertSame(365, DateTime::DATEDIF('2016-01-01', '2016-12-31', 'YD'));
self::assertSame(61.0, DateTime::DATEVALUE('1900-03-01'));
self::assertSame(28, DateTime::DAYOFMONTH('1904-02-28'));
self::assertSame(364, DateTime::DAYS('2007-12-31', '2007-1-1'));
self::assertSame(9, DateTime::DAYS360('2007-1-1', '2007-1-10', false));
self::assertSame(39493.0, DateTime::EDATE('15-Jan-2008', 1));
self::assertSame(39507.0, DateTime::EOMONTH('15-Jan-2008', 1));
self::assertSame(18, DateTime::HOUROFDAY(0.75));
self::assertSame(52, DateTime::ISOWEEKNUM('2000-01-01'));
self::assertSame(24, DateTime::MINUTE(0.6));
self::assertSame(11, DateTime::MONTHOFYEAR('11-Nov-1918'));
self::assertSame(8, DateTime::NETWORKDAYS('1-Jan-2007', '10-Jan-2007'));
self::assertSame(35, DateTime::SECOND('11:15:35'));
self::assertSame(0.5, DateTime::TIME(12, 0, 0));
self::assertSame(0.40625, DateTime::TIMEVALUE('33:45'));
self::assertSame(5, DateTime::WEEKDAY('24-Oct-1968'));
self::assertSame(52, DateTime::WEEKNUM('21-Dec-2000'));
self::assertSame(39094.0, DateTime::WORKDAY('1-Jan-2007', 9));
self::assertSame(1904, DateTime::YEAR('1904-02-28'));
self::assertSame(0.025, DateTime::YEARFRAC('2007-01-10', '2007-01-01', 0));
}
public function testTodayAndNow(): void
{
// Loop to avoid rare edge case where first calculation
// and second do not take place in same second.
do {
$dtStart = new DateTimeImmutable();
$startSecond = $dtStart->format('s');
$nowResult = DateTime::DATETIMENOW();
$todayResult = DateTime::DATENOW();
$dtEnd = new DateTimeImmutable();
$endSecond = $dtEnd->format('s');
} while ($startSecond !== $endSecond);
self::assertSame(DateTime::DAYOFMONTH($nowResult), DateTime::DAYOFMONTH($todayResult));
}
}