Viewing file: PmaSeleniumTableCreateTest.php (4.28 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?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';
/** * PmaSeleniumTableCreateTest class * * @package PhpMyAdmin-test * @subpackage Selenium * @group selenium */ class PMA_SeleniumTableCreateTest extends PMA_SeleniumBase { /** * Creates a table * * @return void * * @group large */ public function testCreateTable() { $this->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' ) ); } }
|