- name: Set zuul-log-path fact include_role: name: set-zuul-log-path-fact when: zuul_log_path is not defined # Always upload (true), never upload (false) or only on failure ('failure') - name: Upload logs when: zuul_site_upload_logs | default(true) | bool or (zuul_site_upload_logs == 'failure' and not zuul_success | bool) block: # Use chmod instead of file because ansible 2.5 file with recurse and # follow can't really handle symlinks to . - name: Ensure logs are readable before uploading delegate_to: localhost command: "chmod -R u=rwX,g=rX,o=rX {{ zuul.executor.log_root }}/" # ANSIBLE0007 chmod used in place of argument mode to file tags: - skip_ansible_lint - name: Upload logs to IBM Cloud delegate_to: localhost no_log: true zuul_ibm_upload: partition: "{{ zuul_log_partition }}" bucket: "{{ zuul_log_bucket }}" bucket_location: "{{ zuul_log_bucket_location }}" public: "{{ zuul_log_bucket_public }}" prefix: "{{ zuul_log_path }}" indexes: "{{ zuul_log_create_indexes }}" api_key: "{{ zuul_log_api_key }}" instance_id: "{{ zuul_log_instance_id }}" endpoint_url: "{{ zuul_log_endpoint_url }}" files: - "{{ zuul.executor.log_root }}/" register: upload_results - name: Return log URL to Zuul delegate_to: localhost zuul_return: data: zuul: log_url: "{{ upload_results.url }}/" when: upload_results is defined