From 09d479b85b7ca4b9138a2ea5b542ad589b892bd7 Mon Sep 17 00:00:00 2001 From: ZhongShengping Date: Tue, 31 Oct 2017 17:24:02 +0800 Subject: [PATCH] Switch to Zuul v3 testing This is the start of the transition to native Zuul v3 support for python-senlinclient. Change-Id: I7762cc84de28ea1a0cca33a4aad33b46fdf26e28 --- .zuul.yaml | 17 ++++ .../senlinclient-dsvm-functional/post.yaml | 80 +++++++++++++++++++ .../senlinclient-dsvm-functional/run.yaml | 70 ++++++++++++++++ 3 files changed, 167 insertions(+) create mode 100644 .zuul.yaml create mode 100644 playbooks/legacy/senlinclient-dsvm-functional/post.yaml create mode 100644 playbooks/legacy/senlinclient-dsvm-functional/run.yaml diff --git a/.zuul.yaml b/.zuul.yaml new file mode 100644 index 00000000..00a4376e --- /dev/null +++ b/.zuul.yaml @@ -0,0 +1,17 @@ +- job: + name: senlinclient-dsvm-functional + parent: legacy-dsvm-base + run: playbooks/legacy/senlinclient-dsvm-functional/run.yaml + post-run: playbooks/legacy/senlinclient-dsvm-functional/post.yaml + timeout: 7200 + required-projects: + - openstack-infra/devstack-gate + - openstack/python-senlinclient + - openstack/senlin + +- project: + name: openstack/python-senlinclient + experimental: + jobs: + - senlinclient-dsvm-functional: + voting: false diff --git a/playbooks/legacy/senlinclient-dsvm-functional/post.yaml b/playbooks/legacy/senlinclient-dsvm-functional/post.yaml new file mode 100644 index 00000000..dac87534 --- /dev/null +++ b/playbooks/legacy/senlinclient-dsvm-functional/post.yaml @@ -0,0 +1,80 @@ +- hosts: primary + tasks: + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=**/*nose_results.html + - --include=*/ + - --exclude=* + - --prune-empty-dirs + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=**/*testr_results.html.gz + - --include=*/ + - --exclude=* + - --prune-empty-dirs + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=/.testrepository/tmp* + - --include=*/ + - --exclude=* + - --prune-empty-dirs + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=**/*testrepository.subunit.gz + - --include=*/ + - --exclude=* + - --prune-empty-dirs + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}/tox' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=/.tox/*/log/* + - --include=*/ + - --exclude=* + - --prune-empty-dirs + + - name: Copy files from {{ ansible_user_dir }}/workspace/ on node + synchronize: + src: '{{ ansible_user_dir }}/workspace/' + dest: '{{ zuul.executor.log_root }}' + mode: pull + copy_links: true + verify_host: true + rsync_opts: + - --include=/logs/** + - --include=*/ + - --exclude=* + - --prune-empty-dirs diff --git a/playbooks/legacy/senlinclient-dsvm-functional/run.yaml b/playbooks/legacy/senlinclient-dsvm-functional/run.yaml new file mode 100644 index 00000000..b81037ae --- /dev/null +++ b/playbooks/legacy/senlinclient-dsvm-functional/run.yaml @@ -0,0 +1,70 @@ +- hosts: all + name: Autoconverted job legacy-senlinclient-dsvm-functional from old job gate-senlinclient-dsvm-functional-nv + tasks: + + - name: Ensure legacy workspace directory + file: + path: '{{ ansible_user_dir }}/workspace' + state: directory + + - shell: + cmd: | + set -e + set -x + cat > clonemap.yaml << EOF + clonemap: + - name: openstack-infra/devstack-gate + dest: devstack-gate + EOF + /usr/zuul-env/bin/zuul-cloner -m clonemap.yaml --cache-dir /opt/git \ + git://git.openstack.org \ + openstack-infra/devstack-gate + executable: /bin/bash + chdir: '{{ ansible_user_dir }}/workspace' + environment: '{{ zuul | zuul_legacy_vars }}' + + - shell: + cmd: | + set -e + set -x + cat << 'EOF' >>"/tmp/dg-local.conf" + [[local|localrc]] + enable_plugin senlin https://git.openstack.org/openstack/senlin + enable_service sl-api sl-eng + + EOF + executable: /bin/bash + chdir: '{{ ansible_user_dir }}/workspace' + environment: '{{ zuul | zuul_legacy_vars }}' + + - shell: + cmd: | + set -e + set -x + export PYTHONUNBUFFERED=true + export BRANCH_OVERRIDE=default + export KEEP_LOCALRC=1 + export PROJECTS="openstack/senlin $PROJECTS" + export DEVSTACK_PROJECT_FROM_GIT=python-senlinclient + export SENLIN_BACKEND="openstack_test" + if [ "$BRANCH_OVERRIDE" != "default" ] ; then + export OVERRIDE_ZUUL_BRANCH=$BRANCH_OVERRIDE + fi + + function pre_test_hook { + cd /opt/stack/new/python-senlinclient/senlinclient/tests/functional/ + ./pre_test_hook.sh + } + export -f pre_test_hook + + function post_test_hook { + cd /opt/stack/new/python-senlinclient/senlinclient/tests/functional/ + ./post_test_hook.sh + } + export -f post_test_hook + + cp devstack-gate/devstack-vm-gate-wrap.sh ./safe-devstack-vm-gate-wrap.sh + ./safe-devstack-vm-gate-wrap.sh + executable: /bin/bash + chdir: '{{ ansible_user_dir }}/workspace' + environment: '{{ zuul | zuul_legacy_vars }}'