summaryrefslogtreecommitdiff
path: root/tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml
diff options
context:
space:
mode:
Diffstat (limited to 'tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml')
-rw-r--r--tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml203
1 files changed, 203 insertions, 0 deletions
diff --git a/tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml b/tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml
new file mode 100644
index 0000000..9ad6955
--- /dev/null
+++ b/tests/integration/targets/vyos_l3_interface/tests/cli/basic.yaml
@@ -0,0 +1,203 @@
+---
+- debug: msg="START cli/basic.yaml on connection={{ ansible_connection }}"
+
+- name: Remove IP address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ state: absent
+
+- name: Remove IP address
+ vyos.vyos.vyos_l3_interface:
+ name: eth2
+ state: absent
+
+- name: Set IPv4 address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"set interfaces ethernet eth1 address 192.168.2.10/24" in result.commands'
+
+- name: Set IPv4 address (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Set IPv6 address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv6: fd5d:12c9:2201:1::1/64
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"set interfaces ethernet eth1 address fd5d:12c9:2201:1::1/64" in result.commands'
+
+- name: Set IPv6 address (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv6: fd5d:12c9:2201:1::1/64
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Remove all IP addresses
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"delete interfaces ethernet eth1 address" in result.commands'
+
+- name: Remove all IP addresses again (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Set IPv4 and IPv6 address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ ipv6: fd5d:12c9:2201:1::1/64
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"set interfaces ethernet eth1 address 192.168.2.10/24" in result.commands'
+ - '"set interfaces ethernet eth1 address fd5d:12c9:2201:1::1/64" in result.commands'
+
+- name: Set IPv4 and IPv6 address again (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ ipv6: fd5d:12c9:2201:1::1/64
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Remove IPv4 address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"delete interfaces ethernet eth1 address 192.168.2.10/24" in result.commands'
+
+- name: Remove IPv4 address again (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv4: 192.168.2.10/24
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Remove IPv6 address
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv6: fd5d:12c9:2201:1::1/64
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"delete interfaces ethernet eth1 address fd5d:12c9:2201:1::1/64" in result.commands'
+
+- name: Remove IPv6 address again (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ name: eth1
+ ipv6: fd5d:12c9:2201:1::1/64
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Set IP addresses on aggregate
+ vyos.vyos.vyos_l3_interface:
+ aggregate:
+ - { name: eth1, ipv4: 192.168.2.10/24 }
+ - { name: eth2, ipv4: 192.168.3.10/24, ipv6: "fd5d:12c9:2201:1::1/64" }
+ - { name: eth2, ipv4: 192.168.4.10/24 }
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"set interfaces ethernet eth1 address 192.168.2.10/24" in result.commands'
+ - '"set interfaces ethernet eth2 address 192.168.3.10/24" in result.commands'
+ - '"set interfaces ethernet eth2 address fd5d:12c9:2201:1::1/64" in result.commands'
+ - '"set interfaces ethernet eth2 address 192.168.4.10/24" in result.commands'
+
+- name: Set IP addresses on aggregate (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ aggregate:
+ - { name: eth1, ipv4: 192.168.2.10/24 }
+ - { name: eth2, ipv4: 192.168.3.10/24, ipv6: "fd5d:12c9:2201:1::1/64" }
+ - { name: eth2, ipv4: 192.168.4.10/24 }
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'
+
+- name: Remove IP addresses on aggregate
+ vyos.vyos.vyos_l3_interface:
+ aggregate:
+ - { name: eth1, ipv4: 192.168.2.10/24 }
+ - { name: eth2, ipv4: 192.168.3.10/24, ipv6: "fd5d:12c9:2201:1::1/64" }
+ - { name: eth2, ipv4: 192.168.4.10/24 }
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == true'
+ - '"delete interfaces ethernet eth1 address 192.168.2.10/24" in result.commands'
+ - '"delete interfaces ethernet eth2 address 192.168.3.10/24" in result.commands'
+ - '"delete interfaces ethernet eth2 address fd5d:12c9:2201:1::1/64" in result.commands'
+ - '"delete interfaces ethernet eth2 address 192.168.4.10/24" in result.commands'
+
+- name: Remove IP addresses on aggregate (idempotent)
+ vyos.vyos.vyos_l3_interface:
+ aggregate:
+ - { name: eth1, ipv4: 192.168.2.10/24 }
+ - { name: eth2, ipv4: 192.168.3.10/24, ipv6: "fd5d:12c9:2201:1::1/64" }
+ - { name: eth2, ipv4: 192.168.4.10/24 }
+ state: absent
+ register: result
+
+- assert:
+ that:
+ - 'result.changed == false'