mirror of
https://github.com/kubernetes-sigs/kubespray.git
synced 2026-06-09 00:46:18 -02:30
* 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>
59 lines
1.9 KiB
YAML
59 lines
1.9 KiB
YAML
---
|
|
|
|
- name: Create image directory
|
|
file:
|
|
state: directory
|
|
path: "{{ images_dir }}"
|
|
mode: 0755
|
|
|
|
- name: Download images files
|
|
get_url:
|
|
url: "{{ item.value.url }}"
|
|
dest: "{{ images_dir }}/{{ item.value.filename }}"
|
|
checksum: "{{ item.value.checksum }}"
|
|
mode: 0644
|
|
loop: "{{ images|dict2items }}"
|
|
|
|
- name: Unxz compressed images
|
|
command: unxz --force {{ images_dir }}/{{ item.value.filename }}
|
|
loop: "{{ images|dict2items }}"
|
|
when:
|
|
- item.value.filename.endswith('.xz')
|
|
|
|
- name: Convert images which is not in qcow2 format
|
|
command: qemu-img convert -O qcow2 {{ images_dir }}/{{ item.value.filename.rstrip('.xz') }} {{ images_dir }}/{{ item.key }}.qcow2
|
|
loop: "{{ images|dict2items }}"
|
|
when:
|
|
- not (item.value.converted|bool)
|
|
|
|
- name: Make sure all images are ending with qcow2
|
|
command: cp {{ images_dir }}/{{ item.value.filename.rstrip('.xz') }} {{ images_dir }}/{{ item.key }}.qcow2
|
|
loop: "{{ images|dict2items }}"
|
|
when:
|
|
- item.value.converted|bool
|
|
|
|
- name: Resize images # noqa 301
|
|
command: qemu-img resize {{ images_dir }}/{{ item.key }}.qcow2 +8G
|
|
loop: "{{ images|dict2items }}"
|
|
|
|
# STEP 2: Include the images inside a container
|
|
- name: Template default Dockerfile
|
|
template:
|
|
src: Dockerfile
|
|
dest: "{{ images_dir }}/Dockerfile"
|
|
mode: 0644
|
|
|
|
- name: Create docker images for each OS # noqa 301
|
|
command: docker build -t {{ registry }}/vm-{{ item.key }}:{{ item.value.tag }} --build-arg cloud_image="{{ item.key }}.qcow2" {{ images_dir }}
|
|
loop: "{{ images|dict2items }}"
|
|
|
|
- name: docker login # noqa 301
|
|
command: docker login -u="{{ docker_user }}" -p="{{ docker_password }}" "{{ docker_host }}"
|
|
|
|
- name: docker push image # noqa 301
|
|
command: docker push {{ registry }}/vm-{{ item.key }}:{{ item.value.tag }}
|
|
loop: "{{ images|dict2items }}"
|
|
|
|
- name: docker logout # noqa 301
|
|
command: docker logout -u="{{ docker_user }}" "{{ docker_host }}"
|