Passed
Pull Request — master (#3108)
by Sergei
12:12
created

DateExpressionTest::diff()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 17
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 17
rs 9.4285
c 0
b 0
f 0
cc 1
eloc 11
nc 1
nop 3
1
<?php
2
3
namespace Doctrine\Tests\DBAL\Functional\Platform;
4
5
use Doctrine\DBAL\Schema\Table;
6
use Doctrine\Tests\DbalFunctionalTestCase;
7
use function sprintf;
8
9
class DateExpressionTest extends DbalFunctionalTestCase
10
{
11
    /**
12
     * @test
13
     * @dataProvider dateDiffProvider
14
     */
15
    public function diff(string $date1, string $date2, int $expected)
16
    {
17
        $table = new Table('date_expr_test');
18
        $table->addColumn('date1', 'date');
19
        $table->addColumn('date2', 'date');
20
        $this->_conn->getSchemaManager()->dropAndCreateTable($table);
21
        $this->_conn->insert('date_expr_test', [
22
            'date1' => $date1,
23
            'date2' => $date2,
24
        ]);
25
26
        $platform = $this->_conn->getDatabasePlatform();
27
28
        $sql  = sprintf('SELECT %s FROM date_expr_test', $platform->getDateDiffExpression('date1', 'date2'));
29
        $diff = $this->_conn->query($sql)->fetchColumn();
30
31
        self::assertEquals($expected, $diff);
32
    }
33
34
    public static function dateDiffProvider()
35
    {
36
        return [
37
            'same day' => ['2018-04-14 23:59:59', '2018-04-14 00:00:00', 0],
38
            'midnight' => ['2018-04-14 00:00:00', '2018-04-13 23:59:59', 1],
39
        ];
40
    }
41
}
42