Initial commit
This commit is contained in:
160
#pma/test/selenium/PmaSeleniumTableStructureTest.php
Normal file
160
#pma/test/selenium/PmaSeleniumTableStructureTest.php
Normal file
@ -0,0 +1,160 @@
|
||||
<?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';
|
||||
|
||||
/**
|
||||
* PmaSeleniumTableStructureTest class
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
* @subpackage Selenium
|
||||
* @group selenium
|
||||
*/
|
||||
class PMA_SeleniumTableStructureTest 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,"
|
||||
. " `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]'
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user