DateExpressionTest.php 1.67 KB
Newer Older
1 2
<?php

3
namespace Doctrine\DBAL\Tests\Functional\Platform;
4 5 6

use DateTimeImmutable;
use Doctrine\DBAL\Schema\Table;
7
use Doctrine\DBAL\Tests\FunctionalTestCase;
8 9
use function sprintf;

10
class DateExpressionTest extends FunctionalTestCase
11 12 13 14 15 16 17
{
    /**
     * @dataProvider differenceProvider
     */
    public function testDifference(string $date1, string $date2, int $expected) : void
    {
        $table = new Table('date_expr_test');
Sergei Morozov's avatar
Sergei Morozov committed
18 19
        $table->addColumn('date1', 'datetime');
        $table->addColumn('date2', 'datetime');
Sergei Morozov's avatar
Sergei Morozov committed
20 21
        $this->connection->getSchemaManager()->dropAndCreateTable($table);
        $this->connection->insert('date_expr_test', [
22 23 24 25
            'date1' => $date1,
            'date2' => $date2,
        ]);

Sergei Morozov's avatar
Sergei Morozov committed
26
        $platform = $this->connection->getDatabasePlatform();
27 28

        $sql  = sprintf('SELECT %s FROM date_expr_test', $platform->getDateDiffExpression('date1', 'date2'));
Sergei Morozov's avatar
Sergei Morozov committed
29
        $diff = $this->connection->query($sql)->fetchColumn();
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55

        self::assertEquals($expected, $diff);
    }

    /**
     * @return string[][]|int[][]
     */
    public static function differenceProvider() : iterable
    {
        $date1    = new DateTimeImmutable();
        $date2    = new DateTimeImmutable('2018-04-10 10:10:10');
        $expected = $date1->modify('midnight')->diff(
            $date2->modify('midnight')
        )->days;

        return [
            'dynamic'  => [
                $date1->format('Y-m-d H:i:s'),
                $date2->format('Y-m-d H:i:s'),
                $expected,
            ],
            'same day' => ['2018-04-14 23:59:59', '2018-04-14 00:00:00', 0],
            'midnight' => ['2018-04-14 00:00:00', '2018-04-13 23:59:59', 1],
        ];
    }
}