StatementTest.php 2.84 KB
Newer Older
1 2 3 4 5 6
<?php

namespace Doctrine\Tests\DBAL\Functional\Driver\OCI8;

use Doctrine\DBAL\Driver\OCI8\Driver;
use Doctrine\Tests\DbalFunctionalTestCase;
7
use function extension_loaded;
8 9 10

class StatementTest extends DbalFunctionalTestCase
{
11
    protected function setUp() : void
12 13 14 15 16 17 18
    {
        if (! extension_loaded('oci8')) {
            $this->markTestSkipped('oci8 is not installed.');
        }

        parent::setUp();

Sergei Morozov's avatar
Sergei Morozov committed
19
        if ($this->connection->getDriver() instanceof Driver) {
Sergei Morozov's avatar
Sergei Morozov committed
20
            return;
21
        }
Sergei Morozov's avatar
Sergei Morozov committed
22 23

        $this->markTestSkipped('oci8 only test.');
24 25 26
    }

    /**
Sergei Morozov's avatar
Sergei Morozov committed
27 28 29
     * @param mixed[] $params
     * @param mixed[] $expected
     *
30 31
     * @dataProvider queryConversionProvider
     */
32
    public function testQueryConversion(string $query, array $params, array $expected) : void
33
    {
34
        self::assertEquals(
35
            $expected,
Sergei Morozov's avatar
Sergei Morozov committed
36
            $this->connection->executeQuery($query, $params)->fetch()
37 38 39
        );
    }

40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
    /**
     * Low-level approach to working with parameter binding
     *
     * @param mixed[] $params
     * @param mixed[] $expected
     *
     * @dataProvider queryConversionProvider
     */
    public function testStatementBindParameters(string $query, array $params, array $expected) : void
    {
        $stmt = $this->connection->prepare($query);
        $stmt->execute($params);

        self::assertEquals(
            $expected,
            $stmt->fetch()
        );
    }

59 60 61 62
    /**
     * @return array<string, array<int, mixed>>
     */
    public static function queryConversionProvider() : iterable
63
    {
Sergei Morozov's avatar
Sergei Morozov committed
64
        return [
65
            'positional' => [
66
                'SELECT ? COL1 FROM DUAL',
Sergei Morozov's avatar
Sergei Morozov committed
67 68 69
                [1],
                ['COL1' => 1],
            ],
70 71 72 73 74
            'named' => [
                'SELECT :COL COL1 FROM DUAL',
                [':COL' => 1],
                ['COL1' => 1],
            ],
Sergei Morozov's avatar
Sergei Morozov committed
75
            'literal-with-placeholder' => [
76
                "SELECT '?' COL1, ? COL2 FROM DUAL",
Sergei Morozov's avatar
Sergei Morozov committed
77 78
                [2],
                [
79 80
                    'COL1' => '?',
                    'COL2' => 2,
Sergei Morozov's avatar
Sergei Morozov committed
81 82 83
                ],
            ],
            'literal-with-quotes' => [
84
                "SELECT ? COL1, '?\"?''?' \"COL?\" FROM DUAL",
Sergei Morozov's avatar
Sergei Morozov committed
85 86
                [3],
                [
87 88
                    'COL1' => 3,
                    'COL?' => '?"?\'?',
Sergei Morozov's avatar
Sergei Morozov committed
89 90 91
                ],
            ],
            'placeholder-at-the-end' => [
92
                'SELECT ? COL1 FROM DUAL WHERE 1 = ?',
Sergei Morozov's avatar
Sergei Morozov committed
93 94 95 96
                [4, 1],
                ['COL1' => 4],
            ],
            'multi-line-literal' => [
97 98
                "SELECT 'Hello,
World?!' COL1 FROM DUAL WHERE 1 = ?",
Sergei Morozov's avatar
Sergei Morozov committed
99 100
                [1],
                [
101 102
                    'COL1' => 'Hello,
World?!',
Sergei Morozov's avatar
Sergei Morozov committed
103 104 105
                ],
            ],
            'empty-literal' => [
106
                "SELECT '' COL1 FROM DUAL",
Sergei Morozov's avatar
Sergei Morozov committed
107 108 109 110
                [],
                ['COL1' => ''],
            ],
        ];
111 112
    }
}