123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280 |
- <?php
- namespace Illuminate\Tests\Database;
- use Illuminate\Console\OutputStyle;
- use Illuminate\Container\Container;
- use Illuminate\Database\Capsule\Manager as DB;
- use Illuminate\Database\Migrations\DatabaseMigrationRepository;
- use Illuminate\Database\Migrations\Migrator;
- use Illuminate\Filesystem\Filesystem;
- use Illuminate\Support\Facades\Facade;
- use Illuminate\Support\Str;
- use Mockery as m;
- use PHPUnit\Framework\TestCase;
- class DatabaseMigratorIntegrationTest extends TestCase
- {
- protected $db;
- protected $migrator;
- /**
- * Bootstrap Eloquent.
- *
- * @return void
- */
- protected function setUp(): void
- {
- $this->db = $db = new DB;
- $db->addConnection([
- 'driver' => 'sqlite',
- 'database' => ':memory:',
- ]);
- $db->addConnection([
- 'driver' => 'sqlite',
- 'database' => ':memory:',
- ], 'sqlite2');
- $db->addConnection([
- 'driver' => 'sqlite',
- 'database' => ':memory:',
- ], 'sqlite3');
- $db->setAsGlobal();
- $container = new Container;
- $container->instance('db', $db->getDatabaseManager());
- Facade::setFacadeApplication($container);
- $this->migrator = new Migrator(
- $repository = new DatabaseMigrationRepository($db->getDatabaseManager(), 'migrations'),
- $db->getDatabaseManager(),
- new Filesystem
- );
- $output = m::mock(OutputStyle::class);
- $output->shouldReceive('writeln');
- $this->migrator->setOutput($output);
- if (! $repository->repositoryExists()) {
- $repository->createRepository();
- }
- $repository2 = new DatabaseMigrationRepository($db->getDatabaseManager(), 'migrations');
- $repository2->setSource('sqlite2');
- if (! $repository2->repositoryExists()) {
- $repository2->createRepository();
- }
- }
- protected function tearDown(): void
- {
- Facade::clearResolvedInstances();
- Facade::setFacadeApplication(null);
- }
- public function testBasicMigrationOfSingleFolder()
- {
- $ran = $this->migrator->run([__DIR__.'/migrations/one']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue(Str::contains($ran[0], 'users'));
- $this->assertTrue(Str::contains($ran[1], 'password_resets'));
- }
- public function testMigrationsDefaultConnectionCanBeChanged()
- {
- $ran = $this->migrator->usingConnection('sqlite2', function () {
- return $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqllite3']);
- });
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue($this->db->schema('sqlite2')->hasTable('users'));
- $this->assertTrue($this->db->schema('sqlite2')->hasTable('password_resets'));
- $this->assertFalse($this->db->schema('sqlite3')->hasTable('users'));
- $this->assertFalse($this->db->schema('sqlite3')->hasTable('password_resets'));
- $this->assertTrue(Str::contains($ran[0], 'users'));
- $this->assertTrue(Str::contains($ran[1], 'password_resets'));
- }
- public function testMigrationsCanEachDefineConnection()
- {
- $ran = $this->migrator->run([__DIR__.'/migrations/connection_configured']);
- $this->assertFalse($this->db->schema()->hasTable('failed_jobs'));
- $this->assertFalse($this->db->schema()->hasTable('jobs'));
- $this->assertFalse($this->db->schema('sqlite2')->hasTable('failed_jobs'));
- $this->assertFalse($this->db->schema('sqlite2')->hasTable('jobs'));
- $this->assertTrue($this->db->schema('sqlite3')->hasTable('failed_jobs'));
- $this->assertTrue($this->db->schema('sqlite3')->hasTable('jobs'));
- $this->assertTrue(Str::contains($ran[0], 'failed_jobs'));
- $this->assertTrue(Str::contains($ran[1], 'jobs'));
- }
- public function testMigratorCannotChangeDefinedMigrationConnection()
- {
- $ran = $this->migrator->usingConnection('sqlite2', function () {
- return $this->migrator->run([__DIR__.'/migrations/connection_configured']);
- });
- $this->assertFalse($this->db->schema()->hasTable('failed_jobs'));
- $this->assertFalse($this->db->schema()->hasTable('jobs'));
- $this->assertFalse($this->db->schema('sqlite2')->hasTable('failed_jobs'));
- $this->assertFalse($this->db->schema('sqlite2')->hasTable('jobs'));
- $this->assertTrue($this->db->schema('sqlite3')->hasTable('failed_jobs'));
- $this->assertTrue($this->db->schema('sqlite3')->hasTable('jobs'));
- $this->assertTrue(Str::contains($ran[0], 'failed_jobs'));
- $this->assertTrue(Str::contains($ran[1], 'jobs'));
- }
- public function testMigrationsCanBeRolledBack()
- {
- $this->migrator->run([__DIR__.'/migrations/one']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $rolledBack = $this->migrator->rollback([__DIR__.'/migrations/one']);
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue(Str::contains($rolledBack[0], 'password_resets'));
- $this->assertTrue(Str::contains($rolledBack[1], 'users'));
- }
- public function testMigrationsCanBeReset()
- {
- $this->migrator->run([__DIR__.'/migrations/one']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $rolledBack = $this->migrator->reset([__DIR__.'/migrations/one']);
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue(Str::contains($rolledBack[0], 'password_resets'));
- $this->assertTrue(Str::contains($rolledBack[1], 'users'));
- }
- public function testNoErrorIsThrownWhenNoOutstandingMigrationsExist()
- {
- $this->migrator->run([__DIR__.'/migrations/one']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->migrator->run([__DIR__.'/migrations/one']);
- }
- public function testNoErrorIsThrownWhenNothingToRollback()
- {
- $this->migrator->run([__DIR__.'/migrations/one']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->migrator->rollback([__DIR__.'/migrations/one']);
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->migrator->rollback([__DIR__.'/migrations/one']);
- }
- public function testMigrationsCanRunAcrossMultiplePaths()
- {
- $this->migrator->run([__DIR__.'/migrations/one', __DIR__.'/migrations/two']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue($this->db->schema()->hasTable('flights'));
- }
- public function testMigrationsCanBeRolledBackAcrossMultiplePaths()
- {
- $this->migrator->run([__DIR__.'/migrations/one', __DIR__.'/migrations/two']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue($this->db->schema()->hasTable('flights'));
- $this->migrator->rollback([__DIR__.'/migrations/one', __DIR__.'/migrations/two']);
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->assertFalse($this->db->schema()->hasTable('flights'));
- }
- public function testMigrationsCanBeResetAcrossMultiplePaths()
- {
- $this->migrator->run([__DIR__.'/migrations/one', __DIR__.'/migrations/two']);
- $this->assertTrue($this->db->schema()->hasTable('users'));
- $this->assertTrue($this->db->schema()->hasTable('password_resets'));
- $this->assertTrue($this->db->schema()->hasTable('flights'));
- $this->migrator->reset([__DIR__.'/migrations/one', __DIR__.'/migrations/two']);
- $this->assertFalse($this->db->schema()->hasTable('users'));
- $this->assertFalse($this->db->schema()->hasTable('password_resets'));
- $this->assertFalse($this->db->schema()->hasTable('flights'));
- }
- public function testMigrationsCanBeProperlySortedAcrossMultiplePaths()
- {
- $paths = [__DIR__.'/migrations/multi_path/vendor', __DIR__.'/migrations/multi_path/app'];
- $migrationsFilesFullPaths = array_values($this->migrator->getMigrationFiles($paths));
- $expected = [
- __DIR__.'/migrations/multi_path/app/2016_01_01_000000_create_users_table.php', // This file was not created on the "vendor" directory on purpose
- __DIR__.'/migrations/multi_path/vendor/2016_01_01_200000_create_flights_table.php', // This file was not created on the "app" directory on purpose
- __DIR__.'/migrations/multi_path/app/2019_08_08_000001_rename_table_one.php',
- __DIR__.'/migrations/multi_path/app/2019_08_08_000002_rename_table_two.php',
- __DIR__.'/migrations/multi_path/app/2019_08_08_000003_rename_table_three.php',
- __DIR__.'/migrations/multi_path/app/2019_08_08_000004_rename_table_four.php',
- __DIR__.'/migrations/multi_path/app/2019_08_08_000005_create_table_one.php',
- __DIR__.'/migrations/multi_path/app/2019_08_08_000006_create_table_two.php',
- __DIR__.'/migrations/multi_path/vendor/2019_08_08_000007_create_table_three.php', // This file was not created on the "app" directory on purpose
- __DIR__.'/migrations/multi_path/app/2019_08_08_000008_create_table_four.php',
- ];
- $this->assertEquals($expected, $migrationsFilesFullPaths);
- }
- public function testConnectionPriorToMigrationIsNotChangedAfterMigration()
- {
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->assertSame('default', $this->migrator->getConnection());
- }
- public function testConnectionPriorToMigrationIsNotChangedAfterRollback()
- {
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->migrator->rollback([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->assertSame('default', $this->migrator->getConnection());
- }
- public function testConnectionPriorToMigrationIsNotChangedWhenNoOutstandingMigrationsExist()
- {
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->assertSame('default', $this->migrator->getConnection());
- }
- public function testConnectionPriorToMigrationIsNotChangedWhenNothingToRollback()
- {
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->migrator->rollback([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->migrator->rollback([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->assertSame('default', $this->migrator->getConnection());
- }
- public function testConnectionPriorToMigrationIsNotChangedAfterMigrateReset()
- {
- $this->migrator->setConnection('default');
- $this->migrator->run([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->migrator->reset([__DIR__.'/migrations/one'], ['database' => 'sqlite2']);
- $this->assertSame('default', $this->migrator->getConnection());
- }
- }
|