summaryrefslogtreecommitdiffstats
path: root/controller/bin
diff options
context:
space:
mode:
Diffstat (limited to 'controller/bin')
-rw-r--r--controller/bin/dtf-get-machine.in87
-rw-r--r--controller/bin/dtf-run-remote.in111
2 files changed, 198 insertions, 0 deletions
diff --git a/controller/bin/dtf-get-machine.in b/controller/bin/dtf-get-machine.in
new file mode 100644
index 0000000..0d7c567
--- /dev/null
+++ b/controller/bin/dtf-get-machine.in
@@ -0,0 +1,87 @@
+#!/bin/bash
+
+die() { echo "$@" ; exit 1 ; }
+info() { echo " * $@" ; }
+
+opt_openstack_instance=os1
+opt_distro=fedora
+opt_distro_version=20
+
+function show_help()
+{
+cat <<EOHELP >&2
+Usage: $0 OPTION
+
+Script is aimed to help sysadmin.
+
+Options:
+ --distro=NAME Distro name, like fedora
+ --distro-version=VERSION E.g. 20 for Fedora 20
+ --openstack-instance=ID
+ --name=NAME Name of the machine
+EOHELP
+test -n "$1" && exit "$1"
+}
+
+boot()
+(
+ set -o pipefail
+ nova boot "$1" --poll \
+ --image "$2" \
+ --flavor "$3" \
+ --security-groups "$os_security_group" \
+ --key-name "$os_keypair" \
+ | grep "| id " | cut -d\| -f 3 | xargs -n 1
+)
+
+get_ip()
+(
+ id="$1"
+ set -o pipefail
+ nova show "$id" | grep ' network ' \
+ | cut -d\| -f 3 | cut -d, -f2 | xargs -n 1
+)
+
+
+longopts="distro:,distro-version:,openstack-instance:,name:"
+ARGS=$(getopt -o "" -l "help,$longopts" -n "$0" -- "$@") \
+ || exit 1
+eval set -- "$ARGS"
+
+while true; do
+ case "$1" in
+ --distro|--distro-version|--openstack-instance|--name)
+ opt=$(sed -e 's/^--//' -e 's/[^[a-zA-Z0-9]/_/g'<<<"$1")
+ eval "opt_$opt=\"${2,,}\""
+ shift 2
+ ;;
+
+ --help)
+ show_help 0
+ ;;
+
+ --)
+ shift
+ break;
+ esac
+done
+
+. "@pkgdatadir@/parse_credsfile" "$opt_openstack_instance" || exit 1
+. ./config/os/"$opt_openstack_instance.sh" || exit 1
+
+image_version=$opt_distro$opt_distro_version
+image=${os_image_ids[$image_version]}
+flavor=${os_flavor_ids[$image_version]}
+
+test -z "$image" && die "no image for '$image_version'"
+test -z "$flavor" && die "no flavor for '$image_version'"
+test -z "$opt_name" && opt_name="testing-$image"
+
+info "booting machine $image_version from $image"
+
+machine=$(boot "$opt_name" "$image" "$flavor")
+
+info "machine id: $machine"
+
+ip=$(get_ip "$machine")
+info "ip: $ip"
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}"