summaryrefslogtreecommitdiffstats
path: root/controller/share/dtf-controller
diff options
context:
space:
mode:
Diffstat (limited to 'controller/share/dtf-controller')
-rw-r--r--controller/share/dtf-controller/ansible/dummy-wrapper.yml7
-rw-r--r--controller/share/dtf-controller/ansible/playbooks/fedora.yml68
-rw-r--r--controller/share/dtf-controller/ansible/playbooks/include/additional-packages.yml6
-rw-r--r--controller/share/dtf-controller/ansible/playbooks/include/beakerlib.yml1
-rw-r--r--controller/share/dtf-controller/ansible/playbooks/include/download-results.yml5
-rw-r--r--controller/share/dtf-controller/ansible/playbooks/include/prepare-testenv.yml3
-rwxr-xr-xcontroller/share/dtf-controller/ansible/run_include19
-rw-r--r--controller/share/dtf-controller/ansible/vars/generated-vars.yml.in4
-rw-r--r--controller/share/dtf-controller/parse_credsfile31
9 files changed, 144 insertions, 0 deletions
diff --git a/controller/share/dtf-controller/ansible/dummy-wrapper.yml b/controller/share/dtf-controller/ansible/dummy-wrapper.yml
new file mode 100644
index 0000000..524b0ea
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/dummy-wrapper.yml
@@ -0,0 +1,7 @@
+- name: "dummy-wrapper"
+ hosts: "{{ target }}"
+ remote_user: root
+ gather_facts: False
+
+ tasks:
+ - include: "{{ include_file }}"
diff --git a/controller/share/dtf-controller/ansible/playbooks/fedora.yml b/controller/share/dtf-controller/ansible/playbooks/fedora.yml
new file mode 100644
index 0000000..215e048
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/playbooks/fedora.yml
@@ -0,0 +1,68 @@
+- name: self-standing testsuite
+ remote_user: root
+ gather_facts: False
+ hosts: localhost
+ vars_files:
+ - "{{ opt_credsfile }}"
+ - "{{ opt_generated_vars }}"
+
+ tasks:
+ - name: generate builder name
+ local_action: shell echo `dd if=/dev/urandom bs=1k count=10 | md5sum ; echo DBTESTS`
+ register: vm_name
+
+ - debug: msg="osusername={{ os_username }}"
+
+ - name: spin it up
+ local_action: nova_compute auth_url={{os_auth_url}}
+ flavor_id={{os_flavor_id}} image_id="{{ os_image_id }}" key_name={{ os_keypair }}
+ login_password={{os_nova_password}} login_tenant_name="{{os_tenant_name}}"
+ login_username={{os_username}} security_groups={{os_security_group}}
+ wait=yes name="{{vm_name.stdout}}" wait_for=600
+ register: nova
+
+ - debug: msg="{{ nova.info.addresses }}"
+
+ # This is ugly as hell... Hopefully nothing will be changing.
+ - local_action: command echo "{{ nova.info.addresses[os_network_dev][1].addr }}"
+ register: machine_ip
+
+ - debug: msg="{{ machine_ip.stdout }}"
+
+ - name: wait for the host to be hot
+ local_action: wait_for host={{ machine_ip.stdout }} port=22 delay=5 timeout=600
+
+ - local_action: shell {{ config_libexecdir }}/dtf-wait-for-ssh "root@{{ machine_ip.stdout }}"
+
+ - name: add it to the special group
+ local_action: add_host hostname={{ machine_ip.stdout }}
+ groupname=temp_group
+
+- hosts: temp_group
+ user: root
+ gather_facts: False
+ vars_files:
+ - "{{ opt_credsfile }}"
+ - "{{ opt_generated_vars }}"
+ tasks:
+ - copy: src={{ opt_workdir }}/{{ opt_testsuite_name }}.tar.gz
+ dest=/root/{{ opt_testsuite_name }}.tar.gz
+
+ - include: "{{ config_ansibleplaybooksdir }}/include/beakerlib.yml"
+
+ - include: "{{ config_ansibleplaybooksdir }}/include/prepare-testenv.yml"
+
+ - include: "{{ config_ansibleplaybooksdir }}/include/additional-packages.yml"
+ when: dtf_rpm_files_list is defined
+
+ - shell: cd /root && tar -xf {{ opt_testsuite_name }}.tar.gz
+
+ - shell: cd /root/{{ opt_testsuite_name }}&& ./run &>/var/tmp/dtf-run.overview
+ register: test_result
+ ignore_errors: yes
+
+ - include: "{{ config_ansibleplaybooksdir }}/include/download-results.yml"
+
+ - name: stop the vm
+ shell: echo "not implemented yet"
+ when: test_result.rc == 0
diff --git a/controller/share/dtf-controller/ansible/playbooks/include/additional-packages.yml b/controller/share/dtf-controller/ansible/playbooks/include/additional-packages.yml
new file mode 100644
index 0000000..f821255
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/playbooks/include/additional-packages.yml
@@ -0,0 +1,6 @@
+- local_action: shell cat "{{ dtf_rpm_files_list }}" | xargs -n 100
+ register: additional_packages
+
+- debug: msg="{{ additional_packages.stdout }}"
+
+- shell: yum install -y {{ additional_packages.stdout }}
diff --git a/controller/share/dtf-controller/ansible/playbooks/include/beakerlib.yml b/controller/share/dtf-controller/ansible/playbooks/include/beakerlib.yml
new file mode 100644
index 0000000..0461f25
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/playbooks/include/beakerlib.yml
@@ -0,0 +1 @@
+- yum: conf_file=https://beaker-project.org/yum/beaker-server-Fedora.repo state=present name=beakerlib
diff --git a/controller/share/dtf-controller/ansible/playbooks/include/download-results.yml b/controller/share/dtf-controller/ansible/playbooks/include/download-results.yml
new file mode 100644
index 0000000..4404e08
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/playbooks/include/download-results.yml
@@ -0,0 +1,5 @@
+- shell: cp -f /var/tmp/dtf-run.overview /var/tmp/dtf/
+
+- shell: cd /var/tmp ; tar -czf dtf.tar.gz dtf
+
+- fetch: src=/var/tmp/dtf.tar.gz dest="{{ opt_workdir }}/" flat=yes
diff --git a/controller/share/dtf-controller/ansible/playbooks/include/prepare-testenv.yml b/controller/share/dtf-controller/ansible/playbooks/include/prepare-testenv.yml
new file mode 100644
index 0000000..a63e51a
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/playbooks/include/prepare-testenv.yml
@@ -0,0 +1,3 @@
+- yum: state=present name=postgresql-server
+
+- yum: state=present name=postgresql-upgrade
diff --git a/controller/share/dtf-controller/ansible/run_include b/controller/share/dtf-controller/ansible/run_include
new file mode 100755
index 0000000..4e84c7d
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/run_include
@@ -0,0 +1,19 @@
+#!/bin/bash
+
+export ANSIBLE_HOST_KEY_CHECKING=False
+
+workdir="$(dirname "${BASH_SOURCE[0]}")"
+workdir=$(readlink -f "$workdir")
+
+export playbook=$(readlink -f "$1")
+
+( set -x
+ cd "$workdir"
+
+ ansible-playbook -i "$workdir/../config/hosts" \
+ --extra-vars "include_file=$playbook" \
+ --extra-vars "script_name=dummy" \
+ --extra-vars "opt_workdir=/tmp/dtf-$(date +%H%M%S%N)" \
+ --extra-vars "target=host" \
+ "dummy-wrapper.yml"
+)
diff --git a/controller/share/dtf-controller/ansible/vars/generated-vars.yml.in b/controller/share/dtf-controller/ansible/vars/generated-vars.yml.in
new file mode 100644
index 0000000..e33e974
--- /dev/null
+++ b/controller/share/dtf-controller/ansible/vars/generated-vars.yml.in
@@ -0,0 +1,4 @@
+---
+config_bindir: @bindir@
+config_libexecdir: @libexecdir@
+config_ansibleplaybooksdir: @ansibleplaybooksdir@
diff --git a/controller/share/dtf-controller/parse_credsfile b/controller/share/dtf-controller/parse_credsfile
new file mode 100644
index 0000000..2379e18
--- /dev/null
+++ b/controller/share/dtf-controller/parse_credsfile
@@ -0,0 +1,31 @@
+___perform_parsing()
+{
+ unset OS_USERNAME
+ local credsfile="$HOME/.dtf/private/os/$1.yml"
+
+ if test -z "$1"; then
+ echo >&2 "argument expected: OpenStack ID"
+ return 1
+ fi
+
+ if test ! -f "$credsfile"; then
+ echo >&2 "file '$credsfile' not found"
+ return 1
+ fi
+
+ while read line; do
+ if [[ "$line" =~ ^([a-zA-Z0-9_]*):\ ?(.*)$ ]]; then
+ key="${BASH_REMATCH[1]}"
+ if test "$key" = os_nova_password; then
+ key=os_password
+ fi
+ eval set ${BASH_REMATCH[2]}
+ eval export "${key^^}"="\"$@\""
+ fi
+ done < "$credsfile"
+}
+
+unset OS_AUTH_URL OS_PASSWORD OS_TENANT_ID OS_TENANT_NAME OS_USERNAME
+___perform_parsing "$@"
+
+# # vi: syntax=sh