MDL-47492 behat: refer to table column indexes instead of names

This commit is contained in:
Marina Glancy 2014-09-30 09:43:25 +08:00 committed by Adrian Greeve
parent 165cdabacb
commit 97329f1bc1

View File

@ -992,7 +992,7 @@ class behat_general extends behat_base {
* @Then /^"(?P<row_string>[^"]*)" row "(?P<column_string>[^"]*)" column of "(?P<table_string>[^"]*)" table should contain "(?P<value_string>[^"]*)"$/ * @Then /^"(?P<row_string>[^"]*)" row "(?P<column_string>[^"]*)" column of "(?P<table_string>[^"]*)" table should contain "(?P<value_string>[^"]*)"$/
* @throws ElementNotFoundException * @throws ElementNotFoundException
* @param string $row row text which will be looked in. * @param string $row row text which will be looked in.
* @param string $column column text to search * @param string $column column text to search (or numeric value for the column position)
* @param string $table table id/class/caption * @param string $table table id/class/caption
* @param string $value text to check. * @param string $value text to check.
*/ */
@ -1004,42 +1004,41 @@ class behat_general extends behat_base {
$valueliteral = $this->getSession()->getSelectorsHandler()->xpathLiteral($value); $valueliteral = $this->getSession()->getSelectorsHandler()->xpathLiteral($value);
$columnliteral = $this->getSession()->getSelectorsHandler()->xpathLiteral($column); $columnliteral = $this->getSession()->getSelectorsHandler()->xpathLiteral($column);
// Header can be in thead or tbody (first row), following xpath should work. if (preg_match('/^-?(\d+)-?$/', $column, $columnasnumber)) {
$theadheaderxpath = "thead/tr[1]/th[(normalize-space(.)=" . $columnliteral . " or a[normalize-space(text())=" . // Column indicated as a number, just use it as position of the column.
$columnliteral . "])]"; $columnpositionxpath = "/child::*[position() = {$columnasnumber[1]}]";
$tbodyheaderxpath = "tbody/tr[1]/td[(normalize-space(.)=" . $columnliteral . " or a[normalize-space(text())=" . } else {
$columnliteral . "])]"; // Header can be in thead or tbody (first row), following xpath should work.
$theadheaderxpath = "thead/tr[1]/th[(normalize-space(.)=" . $columnliteral . " or a[normalize-space(text())=" .
$columnliteral . "])]";
$tbodyheaderxpath = "tbody/tr[1]/td[(normalize-space(.)=" . $columnliteral . " or a[normalize-space(text())=" .
$columnliteral . "])]";
// Check if column exists. // Check if column exists.
$columnheaderxpath = $tablexpath . "[" . $theadheaderxpath . " | " . $tbodyheaderxpath . "]"; $columnheaderxpath = $tablexpath . "[" . $theadheaderxpath . " | " . $tbodyheaderxpath . "]";
$columnheader = $this->getSession()->getDriver()->find($columnheaderxpath); $columnheader = $this->getSession()->getDriver()->find($columnheaderxpath);
if (empty($columnheader)) { if (empty($columnheader)) {
$columnexceptionmsg = $column . '" in table "' . $table . '"'; $columnexceptionmsg = $column . '" in table "' . $table . '"';
throw new ElementNotFoundException($this->getSession(), 'Column', null, $columnexceptionmsg); throw new ElementNotFoundException($this->getSession(), "\n$columnheaderxpath\n\n".'Column', null, $columnexceptionmsg);
}
// Following conditions were considered before finding column count.
// 1. Table header can be in thead/tr/th or tbody/tr/td[1].
// 2. First column can have th (Gradebook -> user report), so having lenient sibling check.
$columnpositionxpath = "/child::*[position() = count(" . $tablexpath . "/" . $theadheaderxpath .
"/preceding-sibling::*) + 1]";
} }
// Check if value exists in specific row/column. // Check if value exists in specific row/column.
// Get row xpath. // Get row xpath.
$rowxpath = $tablexpath."/tbody/tr[th[normalize-space(.)=" . $rowliteral . "] | td[normalize-space(.)=" . $rowliteral . "]]"; $rowxpath = $tablexpath."/tbody/tr[th[normalize-space(.)=" . $rowliteral . "] | td[normalize-space(.)=" . $rowliteral . "]]";
// Following conditions were considered before finding column count.
// 1. Table header can be in thead/tr/th or tbody/tr/td[1].
// 2. First column can have th (Gradebook -> user report), so having lenient sibling check.
$columnpositionxpath = "/child::*[position() = count(" . $tablexpath . "/" . $theadheaderxpath .
"/preceding-sibling::*) + 1]";
$columnvaluexpath = $rowxpath . $columnpositionxpath . "[contains(normalize-space(.)," . $valueliteral . ")]"; $columnvaluexpath = $rowxpath . $columnpositionxpath . "[contains(normalize-space(.)," . $valueliteral . ")]";
// Looks for the requested node inside the container node. // Looks for the requested node inside the container node.
$coumnnode = $this->getSession()->getDriver()->find($columnvaluexpath); $coumnnode = $this->getSession()->getDriver()->find($columnvaluexpath);
if (empty($coumnnode)) { if (empty($coumnnode)) {
// Check if tbody/tr[1] contains header selector. $locatorexceptionmsg = $value . '" in "' . $row . '" row with column "' . $column;
$columnpositionxpath = "/child::*[position() = count(" . $tablexpath . "/" . $tbodyheaderxpath . throw new ElementNotFoundException($this->getSession(), "\n$columnvaluexpath\n\n".'Column value', null, $locatorexceptionmsg);
"/preceding-sibling::*) + 1]";
$columnvaluexpath = $rowxpath . $columnpositionxpath . "[contains(normalize-space(.)," . $valueliteral . ")]";
$coumnnode = $this->getSession()->getDriver()->find($columnvaluexpath);
if (empty($coumnnode)) {
$locatorexceptionmsg = $value . '" in "' . $row . '" row with column "' . $column;
throw new ElementNotFoundException($this->getSession(), 'Column value', null, $locatorexceptionmsg);
}
} }
} }
@ -1071,6 +1070,10 @@ class behat_general extends behat_base {
* Checks that the provided value exist in table. * Checks that the provided value exist in table.
* More info in http://docs.moodle.org/dev/Acceptance_testing#Providing_values_to_steps. * More info in http://docs.moodle.org/dev/Acceptance_testing#Providing_values_to_steps.
* *
* First row may contain column headers or numeric indexes of the columns
* (syntax -1- is also considered to be column index). Column indexes are
* useful in case of multirow headers and/or presence of cells with colspan.
*
* @Then /^the following should exist in the "(?P<table_string>[^"]*)" table:$/ * @Then /^the following should exist in the "(?P<table_string>[^"]*)" table:$/
* @throws ExpectationException * @throws ExpectationException
* @param string $table name of table * @param string $table name of table
@ -1081,10 +1084,14 @@ class behat_general extends behat_base {
public function following_should_exist_in_the_table($table, TableNode $data) { public function following_should_exist_in_the_table($table, TableNode $data) {
$datahash = $data->getHash(); $datahash = $data->getHash();
foreach ($datahash as $value) { foreach ($datahash as $row) {
$row = array_shift($value); $firstcell = null;
foreach ($value as $column => $value) { foreach ($row as $column => $value) {
$this->row_column_of_table_should_contain($row, $column, $table, $value); if ($firstcell === null) {
$firstcell = $value;
} else {
$this->row_column_of_table_should_contain($firstcell, $column, $table, $value);
}
} }
} }
} }