mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
3ee8f505b7
The main benefit of this is so that authors who make use of .editorconfig don't end up with whitespace changes in their PRs. Spaces vs. tabs has been left alone, although that could do with a tidy-up in SS4 after the switch to PSR-1/2. The command used was this: for match in '*.ss' '*.css' '*.scss' '*.html' '*.yml' '*.php' '*.js' '*.csv' '*.inc' '*.php5'; do find . -path ./thirdparty -not -prune -o -path ./admin/thirdparty -not -prune -o -type f -name "$match" -exec sed -E -i '' 's/[[:space:]]+$//' {} \+ find . -path ./thirdparty -not -prune -o -path ./admin/thirdparty -not -prune -o -type f -name "$match" | xargs perl -pi -e 's/ +$//' done
125 lines
2.9 KiB
PHP
125 lines
2.9 KiB
PHP
<?php
|
|
/**
|
|
* @package framework
|
|
* @subpackage testing
|
|
*/
|
|
|
|
class MySQLDatabaseTest extends SapphireTest {
|
|
|
|
protected static $fixture_file = 'MySQLDatabaseTest.yml';
|
|
|
|
protected $extraDataObjects = array(
|
|
'MySQLDatabaseTest_Data'
|
|
);
|
|
|
|
public function testPreparedStatements() {
|
|
if(!(DB::get_connector() instanceof MySQLiConnector)) {
|
|
$this->markTestSkipped('This test requires the current DB connector is MySQLi');
|
|
}
|
|
|
|
// Test preparation of equivalent statemetns
|
|
$result1 = DB::get_connector()->preparedQuery(
|
|
'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"',
|
|
array(0)
|
|
);
|
|
|
|
$result2 = DB::get_connector()->preparedQuery(
|
|
'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"',
|
|
array(2)
|
|
);
|
|
$this->assertInstanceOf('MySQLStatement', $result1);
|
|
$this->assertInstanceOf('MySQLStatement', $result2);
|
|
|
|
// Also select non-prepared statement
|
|
$result3 = DB::get_connector()->query('SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" ORDER BY "Sort"');
|
|
$this->assertInstanceOf('MySQLQuery', $result3);
|
|
|
|
// Iterating one level should not buffer, but return the right result
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 1,
|
|
'Title' => 'First Item'
|
|
),
|
|
$result1->next()
|
|
);
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 2,
|
|
'Title' => 'Second Item'
|
|
),
|
|
$result1->next()
|
|
);
|
|
|
|
// Test first
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 1,
|
|
'Title' => 'First Item'
|
|
),
|
|
$result1->first()
|
|
);
|
|
|
|
// Test seek
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 2,
|
|
'Title' => 'Second Item'
|
|
),
|
|
$result1->seek(1)
|
|
);
|
|
|
|
// Test count
|
|
$this->assertEquals(4, $result1->numRecords());
|
|
|
|
// Test second statement
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 3,
|
|
'Title' => 'Third Item'
|
|
),
|
|
$result2->next()
|
|
);
|
|
|
|
// Test non-prepared query
|
|
$this->assertEquals(
|
|
array(
|
|
'Sort' => 1,
|
|
'Title' => 'First Item'
|
|
),
|
|
$result3->next()
|
|
);
|
|
}
|
|
|
|
public function testAffectedRows() {
|
|
if(!(DB::get_connector() instanceof MySQLiConnector)) {
|
|
$this->markTestSkipped('This test requires the current DB connector is MySQLi');
|
|
}
|
|
|
|
$query = new SQLUpdate('MySQLDatabaseTest_Data');
|
|
$query->setAssignments(array('Title' => 'New Title'));
|
|
|
|
// Test update which affects no rows
|
|
$query->setWhere(array('Title' => 'Bob'));
|
|
$result = $query->execute();
|
|
$this->assertInstanceOf('MySQLQuery', $result);
|
|
$this->assertEquals(0, DB::affected_rows());
|
|
|
|
// Test update which affects some rows
|
|
$query->setWhere(array('Title' => 'First Item'));
|
|
$result = $query->execute();
|
|
$this->assertInstanceOf('MySQLQuery', $result);
|
|
$this->assertEquals(1, DB::affected_rows());
|
|
}
|
|
}
|
|
|
|
class MySQLDatabaseTest_Data extends DataObject implements TestOnly {
|
|
private static $db = array(
|
|
'Title' => 'Varchar',
|
|
'Description' => 'Text',
|
|
'Enabled' => 'Boolean',
|
|
'Sort' => 'Int'
|
|
);
|
|
|
|
private static $default_sort = '"Sort" ASC';
|
|
}
|