dbQuery( "CREATE TABLE `test_table` (" . " `id` int(11) NOT NULL AUTO_INCREMENT," . " `name` varchar(20) NOT NULL," . " `datetimefield` datetime 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->navigateTable('test_table'); } /** * Insert data into table * * @return void * * @group large */ public function testAddData() { if (mb_strtolower($this->getBrowser()) == 'safari') { /* TODO: this should be fixed, but the cause is unclear to me */ $this->markTestIncomplete('Fails with Safari'); } $this->expandMore(); $this->byLinkText("Insert")->click(); $this->waitForElement("byId", "insertForm"); $this->byId("field_1_3")->value("1"); $this->byId("field_2_3")->value("abcd"); $this->byId("field_3_3")->value("2011-01-20 02:00:02"); $this->byId("field_5_3")->value("foo"); $this->byId("field_6_3")->value("2010-01-20 02:00:02"); $select = $this->select($this->byName("after_insert")); $select->selectOptionByLabel("Insert another new row"); // post $this->byId("buttonYes")->click(); $ele = $this->waitForElement("byClassName", "success"); $this->assertContains("2 rows inserted", $ele->text()); $this->byId("field_2_3")->value("Abcd"); $this->byId("field_3_3")->value("2012-01-20 02:00:02"); // post $this->byCssSelector( "input[value=Go]" )->click(); $this->waitForElementNotPresent("byId", "loading_parent"); $ele = $this->waitForElement("byClassName", "success"); $this->assertContains("1 row inserted", $ele->text()); $this->_assertDataPresent(); } /** * Assert various data present in results table * * @return void */ private function _assertDataPresent() { $this->byLinkText("Browse")->click(); $this->waitForElement("byId", "table_results"); $this->assertEquals( "1", $this->getCellByTableClass('table_results', 1, 5) ); $this->assertEquals( "abcd", $this->getCellByTableClass('table_results', 1, 6) ); $this->assertEquals( "2011-01-20 02:00:02", $this->getCellByTableClass('table_results', 1, 7) ); $this->assertEquals( "2", $this->getCellByTableClass('table_results', 2, 5) ); $this->assertEquals( "foo", $this->getCellByTableClass('table_results', 2, 6) ); $this->assertEquals( "2010-01-20 02:00:02", $this->getCellByTableClass('table_results', 2, 7) ); $this->assertEquals( "4", $this->getCellByTableClass('table_results', 3, 5) ); $this->assertEquals( "Abcd", $this->getCellByTableClass('table_results', 3, 6) ); $this->assertEquals( "2012-01-20 02:00:02", $this->getCellByTableClass('table_results', 3, 7) ); } }