Check blocks recursively for loops

Also updates tests for the custom ansible-lint rules.

Adds a simple testsuite so test roles and playbooks that are known to be
faulty or valid can be put in a directory structure like:

<rule id>/valid/playbooks/valid_playbook.yaml
<rule id>/valid/roles/valid_role/tasks/main.yaml
<rule id>/valid/roles/valid_role/handlers/main.yaml

<rule id>/faulty/playbooks/faulty_playbook.yaml
<rule id>/faulty/roles/faulty_role/tasks/main.yaml
<rule id>/faulty/roles/faulty_role/handlers/main.yaml

So they will verify that the rules work as expected.

Change-Id: I29d0766c67e690e35490586f6befb95e4cd31b98
This commit is contained in:
Albin Vass 2020-05-02 11:29:18 +02:00
parent dd8e831379
commit 9ad8c11469
20 changed files with 97 additions and 22 deletions

View File

@ -20,6 +20,25 @@ https://zuul-ci.org/docs/zuul-jobs/policy.html\
if file.get('type') not in ('tasks', 'handlers'): if file.get('type') not in ('tasks', 'handlers'):
return results return results
results.extend(self.handle_play(task))
return results
def handle_play(self, task):
results = []
if 'block' in task:
results.extend(self.handle_playlist(task['block']))
else:
results.extend(self.handle_task(task))
return results
def handle_playlist(self, playlist):
results = []
for play in playlist:
results.extend(self.handle_play(play))
return results
def handle_task(self, task):
results = []
has_loop = 'loop' in task has_loop = 'loop' in task
for key in task.keys(): for key in task.keys():
if key.startswith('with_'): if key.startswith('with_'):

View File

@ -0,0 +1,6 @@
- block:
- debug:
var: item
loop:
- 1
- 2

View File

@ -0,0 +1,6 @@
- block:
- debug:
var: item
with_items:
- 1
- 2

View File

@ -0,0 +1,7 @@
- block:
- block:
- debug:
var: item
loop:
- 1
- 2

View File

@ -0,0 +1,8 @@
- block:
- debug:
msg: zj_item
loop:
- 1
- 2
loop_control:
loop_var: zj_item

View File

@ -0,0 +1,8 @@
- block:
- debug:
msg: zj_item
with_items:
- 1
- 2
loop_control:
loop_var: zj_item

View File

@ -0,0 +1,5 @@
- debug: # noqa ZUULJOBS0001
var: item
loop:
- 1
- 2

View File

@ -15,28 +15,44 @@
- name: Make sure ansible-lint is installed - name: Make sure ansible-lint is installed
command: "{{ ansible_lint_tempdir.path }}/bin/ansible-lint --version" command: "{{ ansible_lint_tempdir.path }}/bin/ansible-lint --version"
- name: Make sure missing loopvars fail linting - name: Get faulty playbooks and roles
command: "{{ ansible_lint_tempdir.path }}/bin/ansible-lint test-playbooks/ansible-lint-rules/roles/{{ item }}" command: >-
find test-playbooks/ansible-lint-rules/
-mindepth 4
-maxdepth 4
-wholename '*ZUULJOBS*/faulty/*/*'
args:
chdir: "{{ ansible_user_dir}}/{{ zuul.project.src_dir }}"
register: faulty_ansible_items
- name: Get valid playbooks and roles
command: >-
find test-playbooks/ansible-lint-rules/
-mindepth 4
-maxdepth 4
-wholename '*ZUULJOBS*/valid/roles/*'
args:
chdir: "{{ ansible_user_dir}}/{{ zuul.project.src_dir }}"
register: valid_ansible_items
- name: Make sure faulty roles fail linting
command: >-
{{ ansible_lint_tempdir.path }}/bin/ansible-lint
-t {{ item | regex_replace('.*/(ZUULJOBS.*?)/.*', '\1') }}
{{ item }}
args: args:
chdir: "{{ ansible_user_dir }}/{{ zuul.project.src_dir }}" chdir: "{{ ansible_user_dir }}/{{ zuul.project.src_dir }}"
register: ansible_lint register: ansible_lint
failed_when: ansible_lint.rc == 0 failed_when: ansible_lint.rc == 0
loop: loop: "{{ faulty_ansible_items.stdout_lines }}"
- tasks-missing-loopvar-with
- tasks-missing-loopvar-loop
- tasks-include-missing-loopvar-with
- tasks-include-missing-loopvar-loop
- handlers-missing-loopvar-with
- handlers-missing-loopvar-loop
- name: Make sure valid configuration passes linting - name: Make sure valid roles pass linting
command: "{{ ansible_lint_tempdir.path }}/bin/ansible-lint test-playbooks/ansible-lint-rules/roles/{{ item }}" command: >-
{{ ansible_lint_tempdir.path }}/bin/ansible-lint
-t {{ item | regex_replace('.*/(ZUULJOBS.*?)/.*', '\1') }}
{{ item }}
args: args:
chdir: "{{ansible_user_dir}}/{{ zuul.project.src_dir }}" chdir: "{{ansible_user_dir}}/{{ zuul.project.src_dir }}"
loop: register: ansible_lint
- tasks-loopvar-with failed_when: ansible_lint.rc != 0
- tasks-loopvar-loop loop: "{{ valid_ansible_items.stdout_lines }}"
- tasks-include-loopvar-with
- tasks-include-loopvar-loop
- handlers-loopvar-with
- handlers-loopvar-loop