Merge "Refactor fetch-sphinx-tarball to be executor safe"
This commit is contained in:
commit
4b19def07d
@ -7,6 +7,7 @@ General Purpose Roles
|
|||||||
.. zuul:autorole:: add-sshkey
|
.. zuul:autorole:: add-sshkey
|
||||||
.. zuul:autorole:: bindep
|
.. zuul:autorole:: bindep
|
||||||
.. zuul:autorole:: buildset-artifacts-location
|
.. zuul:autorole:: buildset-artifacts-location
|
||||||
|
.. zuul:autorole:: clean-directory
|
||||||
.. zuul:autorole:: clear-firewall
|
.. zuul:autorole:: clear-firewall
|
||||||
.. zuul:autorole:: configure-mirrors
|
.. zuul:autorole:: configure-mirrors
|
||||||
.. zuul:autorole:: copy-build-sshkey
|
.. zuul:autorole:: copy-build-sshkey
|
||||||
|
10
roles/clean-directory/README.rst
Normal file
10
roles/clean-directory/README.rst
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
Clean a directory, but leave the directory alone
|
||||||
|
|
||||||
|
This is the equivalent of ``rm -rf *`` when run in a directory. It is
|
||||||
|
safe to run in executor context.
|
||||||
|
|
||||||
|
**Role Variables**
|
||||||
|
|
||||||
|
.. zuul:rolevar:: clean_directory_path
|
||||||
|
|
||||||
|
The directory to clean.
|
28
roles/clean-directory/tasks/main.yaml
Normal file
28
roles/clean-directory/tasks/main.yaml
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
- name: Assert directory set
|
||||||
|
assert:
|
||||||
|
that: clean_directory_path is defined
|
||||||
|
fail_msg: 'Must specify clean_directory_path'
|
||||||
|
|
||||||
|
- block:
|
||||||
|
- name: Collect files
|
||||||
|
find:
|
||||||
|
paths: '{{ clean_directory_path }}'
|
||||||
|
hidden: True
|
||||||
|
recurse: True
|
||||||
|
register: _files
|
||||||
|
|
||||||
|
- name: Collect directories
|
||||||
|
find:
|
||||||
|
paths: '{{ clean_directory_path }}'
|
||||||
|
hidden: True
|
||||||
|
recurse: True
|
||||||
|
file_type: directory
|
||||||
|
register: _dirs
|
||||||
|
|
||||||
|
- name: Clean Directory
|
||||||
|
file:
|
||||||
|
path: '{{ zj_item }}'
|
||||||
|
state: absent
|
||||||
|
loop: '{{ _files.files + _dirs.files }}'
|
||||||
|
loop_control:
|
||||||
|
loop_var: zj_item
|
@ -1,18 +1,45 @@
|
|||||||
- name: Move artifacts and docs to logs dir
|
- name: Move artifacts and docs to logs dir
|
||||||
when: zuul.change is defined
|
when: zuul.change is defined
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
shell: |
|
block:
|
||||||
if [ -n "$(find {{ zuul.executor.work_root }}/{{ zj_item }} -mindepth 1)" ] ; then
|
# Artifacts
|
||||||
# Only create target directory if it is needed.
|
- name: Check if artifacts is empty
|
||||||
# Do not fail if it is already there.
|
find:
|
||||||
mkdir -p {{ zuul.executor.log_root }}/{{ zj_item }}
|
paths: '{{ zuul.executor.work_root }}/artifacts'
|
||||||
# Leave the original directory behind so that other roles
|
register: _artifacts
|
||||||
# operating on the interface directories can simply no-op.
|
|
||||||
mv -f {{ zuul.executor.work_root }}/{{ zj_item }}/* {{ zuul.executor.log_root }}/{{ zj_item }}
|
- name: Copy artifacts into log root
|
||||||
fi
|
synchronize:
|
||||||
loop:
|
src: '{{ zuul.executor.work_root }}/artifacts/'
|
||||||
- artifacts
|
dest: '{{ zuul.exector.log_root }}/artifacts/'
|
||||||
- docs
|
owner: no
|
||||||
loop_control:
|
group: no
|
||||||
loop_var: zj_item
|
when: _artifacts.files
|
||||||
run_once: true
|
|
||||||
|
- name: Clean artifacts
|
||||||
|
include_role:
|
||||||
|
name: clean-directory
|
||||||
|
vars:
|
||||||
|
clean_directory_path: '{{ zuul.executor.work_root }}/artifacts/'
|
||||||
|
when: _artifacts.files
|
||||||
|
|
||||||
|
# Docs
|
||||||
|
- name: Check if docs is empty
|
||||||
|
find:
|
||||||
|
paths: '{{ zuul.executor.work_root }}/docs'
|
||||||
|
register: _docs
|
||||||
|
|
||||||
|
- name: Copy docs into log root
|
||||||
|
synchronize:
|
||||||
|
src: '{{ zuul.executor.work_root }}/docs/'
|
||||||
|
dest: '{{ zuul.exector.log_root }}/docs/'
|
||||||
|
owner: no
|
||||||
|
group: no
|
||||||
|
when: _docs.files
|
||||||
|
|
||||||
|
- name: Clean docs
|
||||||
|
include_role:
|
||||||
|
name: clean-directory
|
||||||
|
vars:
|
||||||
|
clean_directory_path: '{{ zuul.executor.work_root }}/docs/'
|
||||||
|
when: _docs.files
|
||||||
|
@ -455,19 +455,19 @@
|
|||||||
vars:
|
vars:
|
||||||
zuul_use_fetch_output: false
|
zuul_use_fetch_output: false
|
||||||
|
|
||||||
# Disabled because "Move artifacts and docs to logs dir" task would
|
- job:
|
||||||
# fail with "Executing local code is prohibited" during testing
|
name: zuul-jobs-test-fetch-sphinx-tarball-with-zuul-output
|
||||||
# - job:
|
description: Test the fetch-sphinx-tarball
|
||||||
# name: zuul-jobs-test-fetch-sphinx-tarball-with-zuul-output
|
files:
|
||||||
# description: Test the fetch-sphinx-tarball
|
- roles/ensure-output-dirs/.*
|
||||||
# files:
|
- roles/fetch-sphinx-tarball/.*
|
||||||
# - roles/ensure-output-dirs/.*
|
- roles/fetch-output/.*
|
||||||
# - roles/fetch-sphinx-tarball/.*
|
- roles/merge-output-to-logs/.*
|
||||||
# - roles/fetch-output/.*
|
- roles/clean-directory/.*
|
||||||
# run: test-playbooks/python/fetch-sphinx-tarball.yaml
|
- test-playbooks/python/fetch-sphinx-tarball.yaml
|
||||||
# voting: false
|
run: test-playbooks/python/fetch-sphinx-tarball.yaml
|
||||||
# vars:
|
vars:
|
||||||
# zuul_use_fetch_output: true
|
zuul_use_fetch_output: true
|
||||||
|
|
||||||
- job:
|
- job:
|
||||||
name: zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
name: zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
||||||
@ -522,6 +522,7 @@
|
|||||||
- zuul-jobs-test-fetch-subunit-output-synchronize
|
- zuul-jobs-test-fetch-subunit-output-synchronize
|
||||||
- zuul-jobs-test-fetch-sphinx-output
|
- zuul-jobs-test-fetch-sphinx-output
|
||||||
- zuul-jobs-test-fetch-sphinx-output-synchronize
|
- zuul-jobs-test-fetch-sphinx-output-synchronize
|
||||||
|
- zuul-jobs-test-fetch-sphinx-tarball-with-zuul-output
|
||||||
- zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
- zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
||||||
gate:
|
gate:
|
||||||
jobs: &id001
|
jobs: &id001
|
||||||
@ -563,6 +564,7 @@
|
|||||||
- zuul-jobs-test-fetch-subunit-output-synchronize
|
- zuul-jobs-test-fetch-subunit-output-synchronize
|
||||||
- zuul-jobs-test-fetch-sphinx-output
|
- zuul-jobs-test-fetch-sphinx-output
|
||||||
- zuul-jobs-test-fetch-sphinx-output-synchronize
|
- zuul-jobs-test-fetch-sphinx-output-synchronize
|
||||||
|
- zuul-jobs-test-fetch-sphinx-tarball-with-zuul-output
|
||||||
- zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
- zuul-jobs-test-fetch-sphinx-tarball-synchronize
|
||||||
periodic-weekly:
|
periodic-weekly:
|
||||||
jobs: *id001
|
jobs: *id001
|
||||||
|
Loading…
Reference in New Issue
Block a user