* project: update all dependencies including ansible Upgrade to ansible 7.x and ansible-core 2.14.x. There seems to be issue with ansible 8/ansible-core 2.15 so we remain on those versions for now. It's quite a big bump already anyway. Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * tests: install aws galaxy collection Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * ansible-lint: disable various rules after ansible upgrade Temporarily disable a bunch of linting action following ansible upgrade. Those should be taken care of separately. Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve deprecated-module ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve no-free-form ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve schema[meta] ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve schema[playbook] ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve schema[tasks] ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve risky-file-permissions ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve risky-shell-pipe ansible-lint error Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: remove deprecated warn args Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: use fqcn for non builtin tasks Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: resolve syntax-check[missing-file] for contrib playbook Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> * project: use arithmetic inside jinja to fix ansible 6 upgrade Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch> --------- Signed-off-by: Arthur Outhenin-Chalandre <arthur.outhenin-chalandre@proton.ch>
82 lines
2.2 KiB
YAML
82 lines
2.2 KiB
YAML
---
|
|
- hosts: localhost
|
|
become: false
|
|
gather_facts: no
|
|
|
|
vars:
|
|
expire_days: 2
|
|
|
|
tasks:
|
|
- name: Generate uniq bucket name prefix
|
|
raw: date +%Y%m%d
|
|
changed_when: false
|
|
register: out
|
|
|
|
- name: replace_test_id
|
|
set_fact:
|
|
test_name: "kargo-ci-{{ out.stdout_lines[0] }}"
|
|
|
|
- name: Set file_name for logs
|
|
set_fact:
|
|
file_name: "{{ ostype }}-{{ kube_network_plugin }}-{{ commit }}-logs.tar.gz"
|
|
|
|
- name: Create a bucket
|
|
community.google.gc_storage:
|
|
bucket: "{{ test_name }}"
|
|
mode: create
|
|
permission: public-read
|
|
gs_access_key: "{{ gs_key }}"
|
|
gs_secret_key: "{{ gs_skey }}"
|
|
no_log: True
|
|
|
|
- name: Create a lifecycle template for the bucket
|
|
template:
|
|
src: gcs_life.json.j2
|
|
dest: "{{ dir }}/gcs_life.json"
|
|
mode: 0644
|
|
|
|
- name: Create a boto config to access GCS
|
|
template:
|
|
src: boto.j2
|
|
dest: "{{ dir }}/.boto"
|
|
mode: 0640
|
|
no_log: True
|
|
|
|
- name: Download gsutil cp installer
|
|
get_url:
|
|
url: https://dl.google.com/dl/cloudsdk/channels/rapid/install_google_cloud_sdk.bash
|
|
dest: "{{ dir }}/gcp-installer.sh"
|
|
mode: 0644
|
|
|
|
- name: Get gsutil tool
|
|
command: "{{ dir }}/gcp-installer.sh"
|
|
environment:
|
|
CLOUDSDK_CORE_DISABLE_PROMPTS: "1"
|
|
CLOUDSDK_INSTALL_DIR: "{{ dir }}"
|
|
no_log: True
|
|
failed_when: false
|
|
|
|
- name: Apply the lifecycle rules # noqa 301
|
|
command: "{{ dir }}/google-cloud-sdk/bin/gsutil lifecycle set {{ dir }}/gcs_life.json gs://{{ test_name }}"
|
|
changed_when: false
|
|
environment:
|
|
BOTO_CONFIG: "{{ dir }}/.boto"
|
|
no_log: True
|
|
|
|
- name: Upload collected diagnostic info
|
|
community.google.gc_storage:
|
|
bucket: "{{ test_name }}"
|
|
mode: put
|
|
permission: public-read
|
|
object: "{{ file_name }}"
|
|
src: "{{ dir }}/logs.tar.gz"
|
|
headers: '{"Content-Encoding": "x-gzip"}'
|
|
gs_access_key: "{{ gs_key }}"
|
|
gs_secret_key: "{{ gs_skey }}"
|
|
expiration: "{{ expire_days * 36000|int }}"
|
|
failed_when: false
|
|
no_log: True
|
|
|
|
- debug: # noqa unnamed-task
|
|
msg: "A public url https://storage.googleapis.com/{{ test_name }}/{{ file_name }}"
|