summaryrefslogtreecommitdiff
path: root/libs/picodb/tests/PostgresDatabaseTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'libs/picodb/tests/PostgresDatabaseTest.php')
-rw-r--r--libs/picodb/tests/PostgresDatabaseTest.php100
1 files changed, 100 insertions, 0 deletions
diff --git a/libs/picodb/tests/PostgresDatabaseTest.php b/libs/picodb/tests/PostgresDatabaseTest.php
new file mode 100644
index 00000000..d0d8a644
--- /dev/null
+++ b/libs/picodb/tests/PostgresDatabaseTest.php
@@ -0,0 +1,100 @@
+<?php
+
+require_once __DIR__.'/../../../vendor/autoload.php';
+
+use PicoDb\Database;
+
+class PostgresDatabaseTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @var PicoDb\Database
+ */
+ private $db;
+
+ public function setUp()
+ {
+ $this->db = new Database(array('driver' => 'postgres', 'hostname' => 'localhost', 'username' => 'postgres', 'password' => '', 'database' => 'picodb'));
+ $this->db->getConnection()->exec('DROP TABLE IF EXISTS foobar');
+ $this->db->getConnection()->exec('DROP TABLE IF EXISTS schema_version');
+ }
+
+ public function testEscapeIdentifer()
+ {
+ $this->assertEquals('"a"', $this->db->escapeIdentifier('a'));
+ $this->assertEquals('a.b', $this->db->escapeIdentifier('a.b'));
+ $this->assertEquals('"c"."a"', $this->db->escapeIdentifier('a', 'c'));
+ $this->assertEquals('a.b', $this->db->escapeIdentifier('a.b', 'c'));
+ $this->assertEquals('SELECT COUNT(*) FROM test', $this->db->escapeIdentifier('SELECT COUNT(*) FROM test'));
+ $this->assertEquals('SELECT COUNT(*) FROM test', $this->db->escapeIdentifier('SELECT COUNT(*) FROM test', 'b'));
+ }
+
+ public function testEscapeIdentiferList()
+ {
+ $this->assertEquals(array('"c"."a"', '"c"."b"'), $this->db->escapeIdentifierList(array('a', 'b'), 'c'));
+ $this->assertEquals(array('"a"', 'd.b'), $this->db->escapeIdentifierList(array('a', 'd.b')));
+ }
+
+ public function testThatPreparedStatementWorks()
+ {
+ $this->db->getConnection()->exec('CREATE TABLE foobar (id serial PRIMARY KEY, something TEXT)');
+ $this->db->execute('INSERT INTO foobar (something) VALUES (?)', array('a'));
+ $this->assertEquals(1, $this->db->getLastId());
+ $this->assertEquals('a', $this->db->execute('SELECT something FROM foobar WHERE something=?', array('a'))->fetchColumn());
+ }
+
+ /**
+ * @expectedException PicoDb\SQLException
+ */
+ public function testBadSQLQuery()
+ {
+ $this->db->execute('INSERT INTO foobar');
+ }
+
+ public function testDuplicateKey()
+ {
+ $this->db->getConnection()->exec('CREATE TABLE foobar (something TEXT UNIQUE)');
+
+ $this->assertNotFalse($this->db->execute('INSERT INTO foobar (something) VALUES (?)', array('a')));
+ $this->assertFalse($this->db->execute('INSERT INTO foobar (something) VALUES (?)', array('a')));
+
+ $this->assertEquals(1, $this->db->execute('SELECT COUNT(*) FROM foobar WHERE something=?', array('a'))->fetchColumn());
+ }
+
+ public function testThatTransactionReturnsAValue()
+ {
+ $this->assertEquals('a', $this->db->transaction(function (Database $db) {
+ $db->getConnection()->exec('CREATE TABLE foobar (something TEXT UNIQUE)');
+ $db->execute('INSERT INTO foobar (something) VALUES (?)', array('a'));
+
+ return $db->execute('SELECT something FROM foobar WHERE something=?', array('a'))->fetchColumn();
+ }));
+ }
+
+ public function testThatTransactionReturnsTrue()
+ {
+ $this->assertTrue($this->db->transaction(function (Database $db) {
+ $db->getConnection()->exec('CREATE TABLE foobar (something TEXT UNIQUE)');
+ $db->execute('INSERT INTO foobar (something) VALUES (?)', array('a'));
+ }));
+ }
+
+ /**
+ * @expectedException PicoDb\SQLException
+ */
+ public function testThatTransactionThrowExceptionWhenRollbacked()
+ {
+ $this->assertFalse($this->db->transaction(function (Database $db) {
+ $db->getConnection()->exec('CREATE TABL');
+ }));
+ }
+
+ public function testThatTransactionReturnsFalseWhithDuplicateKey()
+ {
+ $this->assertFalse($this->db->transaction(function (Database $db) {
+ $db->getConnection()->exec('CREATE TABLE foobar (something TEXT UNIQUE)');
+ $r1 = $db->execute('INSERT INTO foobar (something) VALUES (?)', array('a'));
+ $r2 = $db->execute('INSERT INTO foobar (something) VALUES (?)', array('a'));
+ return $r1 && $r2;
+ }));
+ }
+}