From b645345b5276e6556ea5a08741db2c5ae9ee26d6 Mon Sep 17 00:00:00 2001 From: Lonnie Ezell Date: Sun, 5 May 2019 22:32:14 -0500 Subject: [PATCH] Additional test that indexes are dropped when a table is dropped. Closes #1983 --- tests/system/Database/Live/ForgeTest.php | 239 ++++++++++++----------- 1 file changed, 125 insertions(+), 114 deletions(-) diff --git a/tests/system/Database/Live/ForgeTest.php b/tests/system/Database/Live/ForgeTest.php index 96fb898a7bab..548f1ca303cb 100644 --- a/tests/system/Database/Live/ForgeTest.php +++ b/tests/system/Database/Live/ForgeTest.php @@ -81,21 +81,19 @@ public function testCreateTable() { $this->forge->dropTable('forge_test_table', true); - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - 'unsigned' => true, - 'auto_increment' => true, - ], - 'mobile' => [ - 'type' => 'INTEGER', - 'constraint' => 10, - 'unsigned' => true, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + 'unsigned' => true, + 'auto_increment' => true, + ], + 'mobile' => [ + 'type' => 'INTEGER', + 'constraint' => 10, + 'unsigned' => true, + ], + ]); $unsignedAttributes = [ 'INTEGER', @@ -141,15 +139,15 @@ public function testCreateTableWithArrayFieldConstraints() { $this->forge->dropTable('forge_array_constraint', true); $this->forge->addField([ - 'status' => [ - 'type' => 'ENUM', - 'constraint' => [ - 'sad', - 'ok', - 'happy', - ], - ], - ]); + 'status' => [ + 'type' => 'ENUM', + 'constraint' => [ + 'sad', + 'ok', + 'happy', + ], + ], + ]); $this->forge->createTable('forge_array_constraint'); $fields = $this->db->getFieldData('forge_array_constraint'); @@ -288,37 +286,33 @@ public function testForeignKey() $attributes = ['ENGINE' => 'InnoDB']; } - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->createTable('forge_test_users', true, $attributes); - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'users_id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'users_id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->addForeignKey('users_id', 'forge_test_users', 'id', 'CASCADE', 'CASCADE'); @@ -353,37 +347,33 @@ public function testForeignKeyFieldNotExistException() $attributes = ['ENGINE' => 'InnoDB']; } - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->createTable('forge_test_users', true, $attributes); - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'users_id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'users_id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->addForeignKey('user_id', 'forge_test_users', 'id', 'CASCADE', 'CASCADE'); @@ -404,32 +394,32 @@ public function testDropForeignKey() } $this->forge->addField([ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ]); + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->createTable('forge_test_users', true, $attributes); $this->forge->addField([ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'users_id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - ], - 'name' => [ - 'type' => 'VARCHAR', - 'constraint' => 255, - ], - ]); + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'users_id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + ], + 'name' => [ + 'type' => 'VARCHAR', + 'constraint' => 255, + ], + ]); $this->forge->addKey('id', true); $this->forge->addForeignKey('users_id', 'forge_test_users', 'id', 'CASCADE', 'CASCADE'); @@ -449,16 +439,14 @@ public function testAddColumn() { $this->forge->dropTable('forge_test_table', true); - $this->forge->addField( - [ - 'id' => [ - 'type' => 'INTEGER', - 'constraint' => 11, - 'unsigned' => false, - 'auto_increment' => true, - ], - ] - ); + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 11, + 'unsigned' => false, + 'auto_increment' => true, + ], + ]); $this->forge->addKey('id', true); $this->forge->createTable('forge_test_table'); @@ -474,8 +462,8 @@ public function testAddColumn() $this->forge->addColumn('forge_test_table', $newField); $fieldNames = $this->db->table('forge_test_table') - ->get() - ->getFieldNames(); + ->get() + ->getFieldNames(); $this->forge->dropTable('forge_test_table', true); @@ -715,4 +703,27 @@ public function testConnectWithArrayGroup() $this->assertInstanceOf(Forge::class, $forge); } + + /** + * @see https://github.com/codeigniter4/CodeIgniter4/issues/1983 + */ + public function testDropTableSuccess() + { + // Add an index to user table so we have + // something to work with + $this->forge->addField([ + 'id' => [ + 'type' => 'INTEGER', + 'constraint' => 3, + ], + ]); + $this->forge->addKey('id'); + $this->forge->createTable('droptest'); + + $this->assertCount(1, $this->db->getIndexData('droptest')); + + $this->forge->dropTable('droptest', true); + + $this->assertCount(0, $this->db->getIndexData('droptest')); + } }