~/src/github.com/openstack-k8s-operators/install_yamls/devsetup ~/ci-framework-data/artifacts ANSIBLE_FORCE_COLOR=true ansible-playbook \ -v -i hosts --tags all \ download_tools.yaml Using /home/zuul/src/github.com/openstack-k8s-operators/ci-framework/ansible.cfg as config file PLAY [Download tools] ********************************************************** TASK [download_tools : Install build dependencies name=['jq', 'skopeo', 'sqlite', 'httpd-tools', 'virt-install', 'gcc', 'python3-jinja2', 'xmlstarlet', 'openssl']] *** Monday 23 February 2026 08:55:32 +0000 (0:00:00.036) 0:00:00.036 ******* Monday 23 February 2026 08:55:32 +0000 (0:00:00.035) 0:00:00.035 ******* changed: [localhost] =>   changed: true  msg: ''  rc: 0  results:  - 'Installed: virt-install-5.0.0-1.el9.noarch'  - 'Installed: virt-manager-common-5.0.0-1.el9.noarch'  - 'Installed: apr-1.7.0-12.el9.x86_64'  - 'Installed: apr-util-1.6.1-23.el9.x86_64'  - 'Installed: apr-util-bdb-1.6.1-23.el9.x86_64'  - 'Installed: xorriso-1.5.4-5.el9.x86_64'  - 'Installed: libosinfo-1.10.0-1.el9.x86_64'  - 'Installed: apr-util-openssl-1.6.1-23.el9.x86_64'  - 'Installed: libisoburn-1.5.4-5.el9.x86_64'  - 'Installed: libvirt-client-11.10.0-4.el9.x86_64'  - 'Installed: libisofs-1.5.4-4.el9.x86_64'  - 'Installed: python3-argcomplete-1.12.0-5.el9.noarch'  - 'Installed: xmlstarlet-1.6.1-20.el9.x86_64'  - 'Installed: sqlite-3.34.1-9.el9.x86_64'  - 'Installed: libburn-1.5.4-5.el9.x86_64'  - 'Installed: skopeo-2:1.22.0-1.el9.x86_64'  - 'Installed: osinfo-db-20250606-1.el9.noarch'  - 'Installed: osinfo-db-tools-1.10.0-1.el9.x86_64'  - 'Installed: httpd-tools-2.4.62-12.el9.x86_64' TASK [download_tools : Set opm download url suffix opm_url_suffix=latest/download] *** Monday 23 February 2026 08:55:36 +0000 (0:00:03.669) 0:00:03.705 ******* Monday 23 February 2026 08:55:36 +0000 (0:00:03.669) 0:00:03.705 ******* skipping: [localhost] =>   changed: false  false_condition: opm_version is undefined or opm_version == "latest"  skip_reason: Conditional result was False TASK [download_tools : Set opm download url suffix opm_url_suffix=download/{{ opm_version }}] *** Monday 23 February 2026 08:55:36 +0000 (0:00:00.024) 0:00:03.730 ******* Monday 23 February 2026 08:55:36 +0000 (0:00:00.024) 0:00:03.729 ******* ok: [localhost] =>   ansible_facts:  opm_url_suffix: download/v1.30.0  changed: false TASK [download_tools : Create $HOME/bin dir path={{ lookup('env', 'HOME') }}/bin, state=directory, mode=0755] *** Monday 23 February 2026 08:55:36 +0000 (0:00:00.029) 0:00:03.759 ******* Monday 23 February 2026 08:55:36 +0000 (0:00:00.029) 0:00:03.758 ******* ok: [localhost] =>   changed: false  gid: 1000  group: zuul  mode: '0755'  owner: zuul  path: /home/zuul/bin  secontext: unconfined_u:object_r:home_bin_t:s0  size: 48  state: directory  uid: 1000 TASK [download_tools : Download opm url=https://github.com/operator-framework/operator-registry/releases/{{ opm_url_suffix }}/linux-amd64-opm, dest={{ lookup('env', 'HOME') }}/bin/opm, mode=0755, timeout=30] *** Monday 23 February 2026 08:55:36 +0000 (0:00:00.279) 0:00:04.039 ******* Monday 23 February 2026 08:55:36 +0000 (0:00:00.279) 0:00:04.038 ******* changed: [localhost] =>   changed: true  checksum_dest: null  checksum_src: 9238abd6903e2fbbb4e1077b6ae3ada340867a32  dest: /home/zuul/bin/opm  elapsed: 0  gid: 1000  group: zuul  md5sum: 7012baf74b8eb8252ce3d768e06f5400  mode: '0755'  msg: OK (54879432 bytes)  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 54879432  src: /home/zuul/.ansible/tmp/ansible-moduletmp-1771836936.7183502-4pjolnxl/tmpqbqpchi6  state: file  status_code: 200  uid: 1000  url: https://github.com/operator-framework/operator-registry/releases/download/v1.30.0/linux-amd64-opm TASK [download_tools : Set oc-mirror download url oc_mirror_url=https://mirror.openshift.com/pub/openshift-v4/clients/ocp/{{ oc_mirror_version }}/oc-mirror.tar.gz] *** Monday 23 February 2026 08:55:37 +0000 (0:00:01.211) 0:00:05.250 ******* Monday 23 February 2026 08:55:37 +0000 (0:00:01.211) 0:00:05.250 ******* ok: [localhost] =>   ansible_facts:  oc_mirror_url: https://mirror.openshift.com/pub/openshift-v4/clients/ocp/latest/oc-mirror.tar.gz  changed: false TASK [download_tools : Download and extract oc-mirror src={{ oc_mirror_url }}, dest={{ lookup('env', 'HOME') }}/bin/, remote_src=True] *** Monday 23 February 2026 08:55:37 +0000 (0:00:00.024) 0:00:05.275 ******* Monday 23 February 2026 08:55:37 +0000 (0:00:00.024) 0:00:05.274 ******* changed: [localhost] =>   changed: true  dest: /home/zuul/bin/  extract_results:  cmd:  - /usr/bin/gtar  - --extract  - -C  - /home/zuul/bin  - -z  - -f  - /home/zuul/.ansible/tmp/ansible-tmp-1771836937.6398091-31152-228424218430461/oc-mirrolj1g58vp.tar.gz  err: ''  out: ''  rc: 0  gid: 1000  group: zuul  handler: TgzArchive  mode: '0755'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 76  src: /home/zuul/.ansible/tmp/ansible-tmp-1771836937.6398091-31152-228424218430461/oc-mirrolj1g58vp.tar.gz  state: directory  uid: 1000 TASK [download_tools : Make oc-mirror executable path={{ lookup('env', 'HOME') }}/bin/oc-mirror, mode=0755] *** Monday 23 February 2026 08:55:45 +0000 (0:00:08.009) 0:00:13.285 ******* Monday 23 February 2026 08:55:45 +0000 (0:00:08.009) 0:00:13.284 ******* changed: [localhost] =>   changed: true  gid: 1000  group: zuul  mode: '0755'  owner: zuul  path: /home/zuul/bin/oc-mirror  secontext: unconfined_u:object_r:home_bin_t:s0  size: 314996368  state: file  uid: 1000 TASK [download_tools : Get version from sdk_version _sdk_version={{ sdk_version | regex_search('v(.*)', '\1') | first }}] *** Monday 23 February 2026 08:55:45 +0000 (0:00:00.171) 0:00:13.456 ******* Monday 23 February 2026 08:55:45 +0000 (0:00:00.171) 0:00:13.455 ******* ok: [localhost] =>   ansible_facts:  _sdk_version: 1.41.1  changed: false TASK [download_tools : Set operator-sdk file for version < 1.3.0 _operator_sdk_file=operator-sdk-{{ sdk_version }}-x86_64-linux-gnu] *** Monday 23 February 2026 08:55:45 +0000 (0:00:00.033) 0:00:13.489 ******* Monday 23 February 2026 08:55:45 +0000 (0:00:00.033) 0:00:13.488 ******* skipping: [localhost] =>   changed: false  false_condition: _sdk_version is version('1.3.0', 'lt', strict=True )  skip_reason: Conditional result was False TASK [download_tools : Set operator-sdk file for version >= 1.3.0 _operator_sdk_file=operator-sdk_linux_amd64] *** Monday 23 February 2026 08:55:45 +0000 (0:00:00.031) 0:00:13.521 ******* Monday 23 February 2026 08:55:45 +0000 (0:00:00.031) 0:00:13.520 ******* ok: [localhost] =>   ansible_facts:  _operator_sdk_file: operator-sdk_linux_amd64  changed: false TASK [download_tools : Download operator-sdk url=https://github.com/operator-framework/operator-sdk/releases/download/{{ sdk_version }}/{{ _operator_sdk_file }}, dest={{ lookup('env', 'HOME') }}/bin/operator-sdk, mode=0755, force=True, timeout=30] *** Monday 23 February 2026 08:55:45 +0000 (0:00:00.036) 0:00:13.558 ******* Monday 23 February 2026 08:55:45 +0000 (0:00:00.036) 0:00:13.557 ******* changed: [localhost] =>   changed: true  checksum_dest: null  checksum_src: b29fbaf7b88d11c0fc7b56fc7468cc20bbb00875  dest: /home/zuul/bin/operator-sdk  elapsed: 0  gid: 1000  group: zuul  md5sum: f288351121b669bf298bab2daeb0d4de  mode: '0755'  msg: OK (120534604 bytes)  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 120534604  src: /home/zuul/.ansible/tmp/ansible-moduletmp-1771836946.1450658-uqien5i8/tmp7sg3dfvw  state: file  status_code: 200  uid: 1000  url: https://github.com/operator-framework/operator-sdk/releases/download/v1.41.1/operator-sdk_linux_amd64 TASK [download_tools : Download and extract kustomize src=https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2F{{ kustomize_version }}/kustomize_{{ kustomize_version }}_linux_amd64.tar.gz, dest={{ lookup('env', 'HOME') }}/bin/, remote_src=True] *** Monday 23 February 2026 08:55:47 +0000 (0:00:01.341) 0:00:14.899 ******* Monday 23 February 2026 08:55:47 +0000 (0:00:01.341) 0:00:14.898 ******* changed: [localhost] =>   changed: true  dest: /home/zuul/bin/  extract_results:  cmd:  - /usr/bin/gtar  - --extract  - -C  - /home/zuul/bin  - -z  - -f  - /home/zuul/.ansible/tmp/ansible-tmp-1771836947.2606544-31198-90657568540853/kustomize_v5.0.3_linux_amd64mnoraqpj.tar.gz  err: ''  out: ''  rc: 0  gid: 1000  group: zuul  handler: TgzArchive  mode: '0755'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 113  src: /home/zuul/.ansible/tmp/ansible-tmp-1771836947.2606544-31198-90657568540853/kustomize_v5.0.3_linux_amd64mnoraqpj.tar.gz  state: directory  uid: 1000 TASK [download_tools : Download kubectl url=https://dl.k8s.io/release/{{ kubectl_version }}/bin/linux/amd64/kubectl, dest={{ lookup('env', 'HOME') }}/bin/kubectl, mode=0755, timeout=30] *** Monday 23 February 2026 08:55:48 +0000 (0:00:01.047) 0:00:15.946 ******* Monday 23 February 2026 08:55:48 +0000 (0:00:01.047) 0:00:15.945 ******* ok: [localhost] =>   changed: false  dest: /home/zuul/bin/kubectl  elapsed: 0  gid: 1000  group: zuul  mode: '0755'  msg: 'HTTP Error 304: Not Modified'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 197726784  state: hard  status_code: 304  uid: 1000  url: https://dl.k8s.io/release/v1.25.7/bin/linux/amd64/kubectl TASK [download_tools : Download kuttl url=https://github.com/kudobuilder/kuttl/releases/download/v{{ kuttl_version }}/kubectl-kuttl_{{ kuttl_version }}_linux_x86_64, dest={{ lookup('env', 'HOME') }}/bin/kubectl-kuttl, mode=0755, timeout=30] *** Monday 23 February 2026 08:55:48 +0000 (0:00:00.326) 0:00:16.273 ******* Monday 23 February 2026 08:55:48 +0000 (0:00:00.326) 0:00:16.272 ******* changed: [localhost] =>   changed: true  checksum_dest: null  checksum_src: b6a31d1f3601af01fcce998d721a8e71df2fddc2  dest: /home/zuul/bin/kubectl-kuttl  elapsed: 0  gid: 1000  group: zuul  md5sum: 3ff8e2099b841f8ef0766ebc22057376  mode: '0755'  msg: OK (39207064 bytes)  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 39207064  src: /home/zuul/.ansible/tmp/ansible-moduletmp-1771836948.819479-a3mrtxou/tmpqlusfan1  state: file  status_code: 200  uid: 1000  url: https://github.com/kudobuilder/kuttl/releases/download/v0.20.0/kubectl-kuttl_0.20.0_linux_x86_64 TASK [download_tools : Download chainsaw src=https://github.com/kyverno/chainsaw/releases/download/v{{ chainsaw_version }}/chainsaw_linux_amd64.tar.gz, dest={{ lookup('env', 'HOME') }}/bin/, remote_src=True, extra_opts=['--exclude', 'README.md', '--exclude', 'LICENSE']] *** Monday 23 February 2026 08:55:49 +0000 (0:00:00.728) 0:00:17.001 ******* Monday 23 February 2026 08:55:49 +0000 (0:00:00.728) 0:00:17.000 ******* changed: [localhost] =>   changed: true  dest: /home/zuul/bin/  extract_results:  cmd:  - /usr/bin/gtar  - --extract  - -C  - /home/zuul/bin  - -z  - --show-transformed-names  - --exclude  - README.md  - --exclude  - LICENSE  - -f  - /home/zuul/.ansible/tmp/ansible-tmp-1771836949.3651223-31236-178224391343969/chainsaw_linux_amd64qsjmdbrz.tar.gz  err: ''  out: ''  rc: 0  gid: 1000  group: zuul  handler: TgzArchive  mode: '0755'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 150  src: /home/zuul/.ansible/tmp/ansible-tmp-1771836949.3651223-31236-178224391343969/chainsaw_linux_amd64qsjmdbrz.tar.gz  state: directory  uid: 1000 TASK [download_tools : Download and extract yq src=https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64.tar.gz, dest={{ lookup('env', 'HOME') }}/bin/, remote_src=True, mode=0755] *** Monday 23 February 2026 08:55:52 +0000 (0:00:03.051) 0:00:20.052 ******* Monday 23 February 2026 08:55:52 +0000 (0:00:03.051) 0:00:20.052 ******* changed: [localhost] =>   changed: true  dest: /home/zuul/bin/  extract_results:  cmd:  - /usr/bin/gtar  - --extract  - -C  - /home/zuul/bin  - -z  - -f  - /home/zuul/.ansible/tmp/ansible-tmp-1771836952.4145498-31266-52260709247194/yq_linux_amd64kjpzg1co.tar.gz  err: ''  out: ''  rc: 0  gid: 1000  group: zuul  handler: TgzArchive  mode: '0755'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 4096  src: /home/zuul/.ansible/tmp/ansible-tmp-1771836952.4145498-31266-52260709247194/yq_linux_amd64kjpzg1co.tar.gz  state: directory  uid: 1000 TASK [download_tools : Link yq_linux_amd64 as yq src={{ lookup('env', 'HOME') }}/bin/yq_linux_amd64, dest={{ lookup('env', 'HOME') }}/bin/yq, state=link] *** Monday 23 February 2026 08:55:53 +0000 (0:00:01.188) 0:00:21.241 ******* Monday 23 February 2026 08:55:53 +0000 (0:00:01.188) 0:00:21.240 ******* changed: [localhost] =>   changed: true  dest: /home/zuul/bin/yq  gid: 1000  group: zuul  mode: '0777'  owner: zuul  secontext: unconfined_u:object_r:home_bin_t:s0  size: 29  src: /home/zuul/bin/yq_linux_amd64  state: link  uid: 1000 TASK [download_tools : Deinstall golang state=absent, name=['golang-bin', 'golang-src', 'golang']] *** Monday 23 February 2026 08:55:53 +0000 (0:00:00.197) 0:00:21.438 ******* Monday 23 February 2026 08:55:53 +0000 (0:00:00.197) 0:00:21.438 ******* ok: [localhost] =>   changed: false  msg: Nothing to do  rc: 0  results: [] TASK [download_tools : Delete old go version installed from upstream path={{ item }}, state=absent] *** Monday 23 February 2026 08:55:54 +0000 (0:00:01.124) 0:00:22.563 ******* Monday 23 February 2026 08:55:54 +0000 (0:00:01.124) 0:00:22.562 ******* ok: [localhost] => (item=/usr/local/go) =>   ansible_loop_var: item  changed: false  item: /usr/local/go  path: /usr/local/go  state: absent ok: [localhost] => (item=/home/zuul/bin/go) =>   ansible_loop_var: item  changed: false  item: /home/zuul/bin/go  path: /home/zuul/bin/go  state: absent ok: [localhost] => (item=/home/zuul/bin/gofmt) =>   ansible_loop_var: item  changed: false  item: /home/zuul/bin/gofmt  path: /home/zuul/bin/gofmt  state: absent ok: [localhost] => (item=/usr/local/bin/go) =>   ansible_loop_var: item  changed: false  item: /usr/local/bin/go  path: /usr/local/bin/go  state: absent ok: [localhost] => (item=/usr/local/bin/gofmt) =>   ansible_loop_var: item  changed: false  item: /usr/local/bin/gofmt  path: /usr/local/bin/gofmt  state: absent TASK [download_tools : Download and extract golang src=https://golang.org/dl/go{{ go_version }}.linux-amd64.tar.gz, dest=/usr/local, remote_src=True, extra_opts=['--exclude', 'go/misc', '--exclude', 'go/pkg/linux_amd64_race', '--exclude', 'go/test']] *** Monday 23 February 2026 08:55:56 +0000 (0:00:01.313) 0:00:23.876 ******* Monday 23 February 2026 08:55:56 +0000 (0:00:01.313) 0:00:23.875 ******* changed: [localhost] =>   changed: true  dest: /usr/local  extract_results:  cmd:  - /bin/gtar  - --extract  - -C  - /usr/local  - -z  - --show-transformed-names  - --exclude  - go/misc  - --exclude  - go/pkg/linux_amd64_race  - --exclude  - go/test  - -f  - /home/zuul/.ansible/tmp/ansible-tmp-1771836956.24112-31329-153819978278590/go1.24.6.linux-amd64e225jh3v.tar.gz  err: ''  out: ''  rc: 0  gid: 0  group: root  handler: TgzArchive  mode: '0755'  owner: root  secontext: system_u:object_r:usr_t:s0  size: 141  src: /home/zuul/.ansible/tmp/ansible-tmp-1771836956.24112-31329-153819978278590/go1.24.6.linux-amd64e225jh3v.tar.gz  state: directory  uid: 0 TASK [download_tools : Set alternatives link to installed go version _raw_params=set -e update-alternatives --install /usr/local/bin/{{ item }} {{ item }} /usr/local/go/bin/{{ item }} 1 ] *** Monday 23 February 2026 08:56:08 +0000 (0:00:12.719) 0:00:36.595 ******* Monday 23 February 2026 08:56:08 +0000 (0:00:12.719) 0:00:36.595 ******* changed: [localhost] => (item=go) =>   ansible_loop_var: item  changed: true  cmd: |  set -e  update-alternatives --install /usr/local/bin/go go /usr/local/go/bin/go 1  delta: '0:00:00.006318'  end: '2026-02-23 08:56:09.191290'  item: go  msg: ''  rc: 0  start: '2026-02-23 08:56:09.184972'  stderr: ''  stderr_lines: []  stdout: ''  stdout_lines: [] changed: [localhost] => (item=gofmt) =>   ansible_loop_var: item  changed: true  cmd: |  set -e  update-alternatives --install /usr/local/bin/gofmt gofmt /usr/local/go/bin/gofmt 1  delta: '0:00:00.004015'  end: '2026-02-23 08:56:09.352022'  item: gofmt  msg: ''  rc: 0  start: '2026-02-23 08:56:09.348007'  stderr: ''  stderr_lines: []  stdout: ''  stdout_lines: [] TASK [download_tools : Clean bash cache msg=When move from rpm to upstream version, make sure to clean bash cache using `hash -d go`] *** Monday 23 February 2026 08:56:09 +0000 (0:00:00.442) 0:00:37.038 ******* Monday 23 February 2026 08:56:09 +0000 (0:00:00.442) 0:00:37.037 ******* ok: [localhost] =>   msg: When move from rpm to upstream version, make sure to clean bash cache using `hash  -d go` PLAY RECAP ********************************************************************* localhost : ok=21  changed=12  unreachable=0 failed=0 skipped=2  rescued=0 ignored=0 Monday 23 February 2026 08:56:09 +0000 (0:00:00.067) 0:00:37.106 ******* =============================================================================== download_tools : Download and extract golang --------------------------- 12.72s download_tools : Download and extract oc-mirror ------------------------- 8.01s download_tools : Install build dependencies ----------------------------- 3.67s download_tools : Download chainsaw -------------------------------------- 3.05s download_tools : Download operator-sdk ---------------------------------- 1.34s download_tools : Delete old go version installed from upstream ---------- 1.31s download_tools : Download opm ------------------------------------------- 1.21s download_tools : Download and extract yq -------------------------------- 1.19s download_tools : Deinstall golang --------------------------------------- 1.12s download_tools : Download and extract kustomize ------------------------- 1.05s download_tools : Download kuttl ----------------------------------------- 0.73s download_tools : Set alternatives link to installed go version ---------- 0.44s download_tools : Download kubectl --------------------------------------- 0.33s download_tools : Create $HOME/bin dir ----------------------------------- 0.28s download_tools : Link yq_linux_amd64 as yq ------------------------------ 0.20s download_tools : Make oc-mirror executable ------------------------------ 0.17s download_tools : Clean bash cache --------------------------------------- 0.07s download_tools : Set operator-sdk file for version >= 1.3.0 ------------- 0.04s download_tools : Get version from sdk_version --------------------------- 0.03s download_tools : Set operator-sdk file for version < 1.3.0 -------------- 0.03s Monday 23 February 2026 08:56:09 +0000 (0:00:00.068) 0:00:37.106 ******* =============================================================================== download_tools --------------------------------------------------------- 37.07s ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ total ------------------------------------------------------------------ 37.07s ~/ci-framework-data/artifacts