Fix quoting in getRegionObj()

Based on work by @jeffreyguo.
See https://github.com/silverstripe-labs/silverstripe-behat-extension/pull/53/commits
This commit is contained in:
Ingo Schommer 2014-06-18 12:57:11 +12:00
parent 2dbd92b16b
commit 3fe596be63

View File

@ -131,22 +131,33 @@ class SilverStripeContext extends MinkContext implements SilverStripeAwareContex
/** /**
* Returns MinkElement based off region defined in .yml file. * Returns MinkElement based off region defined in .yml file.
* Also supports direct CSS selectors and regions identified by a "data-title" attribute. * Also supports direct CSS selectors and regions identified by a "data-title" attribute.
* * When using the "data-title" attribute, ensure not to include double quotes.
*
* @param String $region Region name or CSS selector * @param String $region Region name or CSS selector
* @return MinkElement|null * @return MinkElement|null
*/ */
public function getRegionObj($region) { public function getRegionObj($region) {
// Try to find regions directly by CSS selector // Try to find regions directly by CSS selector.
$regionObj = $this->getSession()->getPage()->find('css', $regionObj = $this->getSession()->getPage()->find(
$this->getSession()->getSelectorsHandler()->xpathLiteral($region)); 'css',
// Escape CSS selector
(false !== strpos($region, "'")) ? str_replace("'", "\'", $region) : $region
);
if($regionObj) { if($regionObj) {
return $regionObj; return $regionObj;
} }
// Fall back to region identified by data-tilte // Fall back to region identified by data-title.
$regionObj = $this->getSession()->getPage()->find('css', '[data-title="' . $region . '"]'); // Only apply if no double quotes exist in search string,
if($regionObj) { // which would break the CSS selector.
return $regionObj; if(false === strpos($region, '"')) {
$regionObj = $this->getSession()->getPage()->find(
'css',
'[data-title="' . $region . '"]'
);
if($regionObj) {
return $regionObj;
}
} }
// Look for named region // Look for named region