diff --git a/roles/download/tasks/main.yml b/roles/download/tasks/main.yml
index 3942283547e49aeb9bf3e6db1d42310799868dcc..e20945af3c12f649c20da377283253155c4091ea 100644
--- a/roles/download/tasks/main.yml
+++ b/roles/download/tasks/main.yml
@@ -25,7 +25,7 @@
 
 - name: download | Download files / images
   include_tasks: "{{ include_file }}"
-  with_dict: "{{ downloads | combine(kubeadm_images) }}"
+  loop: "{{ downloads | combine(kubeadm_images) | dict2items }}"
   vars:
     download: "{{ download_defaults | combine(item.value) }}"
     include_file: "download_{% if download.container %}container{% else %}file{% endif %}.yml"
diff --git a/roles/kubernetes/preinstall/tasks/0090-etchosts.yml b/roles/kubernetes/preinstall/tasks/0090-etchosts.yml
index 81913cb104f8b85b014315f125a022471d1b9c48..491d24a6aba0b7fde207b69bfb4694083a3cc578 100644
--- a/roles/kubernetes/preinstall/tasks/0090-etchosts.yml
+++ b/roles/kubernetes/preinstall/tasks/0090-etchosts.yml
@@ -56,7 +56,7 @@
     etc_hosts_localhosts_dict_target: >-
       {%- set target_entries = (etc_hosts_localhosts_dict|default({})).get(item.key, []) | difference(item.value.get('unexpected' ,[])) -%}
       {{ etc_hosts_localhosts_dict_target|default({}) | combine({item.key: (target_entries + item.value.expected)|unique}) }}
-  with_dict: "{{ etc_hosts_localhost_entries }}"
+  loop: "{{ etc_hosts_localhost_entries|dict2items }}"
 
 - name: Hosts | Update (if necessary) hosts file
   lineinfile:
@@ -66,7 +66,7 @@
     state: present
     backup: yes
     unsafe_writes: yes
-  with_dict: "{{ etc_hosts_localhosts_dict_target }}"
+  loop: "{{ etc_hosts_localhosts_dict_target|dict2items }}"
 
 # gather facts to update ansible_fqdn
 - name: Update facts
diff --git a/test-infra/image-builder/roles/kubevirt-images/tasks/main.yml b/test-infra/image-builder/roles/kubevirt-images/tasks/main.yml
index 95ce250a4991d2744d6dfe7a75fb1fa04be8f3f2..e2ef4e8fc7855ea6f2b53f4d900d2ee2e7f9fb67 100644
--- a/test-infra/image-builder/roles/kubevirt-images/tasks/main.yml
+++ b/test-infra/image-builder/roles/kubevirt-images/tasks/main.yml
@@ -10,34 +10,29 @@
     url: "{{ item.value.url }}"
     dest: "{{ images_dir }}/{{ item.value.filename }}"
     checksum: "{{ item.value.checksum }}"
-  with_dict:
-    - "{{ images }}"
+  loop: "{{ images|dict2items }}"
 
 - name: Unxz compressed images
   command: unxz --force {{ images_dir }}/{{ item.value.filename }}
-  with_dict:
-    - "{{ images }}"
+  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
-  with_dict:
-    - "{{ images }}"
+  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
-  with_dict:
-    - "{{ images }}"
+  loop: "{{ images|dict2items }}"
   when:
     - item.value.converted|bool
 
 - name: Resize images  # noqa 301
   command: qemu-img resize {{ images_dir }}/{{ item.key }}.qcow2 +8G
-  with_dict:
-    - "{{ images }}"
+  loop: "{{ images|dict2items }}"
 
 # STEP 2: Include the images inside a container
 - name: Template default Dockerfile
@@ -47,16 +42,14 @@
 
 - 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 }}
-  with_dict:
-    - "{{ images }}"
+  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 }}
-  with_dict:
-    - "{{ images }}"
+  loop: "{{ images|dict2items }}"
 
 - name: docker logout  # noqa 301
   command: docker logout -u="{{ docker_user }}" "{{ docker_host }}"