summaryrefslogtreecommitdiff
path: root/test/integration/targets/aci_rest/tasks/json_string.yml
blob: 34d0ff4c98c7cf55d5754395d2c75cd42471825e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
# Test code for the ACI modules
# Copyright: (c) 2017, Dag Wieers (@dagwieers) <dag@wieers.com>

# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)


# CLEAN ENVIRONMENT
- name: Remove tenant
  aci_rest: &tenant_absent
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    path: /api/mo/uni/tn-[ansible_test].json
    method: delete

# ADD TENANT
- name: Add tenant (normal mode)
  aci_rest: &tenant_present
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    path: /api/mo/uni.json
    method: post
    content: |
      {
          "fvTenant": {
              "attributes": {
                  "name": "ansible_test"
              }
          }
      }
  register: nm_add_tenant

- name: Add tenant again (normal mode)
  aci_rest: *tenant_present
  register: nm_add_tenant_again

- name: Verify add_tenant
  assert:
    that:
    - nm_add_tenant is changed
    - nm_add_tenant_again is not changed

# CHANGE TENANT
- name: Change description of tenant (normal mode)
  aci_rest: &tenant_changed
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    path: /api/mo/uni.json
    method: post
    content: |
      {
          "fvTenant": {
              "attributes": {
                  "descr": "Ansible test tenant",
                  "name": "ansible_test"
              }
          }
      }
  register: nm_add_tenant_descr

- name: Change description of tenant again (normal mode)
  aci_rest: *tenant_changed
  register: nm_add_tenant_descr_again

- name: Verify add_tenant_descr
  assert:
    that:
    - nm_add_tenant_descr is changed
    - nm_add_tenant_descr_again is not changed

# ADD TENANT AGAIN
- name: Add tenant again with no description (normal mode)
  aci_rest: *tenant_present
  register: nm_add_tenant_again_no_descr

- name: Verify add_tenant_again_no_descr
  assert:
    that:
    - nm_add_tenant_again_no_descr is not changed

# QUERY ALL TENANTS
- name: Query all tenants (normal mode)
  aci_rest: &tenant_query_all
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    path: /api/mo/uni/tn-[ansible_test].json
    method: get
  register: nm_query_all_tenants

- name: Verify query_all_tenants
  assert:
    that:
    - nm_query_all_tenants is not changed

# QUERY A TENANT
- name: Query our tenant
  aci_rest: &tenant_query
    host: '{{ aci_hostname }}'
    username: '{{ aci_username }}'
    password: '{{ aci_password }}'
    validate_certs: '{{ aci_validate_certs | default(false) }}'
    use_ssl: '{{ aci_use_ssl | default(true) }}'
    use_proxy: '{{ aci_use_proxy | default(true) }}'
    output_level: '{{ aci_output_level | default("info") }}'
    path: /api/mo/uni/tn-[ansible_test].json
    method: get
  register: nm_query_tenant

- name: Verify query_tenant
  assert:
    that:
    - nm_query_tenant is not changed

# REMOVE TENANT
- name: Remove tenant (normal mode)
  aci_rest: *tenant_absent
  register: nm_remove_tenant

- name: Remove tenant again (normal mode)
  aci_rest: *tenant_absent
  register: nm_remove_tenant_again

- name: Verify remove_tenant
  assert:
    that:
    - nm_remove_tenant is changed
    - nm_remove_tenant_again is not changed

# QUERY NON-EXISTING TENANT
- name: Query non-existing tenant (normal mode)
  aci_rest: *tenant_query
  register: nm_query_non_tenant

- name: Verify query_non_tenant
  assert:
    that:
    - nm_query_non_tenant is not changed