mirror of
https://github.com/osm-search/Nominatim.git
synced 2024-11-22 21:28:10 +03:00
Merge pull request #1754 from mtmail/nominatim-db-tests-against-postgres
Nominatim::DB tests against separate postgresql database
This commit is contained in:
commit
65ee7a8002
57
lib/DB.php
57
lib/DB.php
@ -240,6 +240,28 @@ class DB
|
||||
return ($this->getOne($sSQL, array(':tablename' => $sTableName)) == 1);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a list of table names in the database
|
||||
*
|
||||
* @return array[]
|
||||
*/
|
||||
public function getListOfTables()
|
||||
{
|
||||
return $this->getCol("SELECT tablename FROM pg_tables WHERE schemaname='public'");
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes a table. Returns true if deleted or didn't exist.
|
||||
*
|
||||
* @param string $sTableName
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public function deleteTable($sTableName)
|
||||
{
|
||||
return $this->exec('DROP TABLE IF EXISTS '.$sTableName.' CASCADE') == 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if an index exists in the database. Optional filtered by tablename
|
||||
*
|
||||
@ -311,11 +333,11 @@ END;
|
||||
}
|
||||
|
||||
/**
|
||||
* Since the DSN includes the database name, checks if the connection works.
|
||||
* Tries to connect to the database but on failure doesn't throw an exception.
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public function databaseExists()
|
||||
public function checkConnection()
|
||||
{
|
||||
$bExists = true;
|
||||
try {
|
||||
@ -350,6 +372,13 @@ END;
|
||||
return (float) ($aMatches[1].'.'.$aMatches[2]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns an associate array of postgresql database connection settings. Keys can
|
||||
* be 'database', 'hostspec', 'port', 'username', 'password'.
|
||||
* Returns empty array on failure, thus check if at least 'database' is set.
|
||||
*
|
||||
* @return array[]
|
||||
*/
|
||||
public static function parseDSN($sDSN)
|
||||
{
|
||||
// https://secure.php.net/manual/en/ref.pdo-pgsql.connection.php
|
||||
@ -365,4 +394,28 @@ END;
|
||||
}
|
||||
return $aInfo;
|
||||
}
|
||||
|
||||
/**
|
||||
* Takes an array of settings and return the DNS string. Key names can be
|
||||
* 'database', 'hostspec', 'port', 'username', 'password' but aliases
|
||||
* 'dbname', 'host' and 'user' are also supported.
|
||||
*
|
||||
* @return string
|
||||
*
|
||||
*/
|
||||
public static function generateDSN($aInfo)
|
||||
{
|
||||
$sDSN = sprintf(
|
||||
'pgsql:host=%s;port=%s;dbname=%s;user=%s;password=%s;',
|
||||
$aInfo['host'] ?? $aInfo['hostspec'] ?? '',
|
||||
$aInfo['port'] ?? '',
|
||||
$aInfo['dbname'] ?? $aInfo['database'] ?? '',
|
||||
$aInfo['user'] ?? '',
|
||||
$aInfo['password'] ?? ''
|
||||
);
|
||||
$sDSN = preg_replace('/\b\w+=;/', '', $sDSN);
|
||||
$sDSN = preg_replace('/;\Z/', '', $sDSN);
|
||||
|
||||
return $sDSN;
|
||||
}
|
||||
}
|
||||
|
@ -85,7 +85,7 @@ class SetupFunctions
|
||||
info('Create DB');
|
||||
$oDB = new \Nominatim\DB;
|
||||
|
||||
if ($oDB->databaseExists()) {
|
||||
if ($oDB->checkConnection()) {
|
||||
fail('database already exists ('.CONST_Database_DSN.')');
|
||||
}
|
||||
|
||||
@ -675,7 +675,7 @@ class SetupFunctions
|
||||
);
|
||||
|
||||
$aDropTables = array();
|
||||
$aHaveTables = $this->oDB->getCol("SELECT tablename FROM pg_tables WHERE schemaname='public'");
|
||||
$aHaveTables = $this->oDB->getListOfTables();
|
||||
|
||||
foreach ($aHaveTables as $sTable) {
|
||||
$bFound = false;
|
||||
@ -870,7 +870,7 @@ class SetupFunctions
|
||||
private function dropTable($sName)
|
||||
{
|
||||
if ($this->bVerbose) echo "Dropping table $sName\n";
|
||||
$this->oDB->exec('DROP TABLE IF EXISTS '.$sName.' CASCADE');
|
||||
$this->oDB->deleteTable($sName);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -46,11 +46,13 @@ Very low coverage.
|
||||
To execute the test suite run
|
||||
|
||||
cd test/php
|
||||
phpunit ../
|
||||
UNIT_TEST_DSN='pgsql:dbname=nominatim_unit_tests' phpunit ../
|
||||
|
||||
It will read phpunit.xml which points to the library, test path, bootstrap
|
||||
strip and set other parameters.
|
||||
|
||||
It will use (and destroy) a local database 'nominatim_unit_tests'. You can set
|
||||
a different connection string with e.g. UNIT_TEST_DSN='pgsql:dbname=foo_unit_tests'.
|
||||
|
||||
BDD Functional Tests
|
||||
====================
|
||||
|
@ -24,10 +24,10 @@ class DBTest extends \PHPUnit\Framework\TestCase
|
||||
$this->assertTrue($oDB->connect());
|
||||
}
|
||||
|
||||
public function testDatabaseExists()
|
||||
public function testCheckConnection()
|
||||
{
|
||||
$oDB = new \Nominatim\DB('');
|
||||
$this->assertFalse($oDB->databaseExists());
|
||||
$this->assertFalse($oDB->checkConnection());
|
||||
}
|
||||
|
||||
public function testErrorHandling()
|
||||
@ -113,4 +113,134 @@ class DBTest extends \PHPUnit\Framework\TestCase
|
||||
\Nominatim\DB::parseDSN('pgsql:dbname=db1;host=machine1;port=1234;user=john;password=secret')
|
||||
);
|
||||
}
|
||||
|
||||
public function testGenerateDSN()
|
||||
{
|
||||
$this->assertEquals(
|
||||
'pgsql:',
|
||||
\Nominatim\DB::generateDSN(array())
|
||||
);
|
||||
$this->assertEquals(
|
||||
'pgsql:host=machine1;dbname=db1',
|
||||
\Nominatim\DB::generateDSN(\Nominatim\DB::parseDSN('pgsql:host=machine1;dbname=db1'))
|
||||
);
|
||||
}
|
||||
|
||||
public function testAgainstDatabase()
|
||||
{
|
||||
$unit_test_dsn = getenv('UNIT_TEST_DSN') != false ?
|
||||
getenv('UNIT_TEST_DSN') :
|
||||
'pgsql:dbname=nominatim_unit_tests';
|
||||
|
||||
$this->assertRegExp(
|
||||
'/unit_test/',
|
||||
$unit_test_dsn,
|
||||
'Test database will get destroyed, thus should have a name like unit_test to be safe'
|
||||
);
|
||||
|
||||
## Create the database.
|
||||
{
|
||||
$aDSNParsed = \Nominatim\DB::parseDSN($unit_test_dsn);
|
||||
$sDbname = $aDSNParsed['database'];
|
||||
$aDSNParsed['database'] = 'postgres';
|
||||
|
||||
$oDB = new \Nominatim\DB(\Nominatim\DB::generateDSN($aDSNParsed));
|
||||
$oDB->connect();
|
||||
$oDB->exec('DROP DATABASE IF EXISTS ' . $sDbname);
|
||||
$oDB->exec('CREATE DATABASE ' . $sDbname);
|
||||
}
|
||||
|
||||
$oDB = new \Nominatim\DB($unit_test_dsn);
|
||||
$oDB->connect();
|
||||
|
||||
$this->assertTrue(
|
||||
$oDB->checkConnection($sDbname)
|
||||
);
|
||||
|
||||
# Tables, Indices
|
||||
{
|
||||
$this->assertEmpty($oDB->getListOfTables());
|
||||
$oDB->exec('CREATE TABLE table1 (id integer, city varchar, country varchar)');
|
||||
$oDB->exec('CREATE TABLE table2 (id integer, city varchar, country varchar)');
|
||||
$this->assertEquals(
|
||||
array('table1', 'table2'),
|
||||
$oDB->getListOfTables()
|
||||
);
|
||||
$this->assertTrue($oDB->deleteTable('table2'));
|
||||
$this->assertTrue($oDB->deleteTable('table99'));
|
||||
$this->assertEquals(
|
||||
array('table1'),
|
||||
$oDB->getListOfTables()
|
||||
);
|
||||
|
||||
$this->assertTrue($oDB->tableExists('table1'));
|
||||
$this->assertFalse($oDB->tableExists('table99'));
|
||||
$this->assertFalse($oDB->tableExists(null));
|
||||
|
||||
$this->assertEmpty($oDB->getListOfIndices());
|
||||
$oDB->exec('CREATE UNIQUE INDEX table1_index ON table1 (id)');
|
||||
$this->assertEquals(
|
||||
array('table1_index'),
|
||||
$oDB->getListOfIndices()
|
||||
);
|
||||
$this->assertEmpty($oDB->getListOfIndices('table2'));
|
||||
}
|
||||
|
||||
# select queries
|
||||
{
|
||||
$oDB->exec(
|
||||
"INSERT INTO table1 VALUES (1, 'Berlin', 'Germany'), (2, 'Paris', 'France')"
|
||||
);
|
||||
|
||||
$this->assertEquals(
|
||||
array(
|
||||
array('city' => 'Berlin'),
|
||||
array('city' => 'Paris')
|
||||
),
|
||||
$oDB->getAll('SELECT city FROM table1')
|
||||
);
|
||||
$this->assertEquals(
|
||||
array(),
|
||||
$oDB->getAll('SELECT city FROM table1 WHERE id=999')
|
||||
);
|
||||
|
||||
|
||||
$this->assertEquals(
|
||||
array('id' => 1, 'city' => 'Berlin', 'country' => 'Germany'),
|
||||
$oDB->getRow('SELECT * FROM table1 WHERE id=1')
|
||||
);
|
||||
$this->assertEquals(
|
||||
false,
|
||||
$oDB->getRow('SELECT * FROM table1 WHERE id=999')
|
||||
);
|
||||
|
||||
|
||||
$this->assertEquals(
|
||||
array('Berlin', 'Paris'),
|
||||
$oDB->getCol('SELECT city FROM table1')
|
||||
);
|
||||
$this->assertEquals(
|
||||
array(),
|
||||
$oDB->getCol('SELECT city FROM table1 WHERE id=999')
|
||||
);
|
||||
|
||||
$this->assertEquals(
|
||||
'Berlin',
|
||||
$oDB->getOne('SELECT city FROM table1 WHERE id=1')
|
||||
);
|
||||
$this->assertEquals(
|
||||
null,
|
||||
$oDB->getOne('SELECT city FROM table1 WHERE id=999')
|
||||
);
|
||||
|
||||
$this->assertEquals(
|
||||
array('Berlin' => 'Germany', 'Paris' => 'France'),
|
||||
$oDB->getAssoc('SELECT city, country FROM table1')
|
||||
);
|
||||
$this->assertEquals(
|
||||
array(),
|
||||
$oDB->getAssoc('SELECT city, country FROM table1 WHERE id=999')
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -28,7 +28,7 @@ function isReverseOnlyInstallation()
|
||||
|
||||
|
||||
echo 'Checking database got created ... ';
|
||||
if ($oDB->databaseExists()) {
|
||||
if ($oDB->checkConnection()) {
|
||||
$print_success();
|
||||
} else {
|
||||
$print_fail();
|
||||
|
Loading…
Reference in New Issue
Block a user