2018-08-17 17:32:10 +00:00
|
|
|
<?php
|
2020-08-26 15:52:25 +00:00
|
|
|
/* Destructr | https://github.com/jobyone/destructr | MIT License */
|
|
|
|
declare (strict_types = 1);
|
2018-09-14 18:17:54 +00:00
|
|
|
namespace Destructr\Drivers;
|
2018-08-17 17:32:10 +00:00
|
|
|
|
2018-08-17 22:32:26 +00:00
|
|
|
use Destructr\Factory;
|
2020-08-26 15:52:25 +00:00
|
|
|
use PHPUnit\DbUnit\TestCaseTrait;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
2018-08-17 17:32:10 +00:00
|
|
|
|
2020-08-29 21:28:45 +00:00
|
|
|
abstract class AbstractSQLDriverIntegrationTest extends TestCase
|
2018-08-17 17:32:10 +00:00
|
|
|
{
|
|
|
|
use TestCaseTrait;
|
2020-08-29 21:28:45 +00:00
|
|
|
const TEST_TABLE = 'integrationtest';
|
2018-08-17 17:32:10 +00:00
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2018-08-17 17:32:10 +00:00
|
|
|
public static function setUpBeforeClass()
|
|
|
|
{
|
|
|
|
$pdo = static::createPDO();
|
2020-08-26 15:52:25 +00:00
|
|
|
$pdo->exec('DROP TABLE ' . static::TEST_TABLE);
|
2018-08-17 17:32:10 +00:00
|
|
|
}
|
|
|
|
|
2020-08-29 21:28:45 +00:00
|
|
|
public function testPrepareEnvironment()
|
2018-08-17 17:32:10 +00:00
|
|
|
{
|
|
|
|
$factory = $this->createFactory();
|
2020-08-29 21:28:45 +00:00
|
|
|
$factory->prepareEnvironment();
|
2018-08-17 17:32:10 +00:00
|
|
|
//table should exist and have zero rows
|
|
|
|
$this->assertEquals(0, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInsert()
|
|
|
|
{
|
|
|
|
$startRowCount = $this->getConnection()->getRowCount(static::TEST_TABLE);
|
|
|
|
$factory = $this->createFactory();
|
|
|
|
//inserting a freshly created object should return true
|
2020-08-26 15:52:25 +00:00
|
|
|
$o = $factory->create(['dso.id' => 'object-one']);
|
2018-08-17 17:32:10 +00:00
|
|
|
$this->assertTrue($o->insert());
|
|
|
|
//inserting it a second time should not
|
|
|
|
$this->assertFalse($o->insert());
|
|
|
|
//there should now be one more row
|
2020-08-26 15:52:25 +00:00
|
|
|
$this->assertEquals($startRowCount + 1, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
2018-08-17 17:32:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testReadAndUpdate()
|
|
|
|
{
|
|
|
|
$startRowCount = $this->getConnection()->getRowCount(static::TEST_TABLE);
|
|
|
|
$factory = $this->createFactory();
|
|
|
|
//insert some new objects
|
2020-08-26 15:52:25 +00:00
|
|
|
$a1 = $factory->create(['foo' => 'bar']);
|
2018-08-17 17:32:10 +00:00
|
|
|
$a1->insert();
|
2020-08-26 15:52:25 +00:00
|
|
|
$b1 = $factory->create(['foo.bar' => 'baz']);
|
2018-08-17 17:32:10 +00:00
|
|
|
$b1->insert();
|
|
|
|
//read objects back out
|
|
|
|
$a2 = $factory->read($a1['dso.id']);
|
|
|
|
$b2 = $factory->read($b1['dso.id']);
|
|
|
|
//objects should be the same
|
|
|
|
$this->assertEquals($a1->get(), $a2->get());
|
|
|
|
$this->assertEquals($b1->get(), $b2->get());
|
|
|
|
//alter things in the objects and update them
|
|
|
|
$a2['foo'] = 'baz';
|
|
|
|
$b2['foo.bar'] = 'bar';
|
|
|
|
$a2->update();
|
|
|
|
$b2->update();
|
|
|
|
//read objects back out a third time
|
|
|
|
$a3 = $factory->read($a1['dso.id']);
|
|
|
|
$b3 = $factory->read($b1['dso.id']);
|
|
|
|
//objects should be the same
|
|
|
|
$this->assertEquals($a2->get(), $a3->get());
|
|
|
|
$this->assertEquals($b2->get(), $b3->get());
|
|
|
|
//they should not be the same as the originals from the beginning
|
|
|
|
$this->assertNotEquals($a1->get(), $a3->get());
|
|
|
|
$this->assertNotEquals($b1->get(), $b3->get());
|
|
|
|
//there should now be two more rows
|
2020-08-26 15:52:25 +00:00
|
|
|
$this->assertEquals($startRowCount + 2, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
2018-08-17 17:32:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testDelete()
|
|
|
|
{
|
|
|
|
$startRowCount = $this->getConnection()->getRowCount(static::TEST_TABLE);
|
|
|
|
$factory = $this->createFactory();
|
|
|
|
//insert some new objects
|
2020-08-26 15:52:25 +00:00
|
|
|
$a1 = $factory->create(['testDelete' => 'undelete me']);
|
2018-08-17 17:32:10 +00:00
|
|
|
$a1->insert();
|
2020-08-26 15:52:25 +00:00
|
|
|
$b1 = $factory->create(['testDelete' => 'should be permanently deleted']);
|
2018-08-17 17:32:10 +00:00
|
|
|
$b1->insert();
|
|
|
|
//there should now be two more rows
|
2020-08-26 15:52:25 +00:00
|
|
|
$this->assertEquals($startRowCount + 2, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
2018-08-17 17:32:10 +00:00
|
|
|
//delete one permanently and the other not, both shoudl take effect immediately
|
|
|
|
$a1->delete();
|
|
|
|
$b1->delete(true);
|
|
|
|
//there should now be only one more row
|
2020-08-26 15:52:25 +00:00
|
|
|
$this->assertEquals($startRowCount + 1, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
2018-08-17 17:32:10 +00:00
|
|
|
//a should be possible to read a back out with the right flags
|
|
|
|
$this->assertNull($factory->read($a1['dso.id']));
|
|
|
|
$this->assertNotNull($factory->read($a1['dso.id'], 'dso.id', true));
|
|
|
|
$this->assertNotNull($factory->read($a1['dso.id'], 'dso.id', null));
|
|
|
|
//undelete a, should have update() inside it
|
|
|
|
$a1->undelete();
|
|
|
|
//it should be possible to read a back out with different flags
|
|
|
|
$this->assertNotNull($factory->read($a1['dso.id']));
|
|
|
|
$this->assertNull($factory->read($a1['dso.id'], 'dso.id', true));
|
|
|
|
$this->assertNotNull($factory->read($a1['dso.id'], 'dso.id', null));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSearch()
|
|
|
|
{
|
|
|
|
$startRowCount = $this->getConnection()->getRowCount(static::TEST_TABLE);
|
|
|
|
$factory = $this->createFactory();
|
|
|
|
//insert some dummy data
|
|
|
|
$factory->create([
|
|
|
|
'testSearch' => 'a',
|
|
|
|
'a' => '1',
|
2020-08-26 15:52:25 +00:00
|
|
|
'b' => '2',
|
2018-08-17 17:32:10 +00:00
|
|
|
])->insert();
|
|
|
|
$factory->create([
|
|
|
|
'testSearch' => 'b',
|
|
|
|
'a' => '2',
|
2020-08-26 15:52:25 +00:00
|
|
|
'b' => '1',
|
2018-08-17 17:32:10 +00:00
|
|
|
])->insert();
|
|
|
|
$factory->create([
|
|
|
|
'testSearch' => 'c',
|
|
|
|
'a' => '3',
|
2020-08-26 15:52:25 +00:00
|
|
|
'b' => '4',
|
2018-08-17 17:32:10 +00:00
|
|
|
])->insert();
|
|
|
|
$factory->create([
|
|
|
|
'testSearch' => 'a',
|
|
|
|
'a' => '4',
|
2020-08-26 15:52:25 +00:00
|
|
|
'b' => '3',
|
2018-08-17 17:32:10 +00:00
|
|
|
])->insert();
|
|
|
|
//there should now be four more rows
|
2020-08-26 15:52:25 +00:00
|
|
|
$this->assertEquals($startRowCount + 4, $this->getConnection()->getRowCount(static::TEST_TABLE));
|
2018-08-17 17:32:10 +00:00
|
|
|
//TODO: test some searches
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a Driver from class constants, so extending classes can test
|
|
|
|
* different databases.
|
|
|
|
*/
|
|
|
|
public 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()
|
2018-08-17 17:32:10 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function createFactory()
|
|
|
|
{
|
|
|
|
$driver = $this->createDriver();
|
|
|
|
return new Factory(
|
|
|
|
$driver,
|
|
|
|
static::TEST_TABLE
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
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()
|
2018-08-17 17:32:10 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getConnection()
|
|
|
|
{
|
|
|
|
return $this->createDefaultDBConnection($this->createPDO(), 'phpunit');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getDataSet()
|
|
|
|
{
|
|
|
|
return new \PHPUnit\DbUnit\DataSet\DefaultDataSet();
|
|
|
|
}
|
|
|
|
}
|