server/tests/acceptance/features/bootstrap/SettingsContext.php
Daniel Calviño Sánchez b43a74bdcd Add acceptance tests for unselecting items in dropdown for tags
Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
2017-07-10 03:38:22 +02:00

152 lines
5.1 KiB
PHP

<?php
/**
*
* @copyright Copyright (c) 2017, Daniel Calviño Sánchez (danxuliu@gmail.com)
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
use Behat\Behat\Context\Context;
class SettingsContext implements Context, ActorAwareInterface {
use ActorAware;
/**
* @return Locator
*/
public static function systemTagsSelectTagButton() {
return Locator::forThe()->id("s2id_systemtag")->
describedAs("Select tag button in system tags section in Administration Settings");
}
/**
* @return Locator
*/
public static function systemTagsItemInDropdownForTag($tag) {
return Locator::forThe()->xpath("//*[contains(concat(' ', normalize-space(@class), ' '), ' select2-result-label ')]//span[normalize-space() = '$tag']/ancestor::li")->
descendantOf(self::select2Dropdown())->
describedAs("Item in dropdown for tag $tag in system tags section in Administration Settings");
}
/**
* @return Locator
*/
private static function select2Dropdown() {
return Locator::forThe()->css("#select2-drop")->
describedAs("Select2 dropdown in Settings");
}
/**
* @return Locator
*/
private static function select2DropdownMask() {
return Locator::forThe()->css("#select2-drop-mask")->
describedAs("Select2 dropdown mask in Settings");
}
/**
* @return Locator
*/
public static function systemTagsTagNameInput() {
return Locator::forThe()->id("systemtag_name")->
describedAs("Tag name input in system tags section in Administration Settings");
}
/**
* @return Locator
*/
public static function systemTagsCreateOrUpdateButton() {
return Locator::forThe()->id("systemtag_submit")->
describedAs("Create/Update button in system tags section in Administration Settings");
}
/**
* @return Locator
*/
public static function systemTagsResetButton() {
return Locator::forThe()->id("systemtag_reset")->
describedAs("Reset button in system tags section in Administration Settings");
}
/**
* @When I create the tag :tag in the settings
*/
public function iCreateTheTagInTheSettings($tag) {
$this->actor->find(self::systemTagsResetButton(), 10)->click();
$this->actor->find(self::systemTagsTagNameInput())->setValue($tag);
$this->actor->find(self::systemTagsCreateOrUpdateButton())->click();
}
/**
* @Then I see that the button to select tags is shown
*/
public function iSeeThatTheButtonToSelectTagsIsShown() {
PHPUnit_Framework_Assert::assertTrue($this->actor->find(self::systemTagsSelectTagButton(), 10)->isVisible());
}
/**
* @Then I see that the dropdown for tags in the settings eventually contains the tag :tag
*/
public function iSeeThatTheDropdownForTagsInTheSettingsEventuallyContainsTheTag($tag) {
// When the dropdown is opened it is not automatically updated if new
// tags are added to the server, and when a tag is created, no explicit
// feedback is provided to the user about the completion of that
// operation (that is, when the tag is added to the server). Therefore,
// to verify that creating a tag does in fact add it to the server it is
// necessary to repeatedly open the dropdown until the tag is shown in
// the dropdown (or the limit of tries is reached).
PHPUnit_Framework_Assert::assertTrue($this->actor->find(self::systemTagsSelectTagButton(), 10)->isVisible());
$actor = $this->actor;
$tagFoundInDropdownCallback = function() use($actor, $tag) {
// Open the dropdown to look for the tag.
$actor->find(self::systemTagsSelectTagButton())->click();
// When the dropdown is opened it is initially empty, and its
// contents are updated once received from the server. Therefore, a
// timeout must be used when looking for the tags.
try {
$tagFound = $this->actor->find(self::systemTagsItemInDropdownForTag($tag), 10)->isVisible();
} catch (NoSuchElementException $exception) {
$tagFound = false;
}
// Close again the dropdown after looking for the tag. When a
// dropdown is opened Select2 creates a special element that masks
// every other element but the dropdown to get all mouse clicks;
// this is used by Select2 to close the dropdown when the user
// clicks outside it.
$actor->find(self::select2DropdownMask())->click();
return $tagFound;
};
$numberOfTries = 5;
for ($i = 0; $i < $numberOfTries; $i++) {
if ($tagFoundInDropdownCallback()) {
return;
}
}
PHPUnit_Framework_Assert::fail("The dropdown in system tags section in Administration Settings does not contain the tag $tag after $numberOfTries tries");
}
}