login(); $this->waitForElement('byLinkText', $this->database_name)->click(); $this->waitForElement('byId', 'create_table_form_minimal'); $this->byCssSelector( "form#create_table_form_minimal input[name=table]" )->value("test_table"); $this->byName("num_fields")->value("4"); $this->byCssSelector('input[value=Go]')->click(); $this->waitForElement('byName', 'do_save_data'); // column details $column_text_details = array( "field_0_1" => "test_id", "field_0_3" => "14", "field_0_10" => "comm1", "field_1_1" => "test_column", "field_1_3" => "10", "field_1_10" => "comm2", ); foreach ($column_text_details as $field => $val) { $this->byId($field)->value($val); } $column_dropdown_details = array( "field_0_6" => "UNSIGNED", "field_0_8" => "PRIMARY", "field_1_2" => "VARCHAR", "field_1_5" => "utf8_general_ci", "field_1_4" => "As defined:" ); foreach ($column_dropdown_details as $selector => $value) { $sel = $this->select($this->byId($selector)); $sel->selectOptionByLabel($value); } $this->byName("field_default_value[1]")->value("def"); $this->byId("field_0_9")->click(); // auto increment $this->byId("field_1_7")->click(); // null // post $this->byName("do_save_data")->click(); $this->waitForElement("byLinkText", "test_table"); $this->_tableStructureAssertions(); } /** * Make assertions for table structure * * @return void */ private function _tableStructureAssertions() { // go to structure page $this->byLinkText("Structure")->click(); $this->waitForElement("byId", "tablestructure"); // make assertions for first row $this->assertContains( "test_id", $this->byCssSelector('label[for=checkbox_row_1]')->text() ); $this->assertEquals( "int(14)", $this->getCellByTableId('tablestructure', 1, 4) ); $this->assertEquals( "UNSIGNED", $this->getCellByTableId('tablestructure', 1, 6) ); $this->assertEquals( "No", $this->getCellByTableId('tablestructure', 1, 7) ); $this->assertEquals( "None", $this->getCellByTableId('tablestructure', 1, 8) ); $this->assertEquals( "AUTO_INCREMENT", $this->getCellByTableId('tablestructure', 1, 9) ); $this->assertFalse( $this->isElementPresent( 'byCssSelector', 'table#tablestructure tbody tr:nth-child(1) " . "ul.table-structure-actions li.primary a' ) ); // make assertions for second row $this->assertContains( "test_column", $this->byCssSelector('label[for=checkbox_row_2]')->text() ); $this->assertEquals( "varchar(10)", $this->getCellByTableId('tablestructure', 2, 4) ); $this->assertEquals( "utf8_general_ci", $this->getCellByTableId('tablestructure', 2, 5) ); $this->assertEquals( "Yes", $this->getCellByTableId('tablestructure', 2, 7) ); $this->assertEquals( "def", $this->getCellByTableId('tablestructure', 2, 8) ); $this->assertFalse( $this->isElementPresent( 'byCssSelector', 'css=ul.table-structure-actions:nth-child(2) li.primary a' ) ); } }