summaryrefslogtreecommitdiffstats
path: root/apps/files_external/tests
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-02-16 10:27:55 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2015-02-16 10:27:55 +0100
commitd001c4e375287bfcfc45d714def4ed835d886dbf (patch)
tree48b8ce8800ad20e0281ca93efd9b71dec98f62e8 /apps/files_external/tests
parentd5ca5c7bcc922f2677847d97813722073e6192bf (diff)
parentf7bbe081b3f7bdf7a87070425d34df6b9353a130 (diff)
downloadnextcloud-server-d001c4e375287bfcfc45d714def4ed835d886dbf.tar.gz
nextcloud-server-d001c4e375287bfcfc45d714def4ed835d886dbf.zip
Merge pull request #13922 from owncloud/smb-autotest-external
[files_external] add SMB autotest
Diffstat (limited to 'apps/files_external/tests')
-rw-r--r--apps/files_external/tests/backends/smb.php8
-rwxr-xr-xapps/files_external/tests/env/start-smb-silvershell.sh63
-rwxr-xr-xapps/files_external/tests/env/start-webdav-ownCloud.sh7
-rwxr-xr-xapps/files_external/tests/env/stop-smb-silvershell.sh36
-rwxr-xr-xapps/files_external/tests/env/stop-webdav-ownCloud.sh11
5 files changed, 112 insertions, 13 deletions
diff --git a/apps/files_external/tests/backends/smb.php b/apps/files_external/tests/backends/smb.php
index 9e5ab2b331f..4b2f4425ebc 100644
--- a/apps/files_external/tests/backends/smb.php
+++ b/apps/files_external/tests/backends/smb.php
@@ -16,12 +16,12 @@ class SMB extends Storage {
parent::setUp();
$id = $this->getUniqueID();
- $this->config = include('files_external/tests/config.php');
- if (!is_array($this->config) or !isset($this->config['smb']) or !$this->config['smb']['run']) {
+ $config = include('files_external/tests/config.smb.php');
+ if (!is_array($config) or !$config['run']) {
$this->markTestSkipped('Samba backend not configured');
}
- $this->config['smb']['root'] .= $id; //make sure we have an new empty folder to work in
- $this->instance = new \OC\Files\Storage\SMB($this->config['smb']);
+ $config['root'] .= $id; //make sure we have an new empty folder to work in
+ $this->instance = new \OC\Files\Storage\SMB($config);
$this->instance->mkdir('/');
}
diff --git a/apps/files_external/tests/env/start-smb-silvershell.sh b/apps/files_external/tests/env/start-smb-silvershell.sh
new file mode 100755
index 00000000000..f72ad3f9e23
--- /dev/null
+++ b/apps/files_external/tests/env/start-smb-silvershell.sh
@@ -0,0 +1,63 @@
+#!/bin/bash
+#
+# ownCloud
+#
+# This script start a docker container to test the files_external tests
+# against. It will also change the files_external config to use the docker
+# container as testing environment. This is reverted in the stop step.W
+#
+# Set environment variable DEBUG to print config file
+#
+# @author Morris Jobke
+# @copyright 2015 Morris Jobke <hey@morrisjobke.de>
+#
+
+if ! command -v docker >/dev/null 2>&1; then
+ echo "No docker executable found - skipped docker setup"
+ exit 0;
+fi
+
+echo "Docker executable found - setup docker"
+
+echo "Fetch recent silvershell/samba docker image"
+docker pull silvershell/samba
+
+# retrieve current folder to place the config in the parent folder
+thisFolder=`echo $0 | replace "env/start-smb-silvershell.sh" ""`
+
+if [ -z "$thisFolder" ]; then
+ thisFolder="."
+fi;
+
+container=`docker run -d -e SMB_USER=test -e SMB_PWD=test silvershell/samba`
+
+host=`docker inspect $container | grep IPAddress | cut -d '"' -f 4`
+
+cat > $thisFolder/config.smb.php <<DELIM
+<?php
+
+return array(
+ 'run'=>true,
+ 'host'=>'$host',
+ 'user'=>'test',
+ 'password'=>'test',
+ 'root'=>'',
+ 'share'=>'public',
+);
+
+DELIM
+
+echo "samba container: $container"
+
+# put container IDs into a file to drop them after the test run (keep in mind that multiple tests run in parallel on the same host)
+echo $container >> $thisFolder/dockerContainerSilvershell.$EXECUTOR_NUMBER.smb
+
+if [ -n "$DEBUG" ]; then
+ cat $thisFolder/config.smb.php
+ cat $thisFolder/dockerContainerSilvershell.$EXECUTOR_NUMBER.smb
+fi
+
+# TODO find a way to determine the successful initialization inside the docker container
+echo "Waiting 5 seconds for smbd initialization ... "
+sleep 5
+
diff --git a/apps/files_external/tests/env/start-webdav-ownCloud.sh b/apps/files_external/tests/env/start-webdav-ownCloud.sh
index c7267cff341..58b87e8f05d 100755
--- a/apps/files_external/tests/env/start-webdav-ownCloud.sh
+++ b/apps/files_external/tests/env/start-webdav-ownCloud.sh
@@ -28,6 +28,10 @@ docker pull morrisjobke/owncloud
# retrieve current folder to place the config in the parent folder
thisFolder=`echo $0 | replace "env/start-webdav-ownCloud.sh" ""`
+if [ -z "$thisFolder" ]; then
+ thisFolder="."
+fi;
+
if [ -n "$RUN_DOCKER_MYSQL" ]; then
echo "Fetch recent mysql docker image"
docker pull mysql
@@ -78,5 +82,6 @@ if [ -n "$databaseContainer" ]; then
fi
if [ -n "$DEBUG" ]; then
- echo $thisFolder/config.webdav.php
+ cat $thisFolder/config.webdav.php
+ cat $thisFolder/dockerContainerOwnCloud.$EXECUTOR_NUMBER.webdav
fi
diff --git a/apps/files_external/tests/env/stop-smb-silvershell.sh b/apps/files_external/tests/env/stop-smb-silvershell.sh
new file mode 100755
index 00000000000..6ae28d15506
--- /dev/null
+++ b/apps/files_external/tests/env/stop-smb-silvershell.sh
@@ -0,0 +1,36 @@
+#!/bin/bash
+#
+# ownCloud
+#
+# This script stops the docker container the files_external tests were run
+# against. It will also revert the config changes done in start step.
+#
+# @author Morris Jobke
+# @copyright 2015 Morris Jobke <hey@morrisjobke.de>
+#
+
+if ! command -v docker >/dev/null 2>&1; then
+ echo "No docker executable found - skipped docker stop"
+ exit 0;
+fi
+
+echo "Docker executable found - stop and remove docker containers"
+
+# retrieve current folder to remove the config from the parent folder
+thisFolder=`echo $0 | replace "env/stop-smb-silvershell.sh" ""`
+
+if [ -z "$thisFolder" ]; then
+ thisFolder="."
+fi;
+
+# stopping and removing docker containers
+for container in `cat $thisFolder/dockerContainerSilvershell.$EXECUTOR_NUMBER.smb`; do
+ echo "Stopping and removing docker container $container"
+ # kills running container and removes it
+ docker rm -f $container
+done;
+
+# cleanup
+rm $thisFolder/config.smb.php
+rm $thisFolder/dockerContainerSilvershell.$EXECUTOR_NUMBER.smb
+
diff --git a/apps/files_external/tests/env/stop-webdav-ownCloud.sh b/apps/files_external/tests/env/stop-webdav-ownCloud.sh
index 2f06eadcf7c..9d75c2bbd03 100755
--- a/apps/files_external/tests/env/stop-webdav-ownCloud.sh
+++ b/apps/files_external/tests/env/stop-webdav-ownCloud.sh
@@ -19,14 +19,9 @@ echo "Docker executable found - stop and remove docker containers"
# retrieve current folder to remove the config from the parent folder
thisFolder=`echo $0 | replace "env/stop-webdav-ownCloud.sh" ""`
-echo "DEBUG"
-
-netstat -tlpen
-
-echo "CONFIG:"
-
-cat $thisFolder/config.webdav.php
-cat $thisFolder/dockerContainerOwnCloud.$EXECUTOR_NUMBER.webdav
+if [ -z "$thisFolder" ]; then
+ thisFolder="."
+fi;
# stopping and removing docker containers
for container in `cat $thisFolder/dockerContainerOwnCloud.$EXECUTOR_NUMBER.webdav`; do