]> source.dussan.org Git - nextcloud-server.git/commitdiff
Fix webdav test env scripts to also work on CI
authorVincent Petry <pvince81@owncloud.com>
Tue, 3 May 2016 10:19:16 +0000 (12:19 +0200)
committerVincent Petry <pvince81@owncloud.com>
Mon, 30 May 2016 14:10:30 +0000 (16:10 +0200)
apps/files_external/tests/env/start-webdav-apache.sh
apps/files_external/tests/env/stop-webdav-apache.sh

index 8201424319034293c86b3a20490a0c5f4575631c..48acb8572d6fe2c3fb359cef2fd41f0c098ae80a 100755 (executable)
@@ -13,6 +13,7 @@
 #
 # @author Morris Jobke
 # @copyright 2014 Morris Jobke <hey@morrisjobke.de>
+# @copyright 2016 Vincent Petry <pvince81@owncloud.com>
 #
 
 if ! command -v docker >/dev/null 2>&1; then
@@ -32,21 +33,36 @@ if [ -z "$thisFolder" ]; then
     thisFolder="."
 fi;
 
-container=`docker run -d -e USERNAME=test -e PASSWORD=test -p 8888:80 morrisjobke/webdav`
+if [ -n "$RUN_DOCKER_MYSQL" ]; then
+    echo "Fetch recent mysql docker image"
+    docker pull mysql
 
-# TODO find a way to determine the successful initialization inside the docker container
-echo "Waiting 30 seconds for Webdav initialization ... "
-sleep 30
+    echo "Setup MySQL ..."
+    # user/password will be read by ENV variables in owncloud container (they are generated by docker)
+    databaseContainer=`docker run -e MYSQL_ROOT_PASSWORD=mysupersecretpassword -d mysql`
+    containerName=`docker inspect $databaseContainer | grep Name | grep _ | cut -d \" -f 4 | cut -d / -f 2`
 
-# get mapped port on host for internal port 80 - output is IP:PORT - we need to extract the port with 'cut'
-port=`docker port $container 80 | cut -f 2 -d :`
+    parameter="--link $containerName:db"
+fi
+
+container=`docker run -P $parameter -d -e USERNAME=test -e PASSWORD=test morrisjobke/webdav`
+host=`docker inspect --format="{{.NetworkSettings.IPAddress}}" $container`
+
+echo -n "Waiting for Apache initialization on ${host}:${port}"
+if ! "$thisFolder"/env/wait-for-connection ${host} 80 60; then
+    echo "[ERROR] Waited 60 seconds, no response" >&2
+    exit 1
+fi
+
+# wait at least 5 more seconds - sometimes the webserver still needs some additional time
+sleep 5
 
 cat > $thisFolder/config.webdav.php <<DELIM
 <?php
 
 return array(
     'run'=>true,
-    'host'=>'localhost:$port/webdav/',
+    'host'=>'${host}:80/webdav/',
     'user'=>'test',
     'password'=>'test',
     'root'=>'',
index 9ebf96030aa4695836e5b6d44527010d7d7fcc64..e898a65cc3619fa920997e89066f13b106617201 100755 (executable)
@@ -7,6 +7,7 @@
 #
 # @author Morris Jobke
 # @copyright 2014 Morris Jobke <hey@morrisjobke.de>
+# @copyright 2016 Vincent Petry <pvince81@owncloud.com>
 #
 
 if ! command -v docker >/dev/null 2>&1; then