migrate->prepareEnvironment(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered */ public function tearDown(): void { $this->migrate->getDbCommand()->dropDatabase(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\DatabaseIsIncompleteException * @throws DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\InvalidMigrationFile * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testVersion0() { $this->migrate->reset(0); $this->assertVersion0(); } public function testIsDatabaseVersioned() { $this->assertFalse($this->migrate->isDatabaseVersioned()); $this->migrate->reset(); $this->assertTrue($this->migrate->isDatabaseVersioned()); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\DatabaseIsIncompleteException * @throws DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\InvalidMigrationFile * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testUpVersion1() { $this->migrate->reset(0); $this->assertVersion0(); $this->migrate->up(1); $this->assertVersion1(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\DatabaseIsIncompleteException * @throws DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\InvalidMigrationFile * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testUpVersion2() { $this->migrate->reset(0); $this->assertVersion0(); $this->migrate->up(2); $this->assertVersion2(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\DatabaseIsIncompleteException * @throws DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\InvalidMigrationFile * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testDownVersion1() { $this->migrate->reset(); $this->assertVersion2(); $this->migrate->down(1); $this->assertVersion1(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\DatabaseIsIncompleteException * @throws DatabaseNotVersionedException * @throws \ByJG\DbMigration\Exception\InvalidMigrationFile * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testDownVersion0() { $this->migrate->reset(); $this->assertVersion2(); $this->migrate->down(0); $this->assertVersion0(); } protected function getExpectedUsersVersion0() { return [ ["id" => 1, "name" => 'John Doe', 'createdate' => '20160110'], ["id" => 2, "name" => 'Jane Doe', 'createdate' => '20151230'] ]; } protected function getExpectedUsersVersion1() { return [ ["id" => 1, "name" => 'John Doe', 'createdate' => '2016-01-10'], ["id" => 2, "name" => 'Jane Doe', 'createdate' => '2015-12-30'] ]; } protected function getExpectedPostsVersion2() { return [ ["id" => 1, "userid" => 1, "title" => 'Testing', 'post' => "\\n

This is an example page. It's different from a blog post because it will stay in one place and will show up in your site navigation (in most themes). Most people start with an About page that introduces them to potential site visitors. It might say something like this:

\\n\\n\\n\\n

Hi there! I'm a bike messenger by day, aspiring actor by night, and this is my website. I live in Los Angeles, have a great dog named Jack, and I like piña coladas. (And gettin' caught in the rain.)

\\n\\n\\n\\n

...or something like this:

\\n\\n\\n\\n

The XYZ Doohickey Company was founded in 1971, and has been providing quality doohickeys to the public ever since. Located in Gotham City, XYZ employs over 2,000 people and does all kinds of awesome things for the Gotham community.

\\n\\n\\n\\n

As a new WordPress user, you should go to your dashboard to delete this page and create new pages for your content. Have fun!

\\n"], ]; } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ protected function assertVersion0() { $version = $this->migrate->getDbDriver()->getScalar('select version from '. $this->migrationTable); $this->assertEquals(0, $version); $status = $this->migrate->getDbDriver()->getScalar('select status from '. $this->migrationTable); $this->assertEquals(Migration::VERSION_STATUS_COMPLETE, $status); $iterator = $this->migrate->getDbDriver()->getIterator('select * from users'); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion0()[0], $row->toArray() ); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion0()[1], $row->toArray() ); $this->assertFalse($iterator->hasNext()); try { $this->migrate->getDbDriver()->getIterator('select * from roles'); } catch (PDOException $ex) { $this->assertTrue(true); } } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ protected function assertVersion1() { $version = $this->migrate->getDbDriver()->getScalar('select version from '. $this->migrationTable); $this->assertEquals(1, $version); $status = $this->migrate->getDbDriver()->getScalar('select status from '. $this->migrationTable); $this->assertEquals(Migration::VERSION_STATUS_COMPLETE, $status); $iterator = $this->migrate->getDbDriver()->getIterator('select * from users'); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion1()[0], $row->toArray() ); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion1()[1], $row->toArray() ); $this->assertFalse($iterator->hasNext()); try { $this->migrate->getDbDriver()->getIterator('select * from roles'); } catch (PDOException $ex) { $this->assertTrue(true); } } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ protected function assertVersion2() { $version = $this->migrate->getDbDriver()->getScalar('select version from '. $this->migrationTable); $this->assertEquals(2, $version); $status = $this->migrate->getDbDriver()->getScalar('select status from '. $this->migrationTable); $this->assertEquals(Migration::VERSION_STATUS_COMPLETE, $status); // Users $iterator = $this->migrate->getDbDriver()->getIterator('select * from users'); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion1()[0], $row->toArray() ); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedUsersVersion1()[1], $row->toArray() ); $this->assertFalse($iterator->hasNext()); // Posts $iterator = $this->migrate->getDbDriver()->getIterator('select * from posts'); $this->assertTrue($iterator->hasNext()); $row = $iterator->moveNext(); $this->assertEquals( $this->getExpectedPostsVersion2()[0], $row->toArray() ); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\DbMigration\Exception\OldVersionSchemaException */ public function testGetCurrentVersionIsEmpty() { $this->expectException(DatabaseNotVersionedException::class); $this->migrate->getCurrentVersion(); } /** * @throws \ByJG\DbMigration\Exception\DatabaseDoesNotRegistered * @throws \ByJG\Serializer\Exception\InvalidArgumentException */ public function testCreateVersion() { $this->migrate->createVersion(); $records = $this->migrate->getDbDriver()->getIterator("select * from " . $this->migrationTable)->toArray(); $this->assertEquals([ [ 'version' => '0', 'status' => Migration::VERSION_STATUS_UNKNOWN ] ], $records); // Check Bug (cannot create twice) $this->migrate->createVersion(); $records = $this->migrate->getDbDriver()->getIterator("select * from " . $this->migrationTable)->toArray(); $this->assertEquals([ [ 'version' => '0', 'status' => Migration::VERSION_STATUS_UNKNOWN ] ], $records); } } __halt_compiler();----SIGNATURE:----QvE1ZC5JtR1HUo8UyMYZGIQMrbZU4I5EQl3X8ReHBMj2RGIeoR25QztXhdIyfIyPJvGIZhwTZkqALH9woDF4QktlDAI85CZeDAxVk9MGNtXjPTFC5z9RKnT4FOZfX5KrkxY8y4lbGypWzn5k1YIRf/cGBEZmhxZx5r/2WMh/9fHP7qs3HBQ8kFb3bhz8z6iswcls2W5GtxDPpnyM3w+MSHxIkQKOb4ar4bJCCsVp23dHb9ifwH+DpF2gieqawi3MFuof3tQdo83UbiWF09na5V7yufyWTkDsw9h0iap2gdm/pkN0Jinr5HcvZ8lG01fLiovpdkLp3LpNt5Dy7Fc7E8+dswgjcRf+6gChzamEA6dYGjpEaDPmwdX/p0XgheW4pG1OBCbR9S3E5a2OBlitEqIvqdTisu4HvsO4khZo4qIirx+REUzS3BzNGFvzoYwkTp0Mi0nM3WoI0WwTmV1POgXPg/TWohVxXXBM8oFPDXoatp8Yy8CMEIU0+SWovvCdHld8+CJjGFSzm5Dl5Jld6JEuzxLPduLNNJZ63B0WfOw9BEhz+3IP3tsclAbYs/lhaAybgbMMUHKIcmvQmKuBI9e4KY5oXlylpe/cP1BCVWnxY8A1DhMsqZZmcBypHvdbPYo1zcD5EDtpEv3QcveEnhNqi7QtOJe+U1b1vKpxsy4=----ATTACHMENT:----MTExMDM5ODc5OTc1ODQxMCA5MTU1ODg4MTE2OTAzMTMwIDg2MzI3MzEwODk2NzkyNjg=