summaryrefslogtreecommitdiffstats
path: root/tests/acceptance
diff options
context:
space:
mode:
authorDaniel Calviño Sánchez <danxuliu@gmail.com>2018-06-22 18:29:08 +0200
committerDaniel Calviño Sánchez <danxuliu@gmail.com>2018-06-22 19:46:44 +0200
commitd70b6bc94b9e24f04596a8e662ab3693db611f67 (patch)
treefd767459e09c91fb92e3abdd6833b6d5c36a9837 /tests/acceptance
parent082646f7e542a02c4a18a49b070a578069e209a6 (diff)
downloadnextcloud-server-d70b6bc94b9e24f04596a8e662ab3693db611f67.tar.gz
nextcloud-server-d70b6bc94b9e24f04596a8e662ab3693db611f67.zip
Set "wd_host" directly in "behat.yml" instead of through "BEHAT_PARAMS"
The "wd_host" parameter of Selenium2 sessions specify the URL used by the Selenium driver to connect with the Selenium server. Thus, when the Selenium server is at a different host or port than the default one (for example, when run on Drone) the "wd_host" parameter must be set for each of the Selenium2 sessions defined in "behat.yml". The "BEHAT_PARAMS" environment variable, which extends the "behat.yml" configuration file, was used for that. However, this required adding to the "BEHAT_PARAMS" in "run-local.sh" each new session added to "behat.yml", including those added in the acceptance tests of apps. To address that limitation, this commit introduces a simulated variable, "selenium.server"; just before the acceptance tests are run the "selenium.server" variable in the "wd_host" parameter is replaced in the "behat.yml" file used by the acceptance tests. Note that the file that is modified is the one inside the Docker container used to run the acceptance tests, so the original file is not touched. Note that a simulated variable is needed because Behat does not support overridding nor setting configuration parameters with environment variables. Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
Diffstat (limited to 'tests/acceptance')
-rw-r--r--tests/acceptance/config/behat.yml10
-rwxr-xr-xtests/acceptance/run-local.sh39
2 files changed, 20 insertions, 29 deletions
diff --git a/tests/acceptance/config/behat.yml b/tests/acceptance/config/behat.yml
index 55d2ff3a6f4..e1248e18a81 100644
--- a/tests/acceptance/config/behat.yml
+++ b/tests/acceptance/config/behat.yml
@@ -27,14 +27,18 @@ default:
Behat\MinkExtension:
sessions:
default:
- selenium2: ~
+ selenium2:
+ wd_host: %selenium.server%
John:
- selenium2: ~
+ selenium2:
+ wd_host: %selenium.server%
Jane:
- selenium2: ~
+ selenium2:
+ wd_host: %selenium.server%
Rubeus:
# Rubeus uses a browser that has CSS grid support.
selenium2:
+ wd_host: %selenium.server%
capabilities:
firefox:
profile: %paths.base%/firefox-profiles/css-grid-enabled.zip
diff --git a/tests/acceptance/run-local.sh b/tests/acceptance/run-local.sh
index eda119d74cc..916b3b67db6 100755
--- a/tests/acceptance/run-local.sh
+++ b/tests/acceptance/run-local.sh
@@ -172,32 +172,19 @@ FILE_CONTENTS=$(<$ACCEPTANCE_TESTS_CONFIG_DIR/behat.yml)
echo "${FILE_CONTENTS//$ORIGINAL/$REPLACEMENT}" > $ACCEPTANCE_TESTS_CONFIG_DIR/behat.yml
if [ "$SELENIUM_SERVER" != "$DEFAULT_SELENIUM_SERVER" ]; then
- # Set the Selenium server to be used by Mink; this extends the default
- # configuration from "config/behat.yml".
- export BEHAT_PARAMS='
-{
- "extensions": {
- "Behat\\MinkExtension": {
- "sessions": {
- "default": {
- "selenium2": {
- "wd_host": "http://'"$SELENIUM_SERVER"'/wd/hub"
- }
- },
- "John": {
- "selenium2": {
- "wd_host": "http://'"$SELENIUM_SERVER"'/wd/hub"
- }
- },
- "Jane": {
- "selenium2": {
- "wd_host": "http://'"$SELENIUM_SERVER"'/wd/hub"
- }
- }
- }
- }
- }
-}'
+ # Set the Selenium server to be used by Mink. Although Mink sessions can be
+ # extended through BEHAT_PARAMS this would require adding here too each new
+ # session added to "behat.yml", including those added in the acceptance
+ # tests of apps. Instead, the default "behat.yml" configuration file is
+ # adjusted to replace the simulated "selenium.server" variable by its value
+ # before the configuration file is parsed by Behat.
+ ORIGINAL="wd_host: %selenium.server%"
+ REPLACEMENT="wd_host: http://$SELENIUM_SERVER/wd/hub"
+ # As the substitution does not involve regular expressions or multilines it
+ # can be done just with Bash. Moreover, this does not require escaping the
+ # regular expression characters that may appear in the URL, like "/".
+ FILE_CONTENTS=$(<$ACCEPTANCE_TESTS_CONFIG_DIR/behat.yml)
+ echo "${FILE_CONTENTS//$ORIGINAL/$REPLACEMENT}" > $ACCEPTANCE_TESTS_CONFIG_DIR/behat.yml
fi
composer install