2020-08-29 21:28:45 +00:00
|
|
|
<?php
|
|
|
|
/* Destructr | https://github.com/jobyone/destructr | MIT License */
|
|
|
|
declare (strict_types = 1);
|
|
|
|
namespace Destructr\Drivers;
|
|
|
|
|
|
|
|
use PDO;
|
|
|
|
use PHPUnit\DbUnit\TestCaseTrait;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class tests a Driver's ability to correctly change schemas.
|
|
|
|
*/
|
|
|
|
abstract class AbstractSQLDriverSchemaChangeTest extends TestCase
|
|
|
|
{
|
|
|
|
use TestCaseTrait;
|
|
|
|
const TEST_TABLE = 'schematest';
|
|
|
|
|
2022-05-27 16:44:41 +00:00
|
|
|
protected static function DRIVER_USERNAME()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function DRIVER_PASSWORD()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function DRIVER_OPTIONS()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2020-08-29 21:28:45 +00:00
|
|
|
public function testSchemaChanges()
|
|
|
|
{
|
|
|
|
// set up using schema A
|
|
|
|
$factory = $this->createFactoryA();
|
2020-08-30 02:59:27 +00:00
|
|
|
$this->assertFalse($factory->checkEnvironment());
|
2020-08-29 21:28:45 +00:00
|
|
|
$factory->prepareEnvironment();
|
2020-08-30 02:59:27 +00:00
|
|
|
$this->assertTrue($factory->checkEnvironment());
|
2020-08-29 21:28:45 +00:00
|
|
|
$factory->updateEnvironment();
|
|
|
|
// verify schema in database
|
|
|
|
$this->assertEquals(
|
|
|
|
$factory->schema,
|
|
|
|
$factory->driver()->getSchema('schematest')
|
|
|
|
);
|
|
|
|
// add some content
|
|
|
|
$new = $factory->create([
|
|
|
|
'dso.id' => 'dso1',
|
|
|
|
'test.a' => 'value a1',
|
|
|
|
'test.b' => 'value b1',
|
|
|
|
'test.c' => 'value c1',
|
|
|
|
]);
|
|
|
|
$new->insert();
|
|
|
|
$new = $factory->create([
|
|
|
|
'dso.id' => 'dso2',
|
|
|
|
'test.a' => 'value a2',
|
|
|
|
'test.b' => 'value b2',
|
|
|
|
'test.c' => 'value c2',
|
|
|
|
]);
|
|
|
|
$new->insert();
|
|
|
|
$new = $factory->create([
|
|
|
|
'dso.id' => 'dso3',
|
|
|
|
'test.a' => 'value a3',
|
|
|
|
'test.b' => 'value b3',
|
|
|
|
'test.c' => 'value c3',
|
|
|
|
]);
|
|
|
|
$new->insert();
|
|
|
|
// verify data in table matches
|
|
|
|
$pdo = $this->createPDO();
|
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('schematest'));
|
|
|
|
for ($i = 1; $i <= 3; $i++) {
|
|
|
|
$row = $pdo->query('select dso_id, test_a, test_b from schematest where dso_id = "dso' . $i . '"')->fetch(PDO::FETCH_ASSOC);
|
|
|
|
$this->assertEquals(['dso_id' => "dso$i", 'test_a' => "value a$i", 'test_b' => "value b$i"], $row);
|
|
|
|
}
|
|
|
|
// change to schema B
|
|
|
|
sleep(1); //a table can't have its schema updated faster than once per second
|
|
|
|
$factory = $this->createFactoryB();
|
2020-08-30 02:59:27 +00:00
|
|
|
$this->assertFalse($factory->checkEnvironment());
|
2020-08-29 21:28:45 +00:00
|
|
|
$factory->prepareEnvironment();
|
2020-08-30 02:59:27 +00:00
|
|
|
$this->assertFalse($factory->checkEnvironment());
|
2020-08-29 21:28:45 +00:00
|
|
|
$factory->updateEnvironment();
|
2020-08-30 02:59:27 +00:00
|
|
|
$this->assertTrue($factory->checkEnvironment());
|
2020-08-29 21:28:45 +00:00
|
|
|
// verify schema in database
|
|
|
|
$this->assertEquals(
|
|
|
|
$factory->schema,
|
|
|
|
$factory->driver()->getSchema('schematest')
|
|
|
|
);
|
|
|
|
// verify data in table matches
|
|
|
|
$pdo = $this->createPDO();
|
|
|
|
$this->assertEquals(3, $this->getConnection()->getRowCount('schematest'));
|
|
|
|
for ($i = 1; $i <= 3; $i++) {
|
|
|
|
$row = $pdo->query('select dso_id, test_a_2, test_c from schematest where dso_id = "dso' . $i . '"')->fetch(PDO::FETCH_ASSOC);
|
|
|
|
$this->assertEquals(['dso_id' => "dso$i", 'test_a_2' => "value a$i", 'test_c' => "value c$i"], $row);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function createFactoryA()
|
|
|
|
{
|
|
|
|
$driver = static::createDriver();
|
|
|
|
$factory = new FactorySchemaA(
|
|
|
|
$driver,
|
|
|
|
static::TEST_TABLE
|
|
|
|
);
|
|
|
|
return $factory;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function createFactoryB()
|
|
|
|
{
|
|
|
|
$driver = static::createDriver();
|
|
|
|
$factory = new FactorySchemaB(
|
|
|
|
$driver,
|
|
|
|
static::TEST_TABLE
|
|
|
|
);
|
|
|
|
return $factory;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function createDriver()
|
|
|
|
{
|
|
|
|
$class = static::DRIVER_CLASS;
|
|
|
|
return new $class(
|
2022-05-27 16:44:41 +00:00
|
|
|
static::DRIVER_DSN(),
|
|
|
|
static::DRIVER_USERNAME(),
|
|
|
|
static::DRIVER_PASSWORD(),
|
|
|
|
static::DRIVER_OPTIONS()
|
2020-08-29 21:28:45 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected static function createPDO()
|
|
|
|
{
|
|
|
|
return new \PDO(
|
2022-05-27 16:44:41 +00:00
|
|
|
static::DRIVER_DSN(),
|
|
|
|
static::DRIVER_USERNAME(),
|
|
|
|
static::DRIVER_PASSWORD(),
|
|
|
|
static::DRIVER_OPTIONS()
|
2020-08-29 21:28:45 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getConnection()
|
|
|
|
{
|
|
|
|
return $this->createDefaultDBConnection($this->createPDO(), 'phpunit');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getDataSet()
|
|
|
|
{
|
|
|
|
return new \PHPUnit\DbUnit\DataSet\DefaultDataSet();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function setUpBeforeClass()
|
|
|
|
{
|
|
|
|
$pdo = static::createPDO();
|
|
|
|
$pdo->exec('DROP TABLE schematest');
|
|
|
|
$pdo->exec('DROP TABLE destructr_schema');
|
|
|
|
}
|
|
|
|
}
|