dbQuery( "CREATE TABLE `test_table` (" . " `id` int(11) NOT NULL AUTO_INCREMENT," . " `val` int(11) NOT NULL," . " `val2` int(11) NOT NULL," . " PRIMARY KEY (`id`)" . ")" ); } /** * setUp function that can use the selenium session (called before each test) * * @return void */ public function setUpPage() { $this->login(); $this->waitForElement('byLinkText', $this->database_name)->click(); $this->navigateTable('test_table'); $this->waitForElement( "byXPath", "(//a[contains(., 'Structure')])" )->click(); $this->waitForElement("byId", "tablestructure"); } /** * Test for adding a new column * * @return void * * @group large */ public function testAddColumn() { $this->byCssSelector("label[for='field_where_after']")->click(); $this->byCssSelector("input[value='Go']")->click(); $this->waitForElement("byClassName", "append_fields_form"); $this->byId("field_0_1")->value('val3'); $this->byCssSelector("input[name='do_save_data']")->click(); $this->waitForElement( "byXPath", "//div[@class='success' and contains(., " . "'Table test_table has been altered successfully')]" ); $this->byLinkText("Structure")->click(); $this->waitForElement("byId", "tablestructure"); $this->assertEquals( "val3", $this->byCssSelector('label[for=checkbox_row_2]')->text() ); $this->assertEquals( "int(11)", $this->getCellByTableId('tablestructure', 2, 4) ); } /** * Test for changing a column * * @return void * * @group large */ public function testChangeColumn() { $this->byXPath("(//a[contains(., 'Change')])[2]")->click(); $this->waitForElement("byClassName", "append_fields_form"); $this->assertEquals("val", $this->byId("field_0_1")->value()); $this->byId("field_0_1")->clear(); $this->byId("field_0_1")->value('val3'); $this->byCssSelector("input[name='do_save_data']")->click(); $this->waitForElement( "byXPath", "//div[@class='success' and contains(., " . "'Table test_table has been altered successfully')]" ); $this->byLinkText("Structure")->click(); $this->waitForElement("byId", "tablestructure"); $this->assertEquals( "val3", $this->byCssSelector('label[for=checkbox_row_2]')->text() ); } /** * Test for dropping columns * * @return void * * @group large */ public function testDropColumns() { $this->byCssSelector('label[for=checkbox_row_2]')->click(); $this->byCssSelector('label[for=checkbox_row_3]')->click(); $this->byXPath( "//button[@class='mult_submit' and contains(., 'Drop')]" )->click(); $this->waitForElement( "byCssSelector", "input[id='buttonYes']" )->click(); $this->waitForElement( "byXPath", "//div[@class='success' and contains(., " . "'Your SQL query has been executed successfully')]" ); $this->assertFalse( $this->isElementPresent( 'byCssSelector', 'label[for=checkbox_row_2]' ) ); } }