Skip to content
Snippets Groups Projects
Commit 1c679c5a authored by Rafael Guterres Jeffman's avatar Rafael Guterres Jeffman
Browse files

templates: Allow execution of plugins in an IPA client host.

Modify templates to create the basic tests for `ipaapi_context: client`.
parent 8bc6b01f
No related branches found
No related tags found
No related merge requests found
...@@ -183,3 +183,4 @@ mkdir -p $dest ...@@ -183,3 +183,4 @@ mkdir -p $dest
src=test_module.yml.in src=test_module.yml.in
[ $member == 1 ] && src=test_module+member.yml.in [ $member == 1 ] && src=test_module+member.yml.in
template $src $dest/test_$name.yml template $src $dest/test_$name.yml
template test_module_client_context.yml.in $dest/test_${name}_client_context.yml
--- ---
- name: Test $name - name: Test $name
hosts: ipaserver hosts: "{{ ipa_test_host | default('ipaserver') }}"
# Change "become" or "gather_facts" to "yes",
# if you test playbook requires any.
become: no become: no
gather_facts: no
tasks: tasks:
...@@ -20,6 +23,7 @@ ...@@ -20,6 +23,7 @@
- name: Ensure $name NAME is present - name: Ensure $name NAME is present
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
# Add needed parameters here # Add needed parameters here
register: result register: result
...@@ -28,6 +32,7 @@ ...@@ -28,6 +32,7 @@
- name: Ensure $name NAME is present again - name: Ensure $name NAME is present again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
# Add needed parameters here # Add needed parameters here
register: result register: result
...@@ -36,6 +41,7 @@ ...@@ -36,6 +41,7 @@
- name: Ensure $name NAME member PARAMETER2 VALUE is present - name: Ensure $name NAME member PARAMETER2 VALUE is present
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
PARAMETER2: VALUE PARAMETER2: VALUE
action: member action: member
...@@ -45,6 +51,7 @@ ...@@ -45,6 +51,7 @@
- name: Ensure $name NAME member PARAMETER2 VALUE is present again - name: Ensure $name NAME member PARAMETER2 VALUE is present again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
PARAMETER2: VALUE PARAMETER2: VALUE
action: member action: member
...@@ -54,6 +61,7 @@ ...@@ -54,6 +61,7 @@
- name: Ensure $name NAME member PARAMETER2 VALUE is absent - name: Ensure $name NAME member PARAMETER2 VALUE is absent
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
PARAMETER2: VALUE PARAMETER2: VALUE
action: member action: member
...@@ -64,6 +72,7 @@ ...@@ -64,6 +72,7 @@
- name: Ensure $name NAME member PARAMETER2 VALUE is absent again - name: Ensure $name NAME member PARAMETER2 VALUE is absent again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
PARAMETER2: VALUE PARAMETER2: VALUE
action: member action: member
...@@ -76,6 +85,7 @@ ...@@ -76,6 +85,7 @@
- name: Ensure $name NAME is absent - name: Ensure $name NAME is absent
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
register: result register: result
...@@ -84,6 +94,7 @@ ...@@ -84,6 +94,7 @@
- name: Ensure $name NAME is absent again - name: Ensure $name NAME is absent again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
register: result register: result
...@@ -94,5 +105,6 @@ ...@@ -94,5 +105,6 @@
- name: Ensure $name NAME is absent - name: Ensure $name NAME is absent
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
--- ---
- name: Test $name - name: Test $name
hosts: ipaserver hosts: "{{ ipa_test_host | default('ipaserver') }}"
# Change "become" or "gather_facts" to "yes",
# if you test playbook requires any.
become: no become: no
gather_facts: no
tasks: tasks:
...@@ -10,6 +13,7 @@ ...@@ -10,6 +13,7 @@
- name: Ensure $name NAME is absent - name: Ensure $name NAME is absent
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
...@@ -28,6 +32,7 @@ ...@@ -28,6 +32,7 @@
- name: Ensure $name NAME is present again - name: Ensure $name NAME is present again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
# Add needed parameters here # Add needed parameters here
register: result register: result
...@@ -38,6 +43,7 @@ ...@@ -38,6 +43,7 @@
- name: Ensure $name NAME is absent - name: Ensure $name NAME is absent
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
register: result register: result
...@@ -46,6 +52,7 @@ ...@@ -46,6 +52,7 @@
- name: Ensure $name NAME is absent again - name: Ensure $name NAME is absent again
ipa$name: ipa$name:
ipaadmin_password: SomeADMINpassword ipaadmin_password: SomeADMINpassword
ipaapi_context: "{{ ipa_context | default(omit) }}"
name: NAME name: NAME
state: absent state: absent
register: result register: result
......
---
- name: Test ${name}
hosts: ipaclients, ipaserver
# Change "become" or "gather_facts" to "yes",
# if you test playbook requires any.
become: no
gather_facts: no
tasks:
- name: Include FreeIPA facts.
include_tasks: ../env_freeipa_facts.yml
# Test will only be executed if host is not a server.
- name: Execute with server context in the client.
ipa${name}:
ipaadmin_password: SomeADMINpassword
ipaapi_context: server
name: ThisShouldNotWork
register: result
failed_when: not (result.failed and result.msg is regex("No module named '*ipaserver'*"))
when: ipa_host_is_client
# Import basic module tests, and execute with ipa_context set to 'client'.
# If ipaclients is set, it will be executed using the client, if not,
# ipaserver will be used.
#
# With this setup, tests can be executed against an IPA client, against
# an IPA server using "client" context, and ensure that tests are executed
# in upstream CI.
- name: Test ${name} using client context, in client host.
import_playbook: test_${name}.yml
when: groups['ipaclients']
vars:
ipa_test_host: ipaclients
- name: Test ${name} using client context, in server host.
import_playbook: test_${name}.yml
when: groups['ipaclients'] is not defined or not groups['ipaclients']
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment