Test Failed
Pull Request — master (#126)
by Wilmer
05:01
created

CommandPDO   A

Complexity

Total Complexity 12

Size/Duplication

Total Lines 49
Duplicated Lines 0 %

Test Coverage

Coverage 76.19%

Importance

Changes 0
Metric Value
eloc 25
dl 0
loc 49
ccs 16
cts 21
cp 0.7619
rs 10
c 0
b 0
f 0
wmc 12

3 Methods

Rating   Name   Duplication   Size   Complexity  
B internalExecute() 0 25 9
A queryBuilder() 0 3 1
A insertEx() 0 12 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Mssql;
6
7
use PDOException;
8
use Yiisoft\Db\Driver\PDO\CommandPDO as AbstractCommandPDO;
9
use Yiisoft\Db\Exception\ConvertException;
10
use Yiisoft\Db\QueryBuilder\QueryBuilderInterface;
11
12
use function is_array;
13
14
final class CommandPDO extends AbstractCommandPDO
15
{
16
    /**
17
     * @inheritDoc
18
     */
19
    public function insertEx(string $table, array $columns): bool|array
20 6
    {
21
        $params = [];
22 6
        $sql = $this->queryBuilder()->insertEx($table, $columns, $params);
23 6
24
        $this->setSql($sql)->bindValues($params);
25 6
        $this->prepare(false);
26 6
27
        /** @psalm-var array|bool $result */
28
        $result = $this->queryOne();
29 6
30
        return is_array($result) ? $result : false;
31 6
    }
32
33
    public function queryBuilder(): QueryBuilderInterface
34 232
    {
35
        return $this->db->getQueryBuilder();
36 232
    }
37
38
    protected function internalExecute(string|null $rawSql): void
39
    {
40
        $attempt = 0;
41
42
        while (true) {
43
            try {
44 221
                if (
45
                    ++$attempt === 1
46 221
                    && $this->isolationLevel !== null
47
                    && $this->db->getTransaction() === null
48 221
                ) {
49
                    $this->db->transaction(
50
                        fn (string $rawSql) => $this->internalExecute($rawSql),
51
                        $this->isolationLevel
52 221
                    );
53 221
                } else {
54
                    $this->pdoStatement?->execute();
55
                }
56
                break;
57
            } catch (PDOException $e) {
58
                $rawSql = $rawSql ?: $this->getRawSql();
59
                $e = (new ConvertException($e, $rawSql))->run();
60 221
61
                if ($this->retryHandler === null || !($this->retryHandler)($e, $attempt)) {
62 220
                    throw $e;
63 6
                }
64 6
            }
65 6
        }
66
    }
67
}
68