Failed Conditions
Push — master ( 379085...b45ed5 )
by Marco
54s queued 28s
created

SQLSrvException::fromSqlSrvErrors()   A

Complexity

Conditions 5
Paths 10

Size

Total Lines 25
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 14
CRAP Score 5.675

Importance

Changes 0
Metric Value
eloc 14
dl 0
loc 25
ccs 14
cts 20
cp 0.7
rs 9.4888
c 0
b 0
f 0
cc 5
nc 10
nop 0
crap 5.675
1
<?php
2
3
namespace Doctrine\DBAL\Driver\SQLSrv;
4
5
use Doctrine\DBAL\Driver\AbstractDriverException;
6
use const SQLSRV_ERR_ERRORS;
7
use function rtrim;
8
use function sqlsrv_errors;
9
10
class SQLSrvException extends AbstractDriverException
11
{
12
    /**
13
     * Helper method to turn sql server errors into exception.
14
     *
15
     * @return \Doctrine\DBAL\Driver\SQLSrv\SQLSrvException
16
     */
17 103
    public static function fromSqlSrvErrors()
18
    {
19 103
        $errors    = sqlsrv_errors(SQLSRV_ERR_ERRORS);
20 103
        $message   = '';
21 103
        $sqlState  = null;
22 103
        $errorCode = null;
23
24 103
        foreach ($errors as $error) {
25 103
            $message .= 'SQLSTATE [' . $error['SQLSTATE'] . ', ' . $error['code'] . ']: ' . $error['message'] . "\n";
26
27 103
            if ($sqlState === null) {
28 103
                $sqlState = $error['SQLSTATE'];
29
            }
30
31 103
            if ($errorCode !== null) {
32 1
                continue;
33
            }
34
35 103
            $errorCode = $error['code'];
36
        }
37 103
        if (! $message) {
38
            $message = 'SQL Server error occurred but no error message was retrieved from driver.';
39
        }
40
41 103
        return new self(rtrim($message), $sqlState, $errorCode);
42
    }
43
}
44