summaryrefslogtreecommitdiffstats
path: root/controller/bin/dtf-run-remote.in
diff options
context:
space:
mode:
Diffstat (limited to 'controller/bin/dtf-run-remote.in')
-rw-r--r--controller/bin/dtf-run-remote.in111
1 files changed, 111 insertions, 0 deletions
diff --git a/controller/bin/dtf-run-remote.in b/controller/bin/dtf-run-remote.in
new file mode 100644
index 0000000..276ad40
--- /dev/null
+++ b/controller/bin/dtf-run-remote.in
@@ -0,0 +1,111 @@
+#!/bin/bash
+
+. "@sysconfdir@/dtf.sh" || exit 1
+
+longopts="verbose,help,force,testid:,listonly"
+
+run_playbook=${run_playbook-@ansibleplaybooksdir@/fedora.yml}
+
+opt_workdir=
+opt_distro=fedora
+opt_openstack_instance="$DTF_OPENSTACK_ID"
+opt_distro_ver=20
+opt_extra_rpms=
+opt_taskdir=
+
+die() { echo >&2 "$@" ; exit 1 ; }
+
+longopts="distro:,distro-version:,workdir:,openstack-instance:,extra-rpms-file:"
+longopts+=",taskdir:"
+ARGS=$(getopt -o "v" -l "$longopts" -n "getopt" -- "$@") \
+ || exit 1
+eval set -- "$ARGS"
+
+while true; do
+ case "$1" in
+ --taskdir)
+ opt=$(sed -e 's/^--//' -e 's/[^[a-zA-Z0-9]/_/g'<<<"$1")
+ eval "opt_$opt=\"${2,,}\""
+ shift 2
+ ;;
+
+ --distro)
+ opt_distro="$2"
+ shift 2
+ ;;
+
+ --distro-version)
+ opt_distro_ver="$2"
+ shift 2
+ ;;
+
+ --openstack-instance)
+ opt_openstack_instance="$2"
+ shift 2
+ ;;
+
+ --workdir)
+ # where the remote results are fetched into
+ opt_workdir="$2"
+ shift 2
+ ;;
+
+ --extra-rpms-file)
+ opt_extra_rpms="$(readlink -f "$2")"
+ shift 2
+ ;;
+
+ --)
+ shift
+ break
+ ;;
+ esac
+done
+
+test -z "$opt_taskdir" && die "you must specify --taskdir"
+
+credsfile="$HOME/.dtf/private/os/$opt_openstack_instance.yml"
+test ! -f "$credsfile" && die "file '$credsfile' not found"
+
+config_os_file="$HOME/.dtf/os/$opt_openstack_instance.sh"
+test ! -r "$config_os_file" && die "file '$config_os_file' not found"
+. "$config_os_file"
+
+config_os_id="$opt_distro$opt_distro_ver"
+
+workdir_prereq()
+{
+ if test -z "$opt_workdir"; then
+ opt_workdir="$(mktemp -d "/tmp/dtf-remoterun-workdir-XXXXXX")" \
+ || die "can't create workdir '$opt_workdir'"
+ echo "temporary workdir created: $opt_workdir"
+ elif test ! -d "$opt_workdir"; then
+ mkdir -p "$opt_workdir" || die "can't create workdir '$opt_workdir'"
+ fi
+}
+
+tarball()
+(
+ testsuite_name="$(basename "$opt_taskdir")"
+ echo "$testsuite_name"
+ "$opt_taskdir/run" --dist | gzip > "$opt_workdir/$testsuite_name.tar.gz"
+)
+
+workdir_prereq
+
+testsuite_name="$(tarball)" || die "can not create dist tarball"
+
+export ANSIBLE_HOST_KEY_CHECKING=False
+ansible-playbook "$run_playbook" \
+ --extra-vars "opt_generated_vars=@ansiblevarsdir@/generated-vars.yml" \
+ --extra-vars "opt_distro=$opt_distro" \
+ --extra-vars "opt_distro_ver=$opt_distro_ver" \
+ --extra-vars "opt_workdir=$opt_workdir" \
+ --extra-vars "opt_credsfile=$credsfile" \
+ --extra-vars "os_flavor_id=${os_flavor_ids[$config_os_id]}" \
+ --extra-vars "os_image_id=${os_image_ids[$config_os_id]}" \
+ --extra-vars "os_keypair=${os_keypair}" \
+ --extra-vars "os_security_group=${os_security_group}" \
+ --extra-vars "os_network_dev=${os_network_dev}" \
+ --extra-vars "opt_testsuite_name=${testsuite_name}" \
+ --extra-vars "${opt_extra_rpms:+dtf_rpm_files_list=$opt_extra_rpms}"