129 lines
3.2 KiB
PHP
129 lines
3.2 KiB
PHP
<?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';
|
|
|
|
|
|
/**
|
|
* PmaSeleniumDbOperationsTest class
|
|
*
|
|
* @package PhpMyAdmin-test
|
|
* @subpackage Selenium
|
|
* @group selenium
|
|
*/
|
|
class PMA_SeleniumDbOperationsTest extends PMA_SeleniumBase
|
|
{
|
|
/**
|
|
* 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->waitForElement("byLinkText", "Structure");
|
|
$this->expandMore();
|
|
$this->waitForElement("byLinkText", "Operations")->click();
|
|
$this->waitForElement(
|
|
"byXPath", "//legend[contains(., 'Rename database to')]"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for adding database comment
|
|
*
|
|
* @return void
|
|
*
|
|
* @group large
|
|
*/
|
|
public function testDbComment()
|
|
{
|
|
$this->skipIfNotPMADB();
|
|
$this->byName("comment")->value("comment_foobar");
|
|
$this->byCssSelector(
|
|
"form#formDatabaseComment input[type='submit']"
|
|
)->click();
|
|
|
|
$this->assertNotNull(
|
|
$this->waitForElement(
|
|
"byXPath",
|
|
"//span[@id='span_table_comment' and contains(., 'comment_foobar')]"
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Test for renaming database
|
|
*
|
|
* @return void
|
|
*
|
|
* @group large
|
|
*/
|
|
public function testRenameDB()
|
|
{
|
|
$new_db_name = $this->database_name . 'rename';
|
|
$this->byCssSelector("form#rename_db_form input[name=newname]")
|
|
->value($new_db_name);
|
|
|
|
$this->byCssSelector("form#rename_db_form input[type='submit']")->click();
|
|
|
|
$this->waitForElement(
|
|
"byXPath", "//button[contains(., 'OK')]"
|
|
)->click();
|
|
|
|
$this->waitForElement(
|
|
"byXPath",
|
|
"//a[@class='item' and contains(., 'Database: $new_db_name')]"
|
|
);
|
|
|
|
$result = $this->dbQuery(
|
|
"SHOW DATABASES LIKE '$new_db_name';"
|
|
);
|
|
$this->assertEquals(1, $result->num_rows);
|
|
|
|
$result = $this->dbQuery(
|
|
"SHOW DATABASES LIKE '" . $this->database_name . "';"
|
|
);
|
|
$this->assertEquals(0, $result->num_rows);
|
|
|
|
$this->database_name = $new_db_name;
|
|
}
|
|
|
|
/**
|
|
* Test for copying database
|
|
*
|
|
* @return void
|
|
*
|
|
* @group large
|
|
*/
|
|
public function testCopyDb()
|
|
{
|
|
$new_db_name = $this->database_name . 'copy';
|
|
$this->byCssSelector("form#copy_db_form input[name=newname]")
|
|
->value($new_db_name);
|
|
|
|
$this->byCssSelector("form#copy_db_form input[type='submit']")->click();
|
|
|
|
$this->waitForElement(
|
|
"byXPath",
|
|
"//div[@class='success' and contains(., 'Database "
|
|
. $this->database_name
|
|
. " has been copied to $new_db_name')]"
|
|
);
|
|
|
|
$result = $this->dbQuery(
|
|
"SHOW DATABASES LIKE '$new_db_name';"
|
|
);
|
|
$this->assertEquals(1, $result->num_rows);
|
|
|
|
$this->dbQuery("DROP DATABASE $new_db_name");
|
|
}
|
|
}
|