|
4 | 4 |
|
5 | 5 | use Tests\TestCase; |
6 | 6 | use Mockery\MockInterface; |
| 7 | +use Illuminate\Support\Facades\DB; |
7 | 8 | use LaravelMigrationGenerator\Definitions\IndexDefinition; |
8 | 9 | use LaravelMigrationGenerator\Definitions\TableDefinition; |
9 | 10 | use LaravelMigrationGenerator\Definitions\ColumnDefinition; |
@@ -52,4 +53,33 @@ public function test_can_sort_tables() |
52 | 53 | $this->assertCount(4, $sorted); |
53 | 54 | $this->assertStringContainsString('$table->dropForeign', $sorted[3]->formatter()->stubTableDown()); |
54 | 55 | } |
| 56 | + |
| 57 | + public function test_can_remove_database_prefix() |
| 58 | + { |
| 59 | + $connection = DB::getDefaultConnection(); |
| 60 | + config()->set('database.connections.' . $connection . '.prefix', 'wp_'); |
| 61 | + |
| 62 | + $mocked = $this->partialMock(MySQLGeneratorManager::class, function (MockInterface $mock) { |
| 63 | + $mock->shouldReceive('init'); |
| 64 | + }); |
| 65 | + |
| 66 | + $definition = (new TableDefinition())->setTableName('wp_posts'); |
| 67 | + $mocked->addTableDefinition($definition); |
| 68 | + $this->assertEquals('posts', $definition->getTableName()); |
| 69 | + |
| 70 | + $definition = (new TableDefinition())->setTableName('posts'); |
| 71 | + $mocked->addTableDefinition($definition); |
| 72 | + $this->assertEquals('posts', $definition->getTableName()); |
| 73 | + |
| 74 | + |
| 75 | + config()->set('database.connections.' . $connection . '.prefix', ''); |
| 76 | + |
| 77 | + $definition = (new TableDefinition())->setTableName('wp_posts'); |
| 78 | + $mocked->addTableDefinition($definition); |
| 79 | + $this->assertEquals('wp_posts', $definition->getTableName()); |
| 80 | + |
| 81 | + $definition = (new TableDefinition())->setTableName('posts'); |
| 82 | + $mocked->addTableDefinition($definition); |
| 83 | + $this->assertEquals('posts', $definition->getTableName()); |
| 84 | + } |
55 | 85 | } |
0 commit comments