aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Calviño Sánchez <danxuliu@gmail.com>2017-04-16 13:39:59 +0200
committerDaniel Calviño Sánchez <danxuliu@gmail.com>2017-04-19 08:26:57 +0200
commited7d63d16a3e954841c40253a8a54223f6ae729e (patch)
tree6beda4f9a73f7a4c4a5a02fc86b05e0f4c578a3b
parentbe96be09b599235c6b712d39f88760f10020508b (diff)
downloadnextcloud-server-ed7d63d16a3e954841c40253a8a54223f6ae729e.tar.gz
nextcloud-server-ed7d63d16a3e954841c40253a8a54223f6ae729e.zip
Add acceptance test steps to Drone
Each acceptance test feature is run in its own Drone step. The container of the step runs the acceptance tests themselves, but they require two additional Drone services. One service provides the Selenium server that performs the web browser actions specified by the tests, and the other service provides the Nextcloud server that the tests will be run against (due to security concerns the acceptance tests themselves can not create Docker containers for the Nextcloud server as done when running them in a local system, as if Drone containers had access to Docker a malicious pull request could be used to take over the Drone server). Signed-off-by: Daniel Calviño Sánchez <danxuliu@gmail.com>
-rw-r--r--.drone.yml40
-rwxr-xr-xbuild/acceptance/run-drone.sh75
2 files changed, 115 insertions, 0 deletions
diff --git a/.drone.yml b/.drone.yml
index 2d4134957ad..16f4be6a39a 100644
--- a/.drone.yml
+++ b/.drone.yml
@@ -478,6 +478,33 @@ pipeline:
when:
matrix:
TESTS: integration-trashbin
+ # As it needs access to the cloned Git repository it must be defined in the
+ # pipeline as "detached" instead of in the services.
+ service-acceptance-nextcloud-server:
+ image: nextcloudci/acceptance-nextcloud-server-php7.1-apache
+ detach: true
+ commands:
+ # "nextcloud-server-control-setup.sh" can not be set as the entry point in
+ # the image because Drone overrides it.
+ - /usr/local/bin/nextcloud-server-control-setup.sh
+ - su --shell "/bin/sh" --command "php /usr/local/bin/nextcloud-server-control.php 12345" - www-data
+ when:
+ matrix:
+ TESTS: acceptance
+ acceptance-access-levels:
+ image: nextcloudci/php7.0:php7.0-7
+ commands:
+ - build/acceptance/run-drone.sh features/access-levels.feature
+ when:
+ matrix:
+ TESTS-ACCEPTANCE: access-levels
+ acceptance-login:
+ image: nextcloudci/php7.0:php7.0-7
+ commands:
+ - build/acceptance/run-drone.sh features/login.feature
+ when:
+ matrix:
+ TESTS-ACCEPTANCE: login
nodb-codecov:
image: nextcloudci/php7.0:php7.0-7
commands:
@@ -551,6 +578,10 @@ matrix:
- TESTS: integration-transfer-ownership-features
- TESTS: integration-ldap-features
- TESTS: integration-trashbin
+ - TESTS: acceptance
+ TESTS-ACCEPTANCE: access-levels
+ - TESTS: acceptance
+ TESTS-ACCEPTANCE: login
- TESTS: jsunit
- TESTS: check-autoloader
- TESTS: check-mergejs
@@ -626,5 +657,14 @@ services:
when:
matrix:
OBJECT_STORE: s3
+ selenium:
+ image: selenium/standalone-firefox:2.53.1-beryllium
+ environment:
+ # Reduce default log level for Selenium server (INFO) as it is too
+ # verbose.
+ - JAVA_OPTS=-Dselenium.LOGGER.level=WARNING
+ when:
+ matrix:
+ TESTS: acceptance
branches: [ master, stable* ]
diff --git a/build/acceptance/run-drone.sh b/build/acceptance/run-drone.sh
new file mode 100755
index 00000000000..93e91c474c6
--- /dev/null
+++ b/build/acceptance/run-drone.sh
@@ -0,0 +1,75 @@
+#!/usr/bin/env bash
+
+# @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/>.
+
+# Helper script to run the acceptance tests, which test a running Nextcloud
+# instance from the point of view of a real user, in a Drone step.
+#
+# The acceptance tests are written in Behat so, besides running the tests, this
+# script installs Behat, its dependencies, and some related packages in the
+# "vendor" subdirectory of the acceptance tests. The acceptance tests also use
+# the Selenium server to control a web browser, and they require a Nextcloud
+# server to be available, so this script waits for the Selenium server and the
+# Nextcloud server (both provided in their own Drone service) to be ready before
+# running the tests.
+
+# Exit immediately on errors.
+set -o errexit
+
+# Ensure working directory is script directory, as some actions (like installing
+# Behat through Composer or running Behat) expect that.
+cd "$(dirname $0)"
+
+SCENARIO_TO_RUN=$1
+
+composer install
+
+# Although Behat documentation states that using the BEHAT_PARAMS environment
+# variable "You can set any value for any option that is available in a
+# behat.yml file" this is currently not true for the constructor parameters of
+# contexts (see https://github.com/Behat/Behat/issues/983). Thus, the default
+# "behat.yml" configuration file has to be adjusted to provide the appropriate
+# parameters for NextcloudTestServerContext.
+ORIGINAL="\
+ - NextcloudTestServerContext"
+REPLACEMENT="\
+ - NextcloudTestServerContext:\n\
+ nextcloudTestServerHelper: NextcloudTestServerDroneHelper\n\
+ nextcloudTestServerHelperParameters:\n\
+ - $NEXTCLOUD_SERVER_CONTROL_PORT"
+sed "s/$ORIGINAL/$REPLACEMENT/" config/behat.yml > config/behat-drone.yml
+
+# Both the Selenium server and the Nextcloud server control should be ready by
+# now, as Composer typically takes way longer to execute than their startup
+# (which is done in parallel in Drone services), but just in case.
+
+echo "Waiting for Selenium"
+timeout 60s bash -c "while ! curl 127.0.0.1:4444 >/dev/null 2>&1; do sleep 1; done"
+
+# This just checks if it can connect to the port in which the Nextcloud server
+# control should be listening on.
+NEXTCLOUD_SERVER_CONTROL_PORT="12345"
+PHP_CHECK_NEXTCLOUD_SERVER="\
+if ((\\\$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) { exit(1); } \
+if (socket_connect(\\\$socket, \\\"127.0.0.1\\\", \\\"$NEXTCLOUD_SERVER_CONTROL_PORT\\\") === false) { exit(1); } \
+socket_close(\\\$socket);"
+
+echo "Waiting for Nextcloud server control"
+timeout 60s bash -c "while ! php -r \"$PHP_CHECK_NEXTCLOUD_SERVER\" >/dev/null 2>&1; do sleep 1; done"
+
+vendor/bin/behat --config=config/behat-drone.yml $SCENARIO_TO_RUN