Skip to content

Commit

Permalink
DatabaseMysqlTest: use dual table
Browse files Browse the repository at this point in the history
  • Loading branch information
macbre committed Mar 24, 2021
1 parent 5c696b2 commit ce183c5
Showing 1 changed file with 10 additions and 25 deletions.
35 changes: 10 additions & 25 deletions tests/DatabaseMysqlTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

use Nano\NanoBaseTest;

/**
* Requires MySQL server running on 0.0.0.0:3306
*/
class DatabaseMysqlTest extends NanoBaseTest
{
/**
Expand All @@ -12,7 +15,7 @@ class DatabaseMysqlTest extends NanoBaseTest
protected function setUp(): void
{
parent::setUp();
$this->database = Database::connect($this->app, ['driver' => 'mysql', 'host' => '0.0.0.0', 'user' => 'root', 'pass' => '', 'database' => 'mysql']);
$this->database = Database::connect($this->app, ['driver' => 'mysql', 'host' => '0.0.0.0', 'user' => 'root', 'pass' => '']);
}

public function testLazyConnect()
Expand All @@ -29,43 +32,25 @@ public function testLazyConnect()
$this->assertTrue($this->database->isConnected(), 'We should be connected now');
}

// requires server running on localhost:3306
public function testMySqlDatabase()
{
// test performance data
$performanceData = $this->database->getPerformanceData();
$this->assertEquals(0, $performanceData['queries']);
$this->assertEquals(0, $performanceData['time']);

try {
$this->database->query('SELECT 1');
} catch (DatabaseException $e) {
$this->markTestSkipped('Requires server running on localhost:3306 - ' . $e->getMessage());
}

$res = $this->database->select('test', '*');
foreach ($res as $i => $row) {
#var_dump($row);
}
$res->free();

$res = $this->database->select('test', '*');
while ($row = $res->fetchRow()) {
#var_dump($row);
}
$res->free();

$row = $this->database->selectRow('test', '*', ['id' => 2]);
#var_dump($row);

$row = $this->database->selectField('test', 'count(*)');
#var_dump($row);

$res = $this->database->query('SELECT VERSION()');
#var_dump($res->fetchField());
// DUAL is purely for the convenience of people who require that all SELECT statements
// should have FROM and possibly other clauses. MySQL may ignore the clauses.
// MySQL does not require FROM DUAL if no tables are referenced.
$this->assertEquals('1', $this->database->selectField('dual', '1'));
$this->assertEquals(1, $this->database->select('dual', '1')->count());

$performanceData = $this->database->getPerformanceData();
$this->assertEquals(5, $performanceData['queries']);
$this->assertTrue($performanceData['time'] > 0);
$this->assertEquals(3, $performanceData['queries']);
}
}

0 comments on commit ce183c5

Please sign in to comment.