From 29c986f85d48b6ef47a3b8374567eb1369cc311d Mon Sep 17 00:00:00 2001 From: Karel Simon Date: Mon, 14 Oct 2024 13:11:20 +0200 Subject: [PATCH] feat!: remove centos7 and centos 8 stream templates These OSes are no longer supported Signed-off-by: Karel Simon --- README.md | 2 - automation/test-linux.sh | 2 +- generate-templates.yaml | 58 ----------- templates/centos-stream8.tpl.yaml | 165 ------------------------------ templates/centos7.tpl.yaml | 165 ------------------------------ 5 files changed, 1 insertion(+), 391 deletions(-) delete mode 100644 templates/centos-stream8.tpl.yaml delete mode 100644 templates/centos7.tpl.yaml diff --git a/README.md b/README.md index 544edb7d..b76fe55a 100644 --- a/README.md +++ b/README.md @@ -83,8 +83,6 @@ The table below lists the guest operating systems that are covered by the templa | Red Hat Enterprise Linux 9 | [rhel9](templates/rhel9.tpl.yaml) | | Ubuntu | [ubuntu](templates/ubuntu.tpl.yaml) | | openSUSE Leap | [opensuse](templates/opensuse.tpl.yaml) | -| CentOS 7 | [centos7](templates/centos7.tpl.yaml) | -| CentOS Stream 8 | [centos-stream8](templates/centos-stream8.tpl.yaml) | | CentOS Stream 9 | [centos-stream9](templates/centos-stream9.tpl.yaml) | ## License diff --git a/automation/test-linux.sh b/automation/test-linux.sh index 47c65021..6991dfc7 100755 --- a/automation/test-linux.sh +++ b/automation/test-linux.sh @@ -80,7 +80,7 @@ if [[ $TARGET =~ opensuse.* ]]; then workloads=("server") fi -if [[ $TARGET =~ centos7.* ]] || [[ $TARGET =~ centos-stream.* ]]; then +if [[ $TARGET =~ centos-stream.* ]]; then workloads=("server" "desktop") fi diff --git a/generate-templates.yaml b/generate-templates.yaml index b8c73893..67e2e5d8 100644 --- a/generate-templates.yaml +++ b/generate-templates.yaml @@ -113,35 +113,6 @@ cloudusername: cloud-user image_urls: "{{ rhel7_image_urls }}" - - name: Load CentOS Stream 8 containerdisk and image urls - set_fact: - centos8stream_containerdisk_urls: "{{ lookup('osinfo', 'centos-stream8') |attr('image_list') |selectattr('architecture', 'eq', 'x86_64') |selectattr('format', 'eq', 'containerdisk') |map(attribute='url') |map('replace', 'docker://', '') |list }}" - centos8stream_image_urls: "{{ lookup('osinfo', 'centos-stream8') |attr('image_list') |selectattr('architecture', 'eq', 'x86_64') |selectattr('format', 'in', ['raw', 'qcow2']) |map(attribute='url') |list }}" - - - name: Generate CentOS Stream 8 templates - template: - src: centos-stream8.tpl.yaml - dest: "{{ playbook_dir }}/dist/templates/{{ os }}-{{ item.workload }}-{{ item.flavor }}.yaml" - with_items: - - {flavor: tiny, workload: server, memsize: "1.5Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: tiny, workload: desktop, memsize: "1.5Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: small, workload: server, memsize: "2Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: True} - - {flavor: small, workload: desktop, memsize: "2Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: medium, workload: server, memsize: "4Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: medium, workload: desktop, memsize: "4Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: large, workload: server, memsize: "8Gi", cpus: 2, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: large, workload: desktop, memsize: "8Gi", cpus: 2, iothreads: False, emulatorthread: False, tablet: True, default: False} - vars: - os: centos-stream8 - icon: centos - majorrelease: centos-stream8 - oslabels: - - centos-stream8 - osinfoname: "{{ oslabels[0] }}" - cloudusername: centos - containerdisk_urls: "{{ centos8stream_containerdisk_urls }}" - image_urls: "{{ centos8stream_image_urls }}" - - name: Load CentOS Stream 9 containerdisk and image urls set_fact: centos9stream_containerdisk_urls: "{{ lookup('osinfo', 'centos-stream9') |attr('image_list') |selectattr('architecture', 'eq', 'x86_64') |selectattr('format', 'eq', 'containerdisk') |map(attribute='url') |map('replace', 'docker://', '') |list }}" @@ -171,35 +142,6 @@ containerdisk_urls: "{{ centos9stream_containerdisk_urls }}" image_urls: "{{ centos9stream_image_urls }}" - - name: Load CentOS 7 containerdisk and image urls - set_fact: - centos7_containerdisk_urls: "{{ lookup('osinfo', 'centos7.0') |attr('image_list') |selectattr('architecture', 'eq', 'x86_64') |selectattr('format', 'eq', 'containerdisk') |map(attribute='url') |map('replace', 'docker://', '') |list }}" - centos7_image_urls: "{{ lookup('osinfo', 'centos7.0') |attr('image_list') |selectattr('architecture', 'eq', 'x86_64') |selectattr('format', 'in', ['raw', 'qcow2']) |map(attribute='url') |list }}" - - - name: Generate CentOS 7 templates - template: - src: centos7.tpl.yaml - dest: "{{ playbook_dir }}/dist/templates/{{ os }}-{{ item.workload }}-{{ item.flavor }}.yaml" - with_items: - - {flavor: tiny, workload: server, memsize: "1Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: tiny, workload: desktop, memsize: "1Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: small, workload: server, memsize: "2Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: True} - - {flavor: small, workload: desktop, memsize: "2Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: medium, workload: server, memsize: "4Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: medium, workload: desktop, memsize: "4Gi", cpus: 1, iothreads: False, emulatorthread: False, tablet: True, default: False} - - {flavor: large, workload: server, memsize: "8Gi", cpus: 2, iothreads: False, emulatorthread: False, tablet: False, default: False} - - {flavor: large, workload: desktop, memsize: "8Gi", cpus: 2, iothreads: False, emulatorthread: False, tablet: True, default: False} - vars: - os: centos7 - icon: centos - majorrelease: centos7 - oslabels: - - centos7.0 - osinfoname: "{{ oslabels[0] }}" - cloudusername: centos - containerdisk_urls: "{{ centos7_containerdisk_urls }}" - image_urls: "{{ centos7_image_urls }}" - - name: Load CentOS 6 versions set_fact: centos6_labels: "{{ lookup('osinfo', 'distro=centos') |map(attribute='short_id') |select('match', '^centos6\\.') |list |sort }}" diff --git a/templates/centos-stream8.tpl.yaml b/templates/centos-stream8.tpl.yaml deleted file mode 100644 index f89504f5..00000000 --- a/templates/centos-stream8.tpl.yaml +++ /dev/null @@ -1,165 +0,0 @@ -apiVersion: template.openshift.io/v1 -kind: Template -metadata: - name: {{ os }}-{{ item.workload }}-{{ item.flavor }} - annotations: - template.kubevirt.io/deprecated: "true" - openshift.io/display-name: "CentOS Stream 8 VM" - description: >- - Template for CentOS Stream 8 VM or newer. - A PVC with the CentOS Stream disk image must be available. - tags: "hidden,kubevirt,virtualmachine,linux,centosstream" - iconClass: "icon-{{ icon }}" - openshift.io/provider-display-name: "KubeVirt" - openshift.io/documentation-url: "https://github.com/kubevirt/common-templates" - openshift.io/support-url: "https://github.com/kubevirt/common-templates/issues" - template.openshift.io/bindable: "false" - template.kubevirt.io/version: v1alpha1 - defaults.template.kubevirt.io/disk: rootdisk -{% if containerdisk_urls | length > 0 %} - template.kubevirt.io/containerdisks: | -{% for url in containerdisk_urls %} - {{ url }} -{% endfor %} -{% endif %} -{% if image_urls | length > 0 %} - template.kubevirt.io/images: | -{% for url in image_urls %} - {{ url }} -{% endfor %} -{% endif %} - template.kubevirt.io/editable: | - /objects[0].spec.template.spec.domain.cpu.sockets - /objects[0].spec.template.spec.domain.cpu.cores - /objects[0].spec.template.spec.domain.cpu.threads - /objects[0].spec.template.spec.domain.memory.guest - /objects[0].spec.template.spec.domain.devices.disks - /objects[0].spec.template.spec.volumes - /objects[0].spec.template.spec.networks -{% for osl in oslabels %} - name.os.template.kubevirt.io/{{ osl }}: {{ lookup('osinfo', oslabels[0]).name }} or higher -{% endfor %} - labels: -{% for osl in oslabels %} - os.template.kubevirt.io/{{ osl }}: "true" -{% endfor %} - workload.template.kubevirt.io/{{ item.workload }}: "true" - flavor.template.kubevirt.io/{{ item.flavor }}: "true" - template.kubevirt.io/type: "base" - template.kubevirt.io/version: "{{ lookup('env', 'VERSION') | default('devel', true) }}" -{% if item.default %} - template.kubevirt.io/default-os-variant: "true" -{% endif %} -objects: -- apiVersion: kubevirt.io/v1 - kind: VirtualMachine - metadata: - name: ${NAME} - labels: - vm.kubevirt.io/template: {{ os }}-{{ item.workload }}-{{ item.flavor }} - vm.kubevirt.io/template.version: "{{ lookup('env', 'VERSION') | default('devel', true) }}" - vm.kubevirt.io/template.revision: "{{ lookup('env', 'REVISION') | default(1, true) }}" - app: ${NAME} - annotations: - vm.kubevirt.io/validations: | - [ - { - "name": "minimal-required-memory", - "path": "jsonpath::.spec.domain.memory.guest", - "rule": "integer", - "message": "This VM requires more memory.", - "min": {{ lookup('osinfo', osinfoname)["minimum_resources.architecture=x86_64|all.ram"] }} - } - ] - spec: - dataVolumeTemplates: - - apiVersion: cdi.kubevirt.io/v1beta1 - kind: DataVolume - metadata: - name: ${NAME} - spec: - storage: - resources: - requests: - storage: 30Gi - sourceRef: - kind: DataSource - name: ${DATA_SOURCE_NAME} - namespace: ${DATA_SOURCE_NAMESPACE} - runStrategy: Halted - template: - metadata: - annotations: - vm.kubevirt.io/os: "{{ os }}" - vm.kubevirt.io/workload: "{{ item.workload }}" - vm.kubevirt.io/flavor: "{{ item.flavor }}" - labels: - kubevirt.io/domain: ${NAME} - kubevirt.io/size: {{ item.flavor }} - spec: - architecture: amd64 - domain: -{% if item.iothreads %} - ioThreadsPolicy: shared -{% endif %} - cpu: - sockets: {{ item.cpus }} - cores: 1 - threads: 1 -{% if cpumodel |default("") %} - model: {{ cpumodel }} -{% endif %} - memory: - guest: {{ item.memsize }} - devices: - rng: {} -{% if item.cpus > 1 %} - networkInterfaceMultiqueue: true -{% endif %} -{% if item.tablet %} - inputs: - - type: tablet - bus: virtio - name: tablet -{% endif %} - disks: - - disk: - bus: {{ diskbus | default("virtio") }} - name: rootdisk - - disk: - bus: {{ diskbus | default("virtio") }} - name: cloudinitdisk - interfaces: - - masquerade: {} - name: default - model: virtio - terminationGracePeriodSeconds: 180 - networks: - - name: default - pod: {} - volumes: - - dataVolume: - name: ${NAME} - name: rootdisk - - cloudInitNoCloud: - userData: |- - #cloud-config - user: {{ cloudusername }} - password: ${CLOUD_USER_PASSWORD} - chpasswd: { expire: False } - name: cloudinitdisk -parameters: -- description: VM name - from: '{{ os }}-[a-z0-9]{16}' - generate: expression - name: NAME -- name: DATA_SOURCE_NAME - description: Name of the DataSource to clone - value: '{{ majorrelease }}' -- name: DATA_SOURCE_NAMESPACE - description: Namespace of the DataSource - value: kubevirt-os-images -- description: Randomized password for the cloud-init user {{ cloudusername }} - from: '[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}' - generate: expression - name: CLOUD_USER_PASSWORD diff --git a/templates/centos7.tpl.yaml b/templates/centos7.tpl.yaml deleted file mode 100644 index c1243dfa..00000000 --- a/templates/centos7.tpl.yaml +++ /dev/null @@ -1,165 +0,0 @@ -apiVersion: template.openshift.io/v1 -kind: Template -metadata: - name: {{ os }}-{{ item.workload }}-{{ item.flavor }} - annotations: - template.kubevirt.io/deprecated: "true" - openshift.io/display-name: "CentOS 7 VM" - description: >- - Template for CentOS 7 VM or newer. - A PVC with the CentOS disk image must be available. - tags: "hidden,kubevirt,virtualmachine,linux,centos" - iconClass: "icon-{{ icon }}" - openshift.io/provider-display-name: "KubeVirt" - openshift.io/documentation-url: "https://github.com/kubevirt/common-templates" - openshift.io/support-url: "https://github.com/kubevirt/common-templates/issues" - template.openshift.io/bindable: "false" - template.kubevirt.io/version: v1alpha1 - defaults.template.kubevirt.io/disk: rootdisk -{% if containerdisk_urls | length > 0 %} - template.kubevirt.io/containerdisks: | -{% for url in containerdisk_urls %} - {{ url }} -{% endfor %} -{% endif %} -{% if image_urls | length > 0 %} - template.kubevirt.io/images: | -{% for url in image_urls %} - {{ url }} -{% endfor %} -{% endif %} - template.kubevirt.io/editable: | - /objects[0].spec.template.spec.domain.cpu.sockets - /objects[0].spec.template.spec.domain.cpu.cores - /objects[0].spec.template.spec.domain.cpu.threads - /objects[0].spec.template.spec.domain.memory.guest - /objects[0].spec.template.spec.domain.devices.disks - /objects[0].spec.template.spec.volumes - /objects[0].spec.template.spec.networks -{% for osl in oslabels %} - name.os.template.kubevirt.io/{{ osl }}: {{ lookup('osinfo', oslabels[0]).name }} or higher -{% endfor %} - labels: -{% for osl in oslabels %} - os.template.kubevirt.io/{{ osl }}: "true" -{% endfor %} - workload.template.kubevirt.io/{{ item.workload }}: "true" - flavor.template.kubevirt.io/{{ item.flavor }}: "true" - template.kubevirt.io/type: "base" - template.kubevirt.io/version: "{{ lookup('env', 'VERSION') | default('devel', true) }}" -{% if item.default %} - template.kubevirt.io/default-os-variant: "true" -{% endif %} -objects: -- apiVersion: kubevirt.io/v1 - kind: VirtualMachine - metadata: - name: ${NAME} - labels: - vm.kubevirt.io/template: {{ os }}-{{ item.workload }}-{{ item.flavor }} - vm.kubevirt.io/template.version: "{{ lookup('env', 'VERSION') | default('devel', true) }}" - vm.kubevirt.io/template.revision: "{{ lookup('env', 'REVISION') | default(1, true) }}" - app: ${NAME} - annotations: - vm.kubevirt.io/validations: | - [ - { - "name": "minimal-required-memory", - "path": "jsonpath::.spec.domain.memory.guest", - "rule": "integer", - "message": "This VM requires more memory.", - "min": {{ lookup('osinfo', osinfoname)["minimum_resources.architecture=x86_64|all.ram"] }} - } - ] - spec: - dataVolumeTemplates: - - apiVersion: cdi.kubevirt.io/v1beta1 - kind: DataVolume - metadata: - name: ${NAME} - spec: - storage: - resources: - requests: - storage: 30Gi - sourceRef: - kind: DataSource - name: ${DATA_SOURCE_NAME} - namespace: ${DATA_SOURCE_NAMESPACE} - runStrategy: Halted - template: - metadata: - annotations: - vm.kubevirt.io/os: "{{ os }}" - vm.kubevirt.io/workload: "{{ item.workload }}" - vm.kubevirt.io/flavor: "{{ item.flavor }}" - labels: - kubevirt.io/domain: ${NAME} - kubevirt.io/size: {{ item.flavor }} - spec: - architecture: amd64 - domain: -{% if item.iothreads %} - ioThreadsPolicy: shared -{% endif %} - cpu: - sockets: {{ item.cpus }} - cores: 1 - threads: 1 -{% if cpumodel |default("") %} - model: {{ cpumodel }} -{% endif %} - memory: - guest: {{ item.memsize }} - devices: - rng: {} -{% if item.cpus > 1 %} - networkInterfaceMultiqueue: true -{% endif %} -{% if item.tablet %} - inputs: - - type: tablet - bus: virtio - name: tablet -{% endif %} - disks: - - disk: - bus: {{ diskbus | default("virtio") }} - name: rootdisk - - disk: - bus: {{ diskbus | default("virtio") }} - name: cloudinitdisk - interfaces: - - masquerade: {} - name: default - model: virtio - terminationGracePeriodSeconds: 180 - networks: - - name: default - pod: {} - volumes: - - dataVolume: - name: ${NAME} - name: rootdisk - - cloudInitNoCloud: - userData: |- - #cloud-config - user: {{ cloudusername }} - password: ${CLOUD_USER_PASSWORD} - chpasswd: { expire: False } - name: cloudinitdisk -parameters: -- description: VM name - from: '{{ os }}-[a-z0-9]{16}' - generate: expression - name: NAME -- name: DATA_SOURCE_NAME - description: Name of the DataSource to clone - value: '{{ majorrelease }}' -- name: DATA_SOURCE_NAMESPACE - description: Namespace of the DataSource - value: kubevirt-os-images -- description: Randomized password for the cloud-init user {{ cloudusername }} - from: '[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}' - generate: expression - name: CLOUD_USER_PASSWORD