250 lines
8 KiB
YAML
250 lines
8 KiB
YAML
|
---
|
||
|
- hosts: localhost
|
||
|
gather_facts: false
|
||
|
roles:
|
||
|
- { role: a, a_str: "roles" }
|
||
|
|
||
|
vars:
|
||
|
INT_VALUE: 42
|
||
|
|
||
|
tasks:
|
||
|
|
||
|
- name: "Valid simple role usage with include_role"
|
||
|
include_role:
|
||
|
name: a
|
||
|
vars:
|
||
|
a_str: "include_role"
|
||
|
|
||
|
- name: "Valid simple role usage with import_role"
|
||
|
import_role:
|
||
|
name: a
|
||
|
vars:
|
||
|
a_str: "import_role"
|
||
|
|
||
|
- name: "Valid role usage (more args)"
|
||
|
include_role:
|
||
|
name: b
|
||
|
vars:
|
||
|
b_str: "xyz"
|
||
|
b_int: 5
|
||
|
b_bool: true
|
||
|
|
||
|
- name: "Valid simple role usage with include_role of different entry point"
|
||
|
include_role:
|
||
|
name: a
|
||
|
tasks_from: "alternate"
|
||
|
vars:
|
||
|
a_int: 256
|
||
|
|
||
|
- name: "Valid simple role usage with import_role of different entry point"
|
||
|
import_role:
|
||
|
name: a
|
||
|
tasks_from: "alternate"
|
||
|
vars:
|
||
|
a_int: 512
|
||
|
|
||
|
- name: "Valid simple role usage with a templated value"
|
||
|
import_role:
|
||
|
name: a
|
||
|
vars:
|
||
|
a_int: "{{ INT_VALUE }}"
|
||
|
|
||
|
- name: "Call role entry point that is defined, but has no spec data"
|
||
|
import_role:
|
||
|
name: a
|
||
|
tasks_from: "no_spec_entrypoint"
|
||
|
|
||
|
- name: "New play to reset vars: Test include_role fails"
|
||
|
hosts: localhost
|
||
|
gather_facts: false
|
||
|
vars:
|
||
|
expected_returned_spec:
|
||
|
b_bool:
|
||
|
required: true
|
||
|
type: "bool"
|
||
|
b_int:
|
||
|
required: true
|
||
|
type: "int"
|
||
|
b_str:
|
||
|
required: true
|
||
|
type: "str"
|
||
|
|
||
|
tasks:
|
||
|
- block:
|
||
|
- name: "EXPECTED FAILURE: Invalid role usage"
|
||
|
include_role:
|
||
|
name: b
|
||
|
vars:
|
||
|
b_bool: 7
|
||
|
|
||
|
- fail:
|
||
|
msg: "Should not get here"
|
||
|
|
||
|
rescue:
|
||
|
- debug:
|
||
|
var: ansible_failed_result
|
||
|
|
||
|
- name: "Validate failure"
|
||
|
assert:
|
||
|
that:
|
||
|
- ansible_failed_task.name == "Validating arguments against arg spec 'main' - Main entry point for role B."
|
||
|
- ansible_failed_result.argument_errors | length == 2
|
||
|
- "'missing required arguments: b_int, b_str' in ansible_failed_result.argument_errors"
|
||
|
- ansible_failed_result.validate_args_context.argument_spec_name == "main"
|
||
|
- ansible_failed_result.validate_args_context.name == "b"
|
||
|
- ansible_failed_result.validate_args_context.type == "role"
|
||
|
- "ansible_failed_result.validate_args_context.path is search('roles_arg_spec/roles/b')"
|
||
|
- ansible_failed_result.argument_spec_data == expected_returned_spec
|
||
|
|
||
|
|
||
|
- name: "New play to reset vars: Test import_role fails"
|
||
|
hosts: localhost
|
||
|
gather_facts: false
|
||
|
vars:
|
||
|
expected_returned_spec:
|
||
|
b_bool:
|
||
|
required: true
|
||
|
type: "bool"
|
||
|
b_int:
|
||
|
required: true
|
||
|
type: "int"
|
||
|
b_str:
|
||
|
required: true
|
||
|
type: "str"
|
||
|
|
||
|
tasks:
|
||
|
- block:
|
||
|
- name: "EXPECTED FAILURE: Invalid role usage"
|
||
|
import_role:
|
||
|
name: b
|
||
|
vars:
|
||
|
b_bool: 7
|
||
|
|
||
|
- fail:
|
||
|
msg: "Should not get here"
|
||
|
|
||
|
rescue:
|
||
|
- debug:
|
||
|
var: ansible_failed_result
|
||
|
|
||
|
- name: "Validate failure"
|
||
|
assert:
|
||
|
that:
|
||
|
- ansible_failed_task.name == "Validating arguments against arg spec 'main' - Main entry point for role B."
|
||
|
- ansible_failed_result.argument_errors | length == 2
|
||
|
- "'missing required arguments: b_int, b_str' in ansible_failed_result.argument_errors"
|
||
|
- ansible_failed_result.validate_args_context.argument_spec_name == "main"
|
||
|
- ansible_failed_result.validate_args_context.name == "b"
|
||
|
- ansible_failed_result.validate_args_context.type == "role"
|
||
|
- "ansible_failed_result.validate_args_context.path is search('roles_arg_spec/roles/b')"
|
||
|
- ansible_failed_result.argument_spec_data == expected_returned_spec
|
||
|
|
||
|
|
||
|
- name: "New play to reset vars: Test nested role including/importing role succeeds"
|
||
|
hosts: localhost
|
||
|
gather_facts: false
|
||
|
vars:
|
||
|
c_int: 1
|
||
|
a_str: "some string"
|
||
|
a_int: 42
|
||
|
tasks:
|
||
|
- name: "Test import_role of role C"
|
||
|
import_role:
|
||
|
name: c
|
||
|
|
||
|
- name: "Test include_role of role C"
|
||
|
include_role:
|
||
|
name: c
|
||
|
|
||
|
|
||
|
- name: "New play to reset vars: Test nested role including/importing role fails"
|
||
|
hosts: localhost
|
||
|
gather_facts: false
|
||
|
vars:
|
||
|
main_expected_returned_spec:
|
||
|
a_str:
|
||
|
required: true
|
||
|
type: "str"
|
||
|
alternate_expected_returned_spec:
|
||
|
a_int:
|
||
|
required: true
|
||
|
type: "int"
|
||
|
|
||
|
tasks:
|
||
|
- block:
|
||
|
- name: "EXPECTED FAILURE: Test import_role of role C (missing a_str)"
|
||
|
import_role:
|
||
|
name: c
|
||
|
vars:
|
||
|
c_int: 100
|
||
|
|
||
|
- fail:
|
||
|
msg: "Should not get here"
|
||
|
|
||
|
rescue:
|
||
|
- debug:
|
||
|
var: ansible_failed_result
|
||
|
- name: "Validate import_role failure"
|
||
|
assert:
|
||
|
that:
|
||
|
# NOTE: a bug here that prevents us from getting ansible_failed_task
|
||
|
- ansible_failed_result.argument_errors | length == 1
|
||
|
- "'missing required arguments: a_str' in ansible_failed_result.argument_errors"
|
||
|
- ansible_failed_result.validate_args_context.argument_spec_name == "main"
|
||
|
- ansible_failed_result.validate_args_context.name == "a"
|
||
|
- ansible_failed_result.validate_args_context.type == "role"
|
||
|
- "ansible_failed_result.validate_args_context.path is search('roles_arg_spec/roles/a')"
|
||
|
- ansible_failed_result.argument_spec_data == main_expected_returned_spec
|
||
|
|
||
|
- block:
|
||
|
- name: "EXPECTED FAILURE: Test include_role of role C (missing a_int from `alternate` entry point)"
|
||
|
include_role:
|
||
|
name: c
|
||
|
vars:
|
||
|
c_int: 200
|
||
|
a_str: "some string"
|
||
|
|
||
|
- fail:
|
||
|
msg: "Should not get here"
|
||
|
|
||
|
rescue:
|
||
|
- debug:
|
||
|
var: ansible_failed_result
|
||
|
- name: "Validate include_role failure"
|
||
|
assert:
|
||
|
that:
|
||
|
# NOTE: a bug here that prevents us from getting ansible_failed_task
|
||
|
- ansible_failed_result.argument_errors | length == 1
|
||
|
- "'missing required arguments: a_int' in ansible_failed_result.argument_errors"
|
||
|
- ansible_failed_result.validate_args_context.argument_spec_name == "alternate"
|
||
|
- ansible_failed_result.validate_args_context.name == "a"
|
||
|
- ansible_failed_result.validate_args_context.type == "role"
|
||
|
- "ansible_failed_result.validate_args_context.path is search('roles_arg_spec/roles/a')"
|
||
|
- ansible_failed_result.argument_spec_data == alternate_expected_returned_spec
|
||
|
|
||
|
- name: "New play to reset vars: Test role with no tasks can fail"
|
||
|
hosts: localhost
|
||
|
gather_facts: false
|
||
|
tasks:
|
||
|
- block:
|
||
|
- name: "EXPECTED FAILURE: Test import_role of role role_with_no_tasks (missing a_str)"
|
||
|
import_role:
|
||
|
name: role_with_no_tasks
|
||
|
|
||
|
- fail:
|
||
|
msg: "Should not get here"
|
||
|
|
||
|
rescue:
|
||
|
- debug:
|
||
|
var: ansible_failed_result
|
||
|
- name: "Validate import_role failure"
|
||
|
assert:
|
||
|
that:
|
||
|
# NOTE: a bug here that prevents us from getting ansible_failed_task
|
||
|
- ansible_failed_result.argument_errors | length == 1
|
||
|
- "'missing required arguments: a_str' in ansible_failed_result.argument_errors"
|
||
|
- ansible_failed_result.validate_args_context.argument_spec_name == "main"
|
||
|
- ansible_failed_result.validate_args_context.name == "role_with_no_tasks"
|
||
|
- ansible_failed_result.validate_args_context.type == "role"
|
||
|
- "ansible_failed_result.validate_args_context.path is search('roles_arg_spec/roles/role_with_no_tasks')"
|