mirror of
https://github.com/silverstripe/silverstripe-postgresql
synced 2024-10-22 15:05:45 +00:00
50 lines
1.6 KiB
PHP
50 lines
1.6 KiB
PHP
|
<?php
|
||
|
|
||
|
/**
|
||
|
* Description of PostgreSQLConnectorTest
|
||
|
*
|
||
|
* @author Damian
|
||
|
*/
|
||
|
class PostgreSQLConnectorTest extends SapphireTest {
|
||
|
|
||
|
public function testSubstitutesPlaceholders() {
|
||
|
$connector = new PostgreSQLConnector();
|
||
|
|
||
|
// basic case
|
||
|
$this->assertEquals(
|
||
|
"SELECT * FROM Table WHERE ID = $1",
|
||
|
$connector->replacePlaceholders("SELECT * FROM Table WHERE ID = ?")
|
||
|
);
|
||
|
|
||
|
// Multiple variables
|
||
|
$this->assertEquals(
|
||
|
"SELECT * FROM Table WHERE ID = $1 AND Name = $2",
|
||
|
$connector->replacePlaceholders("SELECT * FROM Table WHERE ID = ? AND Name = ?")
|
||
|
);
|
||
|
|
||
|
// Ignoring question mark placeholders within string literals
|
||
|
$this->assertEquals(
|
||
|
"SELECT * FROM Table WHERE ID = $1 AND Name = $2 AND Content = '<p>What is love?</p>'",
|
||
|
$connector->replacePlaceholders(
|
||
|
"SELECT * FROM Table WHERE ID = ? AND Name = ? AND Content = '<p>What is love?</p>'"
|
||
|
)
|
||
|
);
|
||
|
|
||
|
// Ignoring question mark placeholders within string literals with escaped slashes
|
||
|
$this->assertEquals(
|
||
|
"SELECT * FROM Table WHERE ID = $1 AND Title = '\\'' AND Name = $2 AND Content = '<p>What is love?</p>'",
|
||
|
$connector->replacePlaceholders(
|
||
|
"SELECT * FROM Table WHERE ID = ? AND Title = '\\'' AND Name = ? AND Content = '<p>What is love?</p>'"
|
||
|
)
|
||
|
);
|
||
|
|
||
|
// same as above, but use double single quote escape syntax
|
||
|
$this->assertEquals(
|
||
|
"SELECT * FROM Table WHERE ID = $1 AND Title = '''' AND Name = $2 AND Content = '<p>What is love?</p>'",
|
||
|
$connector->replacePlaceholders(
|
||
|
"SELECT * FROM Table WHERE ID = ? AND Title = '''' AND Name = ? AND Content = '<p>What is love?</p>'"
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
}
|