diff options
author | Daniel Calviño Sánchez <danxuliu@gmail.com> | 2017-04-16 13:39:59 +0200 |
---|---|---|
committer | Daniel Calviño Sánchez <danxuliu@gmail.com> | 2017-04-19 08:26:57 +0200 |
commit | ed7d63d16a3e954841c40253a8a54223f6ae729e (patch) | |
tree | 6beda4f9a73f7a4c4a5a02fc86b05e0f4c578a3b | |
parent | be96be09b599235c6b712d39f88760f10020508b (diff) | |
download | nextcloud-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.yml | 40 | ||||
-rwxr-xr-x | build/acceptance/run-drone.sh | 75 |
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 |