Initial commit
This commit is contained in:
		
							
								
								
									
										344
									
								
								#pma/test/selenium/PmaSeleniumTableBrowseTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										344
									
								
								#pma/test/selenium/PmaSeleniumTableBrowseTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,344 @@ | ||||
| <?php | ||||
| /* vim: set expandtab sw=4 ts=4 sts=4: */ | ||||
| /** | ||||
|  * Selenium TestCase for table related tests | ||||
|  * | ||||
|  * @package    PhpMyAdmin-test | ||||
|  * @subpackage Selenium | ||||
|  */ | ||||
|  | ||||
| require_once 'TestBase.php'; | ||||
|  | ||||
| /** | ||||
|  * PmaSeleniumTableBrowseTest class | ||||
|  * | ||||
|  * @package    PhpMyAdmin-test | ||||
|  * @subpackage Selenium | ||||
|  * @group      selenium | ||||
|  */ | ||||
| class PMA_SeleniumTableBrowseTest extends PMA_SeleniumBase | ||||
| { | ||||
|     /** | ||||
|      * Setup the browser environment to run the selenium test case | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setUp() | ||||
|     { | ||||
|         parent::setUp(); | ||||
|         $this->dbQuery( | ||||
|             "CREATE TABLE `test_table` (" | ||||
|             . " `id` int(11) NOT NULL AUTO_INCREMENT," | ||||
|             . " `name` varchar(20) NOT NULL," | ||||
|             . " `datetimefield` datetime NOT NULL," | ||||
|             . " PRIMARY KEY (`id`)" | ||||
|             . ")" | ||||
|         ); | ||||
|         $this->dbQuery( | ||||
|             "INSERT INTO `test_table` (`id`, `name`, `datetimefield`) VALUES" | ||||
|             . " (1, 'abcd', '2011-01-20 02:00:02')," | ||||
|             . " (2, 'foo', '2010-01-20 02:00:02')," | ||||
|             . " (3, 'Abcd', '2012-01-20 02:00:02')" | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * setUp function that can use the selenium session (called before each test) | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setUpPage() | ||||
|     { | ||||
|         $this->login(); | ||||
|         $this->navigateTable('test_table'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test sorting of records in browse table | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testSortRecords() | ||||
|     { | ||||
|         /* TODO: needs to be fixed */ | ||||
|         $this->markTestIncomplete( | ||||
|             'Does not work with multi column sorting.' | ||||
|         ); | ||||
|         // case 1 | ||||
|         $this->byLinkText("name")->click(); | ||||
|         $this->waitForElementNotPresent("byId", "loading_parent"); | ||||
|         $this->sleep(); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "1", | ||||
|             $this->getCellByTableClass('table_results', 1, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "3", | ||||
|             $this->getCellByTableClass('table_results', 2, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2", | ||||
|             $this->getCellByTableClass('table_results', 3, 5) | ||||
|         ); | ||||
|  | ||||
|         // case 2 | ||||
|         $this->byLinkText("name")->click(); | ||||
|         $this->waitForElementNotPresent("byId", "loading_parent"); | ||||
|         $this->sleep(); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2", | ||||
|             $this->getCellByTableClass('table_results', 1, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "1", | ||||
|             $this->getCellByTableClass('table_results', 2, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "3", | ||||
|             $this->getCellByTableClass('table_results', 3, 5) | ||||
|         ); | ||||
|  | ||||
|         // case 2 | ||||
|         $this->byLinkText("datetimefield")->click(); | ||||
|         $this->waitForElementNotPresent("byId", "loading_parent"); | ||||
|         $this->sleep(); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "3", | ||||
|             $this->getCellByTableClass('table_results', 1, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "1", | ||||
|             $this->getCellByTableClass('table_results', 2, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2", | ||||
|             $this->getCellByTableClass('table_results', 3, 5) | ||||
|         ); | ||||
|  | ||||
|         // case 4 | ||||
|         $this->byLinkText("datetimefield")->click(); | ||||
|         $this->waitForElementNotPresent("byId", "loading_parent"); | ||||
|         $this->sleep(); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2", | ||||
|             $this->getCellByTableClass('table_results', 1, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "1", | ||||
|             $this->getCellByTableClass('table_results', 2, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "3", | ||||
|             $this->getCellByTableClass('table_results', 3, 5) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test Edit Record | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testChangeRecords() | ||||
|     { | ||||
|         $this->sleep(); | ||||
|         $this->byCssSelector( | ||||
|             "table.table_results tbody tr:nth-child(2) td:nth-child(2) a" | ||||
|         )->click(); | ||||
|         $this->sleep(); | ||||
|         /* TODO: this occasionally fails, so there is probably something wrong */ | ||||
|         $this->waitForElement("byId", "insertForm"); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2", | ||||
|             $this->byId("field_1_3")->value() | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "foo", | ||||
|             $this->byId("field_2_3")->value() | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2010-01-20 02:00:02", | ||||
|             $this->byId("field_3_3")->value() | ||||
|         ); | ||||
|  | ||||
|         $this->byId("field_2_3")->clear(); | ||||
|         $this->byId("field_2_3")->value("foobar"); | ||||
|         $this->byId("field_3_3")->clear(); | ||||
|         $this->byId("field_3_3")->value("2009-01-20 02:00:02"); | ||||
|  | ||||
|         $this->byId("buttonYes")->click(); | ||||
|  | ||||
|         $success = $this->waitForElement("byClassName", "success"); | ||||
|         $this->assertContains("1 row affected", $success->text()); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "foobar", | ||||
|             $this->getCellByTableClass('table_results', 2, 6) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2009-01-20 02:00:02", | ||||
|             $this->getCellByTableClass('table_results', 2, 7) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test edit record by double click | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testChangeRecordsByDoubleClick() | ||||
|     { | ||||
|         $element = $this->byCssSelector( | ||||
|             "table.table_results tbody tr:nth-child(1) td:nth-child(6)" | ||||
|         ); | ||||
|  | ||||
|         $this->moveto($element); | ||||
|         $this->doubleclick(); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             $this->byCssSelector("textarea.edit_box")->value(), | ||||
|             "abcd" | ||||
|         ); | ||||
|  | ||||
|         $this->byCssSelector("textarea.edit_box")->clear(); | ||||
|         $this->byCssSelector("textarea.edit_box")->value("abcde"); | ||||
|         $this->keys(PHPUnit_Extensions_Selenium2TestCase_Keys::RETURN_); | ||||
|  | ||||
|         $success = $this->waitForElement( | ||||
|             "byCssSelector", "span.ajax_notification div.success" | ||||
|         ); | ||||
|         $this->assertContains("1 row affected", $success->text()); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "abcde", | ||||
|             $this->getCellByTableClass('table_results', 1, 6) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test copy and insert record | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testCopyRecords() | ||||
|     { | ||||
|         $this->byCssSelector( | ||||
|             "table.table_results tbody tr:nth-child(3) td:nth-child(3) a" | ||||
|         )->click(); | ||||
|  | ||||
|         /* TODO: this occasionally fails, so there is probably something wrong */ | ||||
|         $this->waitForElement("byId", "insertForm"); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "Abcd", | ||||
|             $this->byId("field_2_3")->value() | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2012-01-20 02:00:02", | ||||
|             $this->byId("field_3_3")->value() | ||||
|         ); | ||||
|  | ||||
|         $this->byId("field_2_3")->clear(); | ||||
|         $this->byId("field_2_3")->value("ABCDEFG"); | ||||
|         $this->byId("field_3_3")->clear(); | ||||
|         $this->byId("field_3_3")->value("2012-01-20 02:05:02"); | ||||
|  | ||||
|         $this->byId("buttonYes")->click(); | ||||
|         $success = $this->waitForElement("byClassName", "success"); | ||||
|         $this->assertContains("1 row inserted", $success->text()); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "ABCDEFG", | ||||
|             $this->getCellByTableClass('table_results', 4, 6) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "2012-01-20 02:05:02", | ||||
|             $this->getCellByTableClass('table_results', 4, 7) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test search table | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testSearchRecords() | ||||
|     { | ||||
|         $this->expandMore(); | ||||
|  | ||||
|         $this->byLinkText("Search")->click(); | ||||
|         $this->waitForElement("byId", "tbl_search_form"); | ||||
|  | ||||
|         $this->byId("fieldID_1")->value("abcd"); | ||||
|         $select = $this->select($this->byName("criteriaColumnOperators[1]")); | ||||
|         $select->selectOptionByLabel("LIKE %...%"); | ||||
|  | ||||
|         $this->byName("submit")->click(); | ||||
|         $success = $this->waitForElement("byClassName", "success"); | ||||
|         $this->assertContains("Showing rows", $success->text()); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "1", | ||||
|             $this->getCellByTableClass('table_results', 1, 5) | ||||
|         ); | ||||
|  | ||||
|         $this->assertEquals( | ||||
|             "3", | ||||
|             $this->getCellByTableClass('table_results', 2, 5) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test delete multiple records | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @group large | ||||
|      */ | ||||
|     public function testDeleteRecords() | ||||
|     { | ||||
|         $this->byId("id_rows_to_delete1_left")->click(); | ||||
|         $this->byId("id_rows_to_delete2_left")->click(); | ||||
|  | ||||
|         $this->byCssSelector("button[value=delete]")->click(); | ||||
|         $this->waitForElement("byCssSelector", "fieldset.confirmation"); | ||||
|  | ||||
|         $this->byId("buttonYes")->click(); | ||||
|         $success = $this->waitForElement("byClassName", "success"); | ||||
|         $this->assertContains("Showing rows", $success->text()); | ||||
|  | ||||
|         $this->assertFalse( | ||||
|             $this->isElementPresent( | ||||
|                 "byCssSelector", "table.table_results tbody tr:nth-child(2)" | ||||
|             ) | ||||
|         ); | ||||
|  | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user