summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2017-04-21 16:09:50 -0500
committerGitHub <noreply@github.com>2017-04-21 16:09:50 -0500
commit17c7b64f04510e9f37e105c579fb4314d4460fc5 (patch)
tree4b444018264c1b1210e355a230b38d3cf47a4992
parenteaa6f766e694f08e899c9469f668135c5d7b0c34 (diff)
parentdb7eedccc983ab07fe5963fc2363b4ca9912fd04 (diff)
downloadnextcloud-server-17c7b64f04510e9f37e105c579fb4314d4460fc5.tar.gz
nextcloud-server-17c7b64f04510e9f37e105c579fb4314d4460fc5.zip
Merge pull request #4431 from nextcloud/acceptance-macos
Run acceptance tests on macOS
-rwxr-xr-xtests/acceptance/run.sh34
1 files changed, 30 insertions, 4 deletions
diff --git a/tests/acceptance/run.sh b/tests/acceptance/run.sh
index f9711cbb404..3969782300d 100755
--- a/tests/acceptance/run.sh
+++ b/tests/acceptance/run.sh
@@ -48,6 +48,32 @@
# (probably you will not have containers nor images with those names, but just
# in case).
+# Switch between timeout on linux and gtimeout on macOS (same for mktemp and
+# gmktemp)
+
+case "$OSTYPE" in
+ darwin*)
+ INSTALLED=$(which gtimeout)
+ if [ "$INSTALLED" == "" ]; then
+ echo "Please install coreutils (brew install coreutils)"
+ exit 1;
+ fi
+
+ MKTEMP=gmktemp
+ TIMEOUT=gtimeout
+ DOCKEROPTION="-e no_proxy=localhost "
+ ;;
+ linux*)
+ MKTEMP=mktemp
+ TIMEOUT=timeout
+ DOCKEROPTION=" "
+ ;;
+ *)
+ echo "Operating system ($OSTYPE) not supported"
+ exit 1
+ ;;
+esac
+
# Launches the Selenium server in a Docker container.
#
# The acceptance tests use Firefox by default but, unfortunately, Firefox >= 48
@@ -79,12 +105,12 @@ function prepareSelenium() {
SELENIUM_CONTAINER=selenium-nextcloud-local-test-acceptance
echo "Starting Selenium server"
- docker run --detach --name=$SELENIUM_CONTAINER --publish 4444:4444 --publish 5900:5900 selenium/standalone-firefox-debug:2.53.1-beryllium
+ docker run --detach --name=$SELENIUM_CONTAINER --publish 4444:4444 --publish 5900:5900 $DOCKEROPTION selenium/standalone-firefox-debug:2.53.1-beryllium
echo "Waiting for Selenium server to be ready"
- if ! timeout 10s bash -c "while ! curl 127.0.0.1:4444 >/dev/null 2>&1; do sleep 1; done"; then
+ if ! $TIMEOUT 10s bash -c "while ! curl 127.0.0.1:4444 >/dev/null 2>&1; do sleep 1; done"; then
echo "Could not start Selenium server; running" \
- "\"docker run --rm --publish 4444:4444 --publish 5900:5900 selenium/standalone-firefox-debug:2.53.1-beryllium\"" \
+ "\"docker run --rm --publish 4444:4444 --publish 5900:5900 $DOCKEROPTION selenium/standalone-firefox-debug:2.53.1-beryllium\"" \
"could give you a hint of the problem"
exit 1
@@ -112,7 +138,7 @@ function prepareDocker() {
docker run --detach --name=$NEXTCLOUD_LOCAL_CONTAINER --network=container:$SELENIUM_CONTAINER --interactive --tty nextcloudci/php7.0:php7.0-7 bash
# Use the $TMPDIR or, if not set, fall back to /tmp.
- NEXTCLOUD_LOCAL_TAR="$(mktemp --tmpdir="${TMPDIR:-/tmp}" --suffix=.tar nextcloud-local-XXXXXXXXXX)"
+ NEXTCLOUD_LOCAL_TAR="$($MKTEMP --tmpdir="${TMPDIR:-/tmp}" --suffix=.tar nextcloud-local-XXXXXXXXXX)"
# Setting the user and group of files in the tar would be superfluous, as
# "docker cp" does not take them into account (the extracted files are set