Merge "Refactor fetch-sphinx-tarball to be executor safe"

This commit is contained in:
Zuul 2020-10-14 18:51:05 +00:00 committed by Gerrit Code Review
commit 4b19def07d
5 changed files with 96 additions and 28 deletions

View File

@ -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

View 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.

View 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

View File

@ -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

View File

@ -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