BUG Fix PDOConnector issues

Travis support for PDO
ATTR_EMULATE_PREPARES = false breaks some test cases
Enable username sans password
Remove unnecessary semicolons delimiting queries
This commit is contained in:
Damian Mooyman 2014-08-01 17:56:21 +12:00
parent 7c4294b782
commit b0239f4330
4 changed files with 62 additions and 65 deletions

View File

@ -14,20 +14,20 @@ env:
matrix: matrix:
include: include:
- php: 5.3 - php: 5.4
env: DB=PGSQL CORE_RELEASE=master
- php: 5.3
env: DB=SQLITE CORE_RELEASE=master env: DB=SQLITE CORE_RELEASE=master
- php: 5.4
env: DB=PGSQL CORE_RELEASE=master
- php: 5.4 - php: 5.4
env: DB=MYSQL CORE_RELEASE=master env: DB=MYSQL CORE_RELEASE=master
- php: 5.4
env: DB=MYSQL CORE_RELEASE=master PDO=1
- php: 5.5 - php: 5.5
env: DB=MYSQL CORE_RELEASE=master env: DB=MYSQL CORE_RELEASE=master
- php: 5.6 - php: 5.6
env: DB=MYSQL CORE_RELEASE=master env: DB=MYSQL CORE_RELEASE=master
- php: 5.4 - php: 5.4
env: DB=MYSQL CORE_RELEASE=master BEHAT_TEST=1 env: DB=MYSQL CORE_RELEASE=master BEHAT_TEST=1
- php: 5.6
env: DB=MYSQL CORE_RELEASE=master
before_script: before_script:
- composer self-update - composer self-update

View File

@ -112,7 +112,6 @@ class MySQLDatabase extends SS_Database {
if (!class_exists('File')) if (!class_exists('File'))
throw new Exception('MySQLDatabase->searchEngine() requires "File" class'); throw new Exception('MySQLDatabase->searchEngine() requires "File" class');
$fileFilter = '';
$keywords = $this->escapeString($keywords); $keywords = $this->escapeString($keywords);
$htmlEntityKeywords = htmlentities($keywords, ENT_NOQUOTES, 'UTF-8'); $htmlEntityKeywords = htmlentities($keywords, ENT_NOQUOTES, 'UTF-8');
@ -233,30 +232,30 @@ class MySQLDatabase extends SS_Database {
public function transactionStart($transactionMode = false, $sessionCharacteristics = false) { public function transactionStart($transactionMode = false, $sessionCharacteristics = false) {
// This sets the isolation level for the NEXT transaction, not the current one. // This sets the isolation level for the NEXT transaction, not the current one.
if ($transactionMode) { if ($transactionMode) {
$this->query('SET TRANSACTION ' . $transactionMode . ';'); $this->query('SET TRANSACTION ' . $transactionMode);
} }
$this->query('START TRANSACTION;'); $this->query('START TRANSACTION');
if ($sessionCharacteristics) { if ($sessionCharacteristics) {
$this->query('SET SESSION TRANSACTION ' . $sessionCharacteristics . ';'); $this->query('SET SESSION TRANSACTION ' . $sessionCharacteristics);
} }
} }
public function transactionSavepoint($savepoint) { public function transactionSavepoint($savepoint) {
$this->query("SAVEPOINT $savepoint;"); $this->query("SAVEPOINT $savepoint");
} }
public function transactionRollback($savepoint = false) { public function transactionRollback($savepoint = false) {
if ($savepoint) { if ($savepoint) {
$this->query('ROLLBACK TO ' . $savepoint . ';'); $this->query('ROLLBACK TO ' . $savepoint);
} else { } else {
$this->query('ROLLBACK'); $this->query('ROLLBACK');
} }
} }
public function transactionEnd($chain = false) { public function transactionEnd($chain = false) {
$this->query('COMMIT AND ' . ($chain ? '' : 'NO ') . 'CHAIN;'); $this->query('COMMIT AND ' . ($chain ? '' : 'NO ') . 'CHAIN');
} }
public function comparisonClause($field, $value, $exact = false, $negate = false, $caseSensitive = null, public function comparisonClause($field, $value, $exact = false, $negate = false, $caseSensitive = null,

View File

@ -128,17 +128,19 @@ class PDOConnector extends DBConnector {
// Connection commands to be run on every re-connection // Connection commands to be run on every re-connection
$options = array( $options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8', PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
PDO::ATTR_EMULATE_PREPARES => self::is_emulate_prepare()
); );
if(self::is_emulate_prepare()) {
$options[PDO::ATTR_EMULATE_PREPARES] = true;
}
// May throw a PDOException if fails // May throw a PDOException if fails
if(empty($parameters['username']) || empty($parameters['password'])) { $this->pdoConnection = new PDO(
$this->pdoConnection = new PDO($driver.implode(';', $dsn)); $driver.implode(';', $dsn),
} else { empty($parameters['username']) ? '' : $parameters['username'],
$this->pdoConnection = new PDO($driver.implode(';', $dsn), $parameters['username'], empty($parameters['password']) ? '' : $parameters['password'],
$parameters['password'], $options); $options
} );
// Show selected DB if requested // Show selected DB if requested
if($this->pdoConnection && $selectDB && !empty($parameters['database'])) { if($this->pdoConnection && $selectDB && !empty($parameters['database'])) {

View File

@ -27,10 +27,6 @@ class PDOQuery extends SS_Query {
$statement->closeCursor(); $statement->closeCursor();
} }
public function __destruct() {
$this->statement->closeCursor();
}
public function seek($row) { public function seek($row) {
$this->rowNum = $row - 1; $this->rowNum = $row - 1;
return $this->nextRecord(); return $this->nextRecord();