diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index bbd7344600e011107766d42b521651865932163d..d0d382942cbaed1d37acad7e51fa031264a362e3 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -15,6 +15,7 @@ variables: stages: - syntax-check - lint-tests + - molecule ### ### SYNTAX-CHECK @@ -72,7 +73,7 @@ syntax-check-docker-containers: ### ### LINT-TESTS ### -role-test: +lint-test: stage: lint-tests before_script: - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* @@ -82,7 +83,7 @@ role-test: - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_TEST allow_failure: false -role-dependencies: +lint-dependencies: stage: lint-tests before_script: - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* @@ -92,7 +93,7 @@ role-dependencies: - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_DEPENDENCIES allow_failure: false -role-clone-repositories: +lint-clone-repositories: stage: lint-tests before_script: - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* @@ -102,7 +103,7 @@ role-clone-repositories: - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_CLONE_REPOSITORIES allow_failure: false -role-docker-images: +lint-docker-images: stage: lint-tests before_script: - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* @@ -112,7 +113,7 @@ role-docker-images: - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_DOCKER_IMAGES allow_failure: false -role-docker-containers: +lint-docker-containers: stage: lint-tests before_script: - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* @@ -121,3 +122,20 @@ role-docker-containers: - echo "Running ansible-lint tests at the role-> 'docker_containers'" - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_DOCKER_CONTAINERS allow_failure: false + + +### +### molecule +### +molecule-test: + stage: molecule + before_script: + - apt-get update && apt-get install -y python3-pip && apt-get clean && rm -rf /var/lib/apt/lists/* + - pip3 install -r ci-cd/requirements.txt + - pip3 install --upgrade molecule molecule-docker + # - python3 -m pip install --user "molecule-plugins[docker] + - pip3 install --user "molecule-plugins[docker] + script: + - echo "Running ansible-lint tests at the role-> 'test'" + - ansible-lint $PLAYBOOK_PATH_FOR_ROLE_TEST + allow_failure: false diff --git a/roles/test/defaults/main.yml b/roles/test/defaults/main.yml index 7ec0ac3345d6f65e42a93d6672af8c4a1b9b3acd..9c8dd30304fe755907bd1212c4e6fdf95123a598 100644 --- a/roles/test/defaults/main.yml +++ b/roles/test/defaults/main.yml @@ -2,5 +2,4 @@ # defaults file for test var_setted_everywhere: "answer from roles/test/defaults/main.yml" - var_setted_only_defaults_main: "MESSAGE FROM roles/test/defaults/main.yml" diff --git a/roles/test/molecule/default/converge.yml b/roles/test/molecule/default/converge.yml new file mode 100644 index 0000000000000000000000000000000000000000..7cbd7c0a18ee3fcae421ad6acb033e95aaf1f4e2 --- /dev/null +++ b/roles/test/molecule/default/converge.yml @@ -0,0 +1,5 @@ +--- +- name: MOLECULE | Converge + hosts: all + roles: + - role: test diff --git a/roles/test/molecule/default/inventory/group_vars/example_servers_group.yml b/roles/test/molecule/default/inventory/group_vars/example_servers_group.yml new file mode 100644 index 0000000000000000000000000000000000000000..7ba656ace1512ccd819336f8d3a48f73e976d964 --- /dev/null +++ b/roles/test/molecule/default/inventory/group_vars/example_servers_group.yml @@ -0,0 +1,2 @@ +var_setted_only_group_vars: "group_vars_value" +var_setted_everywhere: "group_vars_value" diff --git a/roles/test/molecule/default/inventory/host_vars/example_server.yml b/roles/test/molecule/default/inventory/host_vars/example_server.yml new file mode 100644 index 0000000000000000000000000000000000000000..3ed6bf4d74dca02fe60cdca10096f343d0495ba8 --- /dev/null +++ b/roles/test/molecule/default/inventory/host_vars/example_server.yml @@ -0,0 +1,2 @@ +var_setted_only_host_vars: "host_vars_value" +var_setted_everywhere: "host_vars_value" diff --git a/roles/test/molecule/default/molecule.yml b/roles/test/molecule/default/molecule.yml new file mode 100644 index 0000000000000000000000000000000000000000..55eb160602fa451432faa04e7861ad8a9ac47110 --- /dev/null +++ b/roles/test/molecule/default/molecule.yml @@ -0,0 +1,37 @@ +--- +dependency: + name: galaxy +driver: + name: docker +platforms: + - name: instance + image: geerlingguy/docker-ubuntu2004-ansible:latest + # privileged: true + pre_build_image: true +provisioner: + name: ansible + lint: + name: ansible-lint + inventory: + group_vars: + example_servers_group: + var_setted_only_group_vars: "group_vars_value" + var_setted_everywhere: "group_vars_value" + host_vars: + instance: + var_setted_only_host_vars: "host_vars_value" + var_setted_everywhere: "host_vars_value" +verifier: + name: ansible + ### + # lint: + # name: ansible-lint + ### + # playbook: verify.yml + ### + # Remove the 'playbooks' key and use 'playbooks' directly under 'verifier' + # playbooks: + # verify: verify.yml + ### + # lint: + # name: flake8 diff --git a/roles/test/molecule/default/tests/test_default.yml b/roles/test/molecule/default/tests/test_default.yml new file mode 100644 index 0000000000000000000000000000000000000000..75dae12c11148a5ae5c21b97f96bc5d5bc32057c --- /dev/null +++ b/roles/test/molecule/default/tests/test_default.yml @@ -0,0 +1,34 @@ +--- +- name: MOLECULE | Test role for debugging variables + hosts: all + tasks: + - name: MOLECULE | TESTS | Test parsed variable setted only at roles/test/defaults/main.yml + ansible.builtin.debug: + msg: "{{ var_setted_only_defaults_main }}" + + - name: MOLECULE | TESTS | Test parsed variable setted only at roles/test/vars/main.yml + ansible.builtin.debug: + msg: "{{ var_setted_only_vars_main }}" + + - name: MOLECULE | TESTS | Test parsed variable setted only at inventory/group_vars/example_servers_group.yml + ansible.builtin.debug: + msg: "{{ var_setted_only_group_vars }}" + when: var_setted_only_group_vars is defined + + - name: MOLECULE | TESTS | Test parsed variable setted only at inventory/host_vars/example_server.yml + ansible.builtin.debug: + msg: "{{ var_setted_only_host_vars }}" + + - name: MOLECULE | TESTS | Test parsed variable setted EVERYWHERE -> should come from roles/test/vars/main.yml + ansible.builtin.debug: + msg: "{{ var_setted_everywhere }}" + + - name: MOLECULE | TESTS | List the root ('/') folder from the target to a register + ansible.builtin.command: + cmd: ls -hal / + register: ret_list_folder + changed_when: false + + - name: MOLECULE | TESTS | Shows output from listing folder + ansible.builtin.debug: + msg: "{{ ret_list_folder }}" diff --git a/roles/test/tasks/main.yml b/roles/test/tasks/main.yml index 231332ebcb0b4a807ddd486fa62f2186f6e52d03..3e7e633615708d3a17a07bcb244ec0779c8725ac 100644 --- a/roles/test/tasks/main.yml +++ b/roles/test/tasks/main.yml @@ -1,8 +1,6 @@ --- # tasks file for test -# - import_tasks: test_task.yml - - name: Test parsed variable setted only at roles/test/defaults/main.yml ansible.builtin.debug: msg: "{{ var_setted_only_defaults_main }}" @@ -14,6 +12,7 @@ - name: Test parsed variable setted only at inventory/group_vars/example_servers_group.yml ansible.builtin.debug: msg: "{{ var_setted_only_group_vars }}" + when: var_setted_only_group_vars is defined - name: Test parsed variable setted only at inventory/host_vars/example_server.yml ansible.builtin.debug: @@ -27,7 +26,7 @@ ansible.builtin.command: cmd: ls -hal / register: ret_list_folder - changed_when: ret_list_folder.rc != 0 + changed_when: false - name: Shows output from listing folder ansible.builtin.debug: diff --git a/roles/test/vars/main.yml b/roles/test/vars/main.yml index 9fbe7d9e7123fee461a946fd278bec3fed65d262..76a45cb0672a680111467fd9d9576ca1e237dce8 100644 --- a/roles/test/vars/main.yml +++ b/roles/test/vars/main.yml @@ -2,5 +2,4 @@ # vars file for test var_setted_everywhere: "MESSAGE EVERYWHERE FROM roles/test/vars/main.yml" - var_setted_only_vars_main: "MESSAGE FROM roles/test/vars/main.yml"