summaryrefslogtreecommitdiffstats
path: root/ansible_collections/mellanox/onyx/tests/unit
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:03:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:03:42 +0000
commit66cec45960ce1d9c794e9399de15c138acb18aed (patch)
tree59cd19d69e9d56b7989b080da7c20ef1a3fe2a5a /ansible_collections/mellanox/onyx/tests/unit
parentInitial commit. (diff)
downloadansible-upstream.tar.xz
ansible-upstream.zip
Adding upstream version 7.3.0+dfsg.upstream/7.3.0+dfsgupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'ansible_collections/mellanox/onyx/tests/unit')
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/__init__.py0
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_bgp_show.cfg34
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_buffer_pool.cfg15
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_command_show_version.txt19
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_config.cfg115
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_src.cfg3
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_interfaces_ethernet.cfg20
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_module.cfg7
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_version.cfg19
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_igmp_show.cfg14
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_rates.cfg10
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_show.cfg74
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_status.cfg15
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l2_interface_show.cfg12
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_interface_show.cfg89
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_vlan_interface_show.cfg18
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_interface_show.cfg16
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_show.cfg14
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_config_show.cfg11
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_show.cfg35
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_magp_show.cfg18
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_ipl_show.cfg29
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_port_channel_show.cfg18
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_show.cfg18
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_vip_show.cfg19
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_servers_peers_show.cfg19
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_show.cfg30
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_interfaces_show.cfg5
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_show.cfg1
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_disabled.cfg26
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_enabled.cfg26
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_port_channel_show.cfg15
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_protocols_show.cfg27
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_aaa.cfg16
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_bfd.cfg14
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_dcb_ets_interface.cfg99
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_igmp_interfaces.cfg162
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interface_congestion_control.cfg46
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve.cfg18
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve_detail.cfg16
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping.cfg10
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_groups.cfg30
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_querier.cfg20
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ntp_configured.cfg8
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_clock.cfg7
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_interface.cfg15
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_hosts.cfg38
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_users.cfg22
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_snmp_show.cfg52
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_username_show.cfg51
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_vlan_show.cfg14
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_wjh_show.cfg3
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/show_qos_interface_ethernet.cfg134
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/onyx_module.py91
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_aaa.py74
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bfd.py114
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bgp.py111
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_buffer_pool.py78
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_command.py114
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_config.py113
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_facts.py71
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp.py127
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_interface.py69
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_vlan.py190
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_interface.py125
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l2_interface.py119
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l3_interface.py113
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_linkagg.py116
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp.py68
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp_interface.py76
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_magp.py110
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_ipl.py86
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_vip.py84
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp.py76
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp_servers_peers.py134
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ospf.py106
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_pfc_interface.py114
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocol.py152
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocols.py143
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp.py138
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_global.py138
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_interface.py91
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_qos.py52
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp.py150
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_hosts.py170
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_users.py95
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_files.py113
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_remote.py91
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_traffic_class.py108
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_username.py99
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vlan.py106
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vxlan.py101
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_wjh.py66
-rw-r--r--ansible_collections/mellanox/onyx/tests/unit/modules/utils.py56
94 files changed, 5914 insertions, 0 deletions
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/__init__.py b/ansible_collections/mellanox/onyx/tests/unit/modules/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/__init__.py
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_bgp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_bgp_show.cfg
new file mode 100644
index 00000000..b9c5c952
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_bgp_show.cfg
@@ -0,0 +1,34 @@
+##
+## Running database "initial"
+## Generated at 2009/01/14 12:53:06 +0000
+## Hostname: r-ufm-sw102
+##
+
+##
+## Running-config temporary prefix mode setting
+##
+no cli default prefix-modes enable
+
+##
+## BGP configuration
+##
+ protocol bgp
+ router bgp 172 vrf default
+ router bgp 172 vrf default router-id 1.2.3.4 force
+ router bgp 172 vrf default bgp fast-external-fallover
+ router bgp 172 vrf default maximum-paths 31
+ router bgp 172 vrf default bestpath as-path multipath-relax force
+ router bgp 172 vrf default neighbor evpn peer-group
+ router bgp 172 vrf default neighbor evpn send-community extended
+ router bgp 172 vrf default neighbor 10.2.3.4 remote-as 173
+ router bgp 172 vrf default neighbor 10.2.3.5 remote-as 322
+ router bgp 172 vrf default neighbor 10.2.3.5 peer-group evpn
+ router bgp 172 vrf default neighbor 10.2.3.5 ebgp-multihop 255
+ router bgp 172 vrf default address-family l2vpn-evpn neighbor evpn next-hop-unchanged
+ router bgp 172 vrf default address-family l2vpn-evpn neighbor evpn activate
+ router bgp 172 vrf default network 172.16.1.0 /24
+ router bgp 172 vrf default address-family l2vpn-evpn auto-create
+##
+## Persistent prefix mode setting
+##
+cli default prefix-modes enable
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_buffer_pool.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_buffer_pool.cfg
new file mode 100644
index 00000000..7172e8dc
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_buffer_pool.cfg
@@ -0,0 +1,15 @@
+{
+ "roce": [
+ {
+ "Type": "lossless",
+ "Switch Priorities": "3",
+ "Max Usage": "0",
+ "Usage": "0",
+ "Memory actual": "5.9M",
+ "Memory [%]": "50.00"
+ }
+ ],
+ "Exception list": {
+ "message": "N/A"
+ }
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_command_show_version.txt b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_command_show_version.txt
new file mode 100644
index 00000000..cca075b6
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_command_show_version.txt
@@ -0,0 +1,19 @@
+Product name: MLNX-OS
+Product release: 3.6.5000
+Build ID: #1-dev
+Build date: 2017-11-10 18:14:32
+Target arch: x86_64
+Target hw: x86_64
+Built by: jenkins@cc45f26cd083
+Version summary: X86_64 3.6.5000 2017-11-10 18:14:32 x86_64
+
+Product model: x86onie
+Host ID: 248A073D505C
+System serial num: \"MT1632X00205\"
+System UUID: 0b19d6d0-5eca-11e6-8000-7cfe90fadc40
+
+Uptime: 1d 16h 31m 43.856s
+CPU load averages: 0.06 / 0.12 / 0.13
+Number of CPUs: 4
+System memory: 2597 MB used / 5213 MB free / 7810 MB total
+Swap: 0 MB used / 0 MB free / 0 MB total
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_config.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_config.cfg
new file mode 100644
index 00000000..38062a8c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_config.cfg
@@ -0,0 +1,115 @@
+##
+## Running database "initial"
+## Generated at 2017/11/28 17:52:08 +0000
+## Hostname: ufm-switch16
+##
+
+##
+## Running-config temporary prefix mode setting
+##
+no cli default prefix-modes enable
+
+##
+## License keys
+##
+ license install 11223344
+
+##
+## MLAG protocol
+##
+ protocol mlag
+
+##
+## Interface Ethernet configuration
+##
+ interface mlag-port-channel 2
+ interface port-channel 1
+ interface ethernet 1/7-1/8 channel-group 1 mode active
+ interface ethernet 1/32 mlag-channel-group 2 mode on
+ interface mlag-port-channel 2 switchport mode hybrid
+ interface mlag-port-channel 2 no shutdown
+
+##
+## LAG configuration
+##
+ lacp
+
+##
+## VLAN configuration
+##
+ vlan 101
+ vlan 4094
+ interface mlag-port-channel 2 switchport access vlan 101
+
+##
+## STP configuration
+##
+no spanning-tree
+
+##
+## L3 configuration
+##
+ ip routing vrf default
+ interface vlan 101
+ interface vlan 4094
+ interface vlan 101 ip address 10.0.0.254 255.255.255.0
+ interface vlan 4094 ip address 10.10.10.1 255.255.255.0
+
+##
+## Other IP configuration
+##
+hostname ufm-switch16
+
+##
+## DCBX PFC configuration
+##
+ dcb priority-flow-control enable force
+ interface ethernet 1/7-1/8 dcb priority-flow-control mode on force
+ interface port-channel 1 dcb priority-flow-control mode on force
+
+##
+## LLDP configuration
+##
+ lldp
+
+##
+## MAGP configuration
+##
+ protocol magp
+ interface vlan 101 magp 102
+ interface vlan 101 magp 102 ip virtual-router address 10.0.0.252
+ interface vlan 101 magp 102 ip virtual-router mac-address 00:00:5E:00:01:01
+
+##
+## MLAG configurations
+##
+ mlag-vip neo-mlag-vip-4094 ip 192.168.1.1 /24 force
+no mlag shutdown
+ mlag system-mac 00:00:5E:00:01:00
+ interface port-channel 1 ipl 1
+ interface vlan 4094 ipl 1 peer-address 10.10.10.2
+
+##
+## AAA remote server configuration
+##
+# ldap bind-password ********
+# radius-server key ********
+# tacacs-server key ********
+
+##
+## Network management configuration
+##
+# web proxy auth basic password ********
+ telnet-server enable
+
+##
+## X.509 certificates configuration
+##
+#
+# Certificate name system-self-signed, ID 51f545df9722387056f674401f510ff56077800b
+# (public-cert config omitted since private-key config is hidden)
+
+##
+## Persistent prefix mode setting
+##
+cli default prefix-modes enable \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_src.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_src.cfg
new file mode 100644
index 00000000..2fc2ada1
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_config_src.cfg
@@ -0,0 +1,3 @@
+no cli default prefix-modes enable
+interface mlag-port-channel 2
+
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_interfaces_ethernet.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_interfaces_ethernet.cfg
new file mode 100644
index 00000000..03128f1e
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_interfaces_ethernet.cfg
@@ -0,0 +1,20 @@
+[
+ {
+ "Fec": "auto",
+ "Mac address": "7c:fe:90:e5:ca:3c",
+ "Actual speed": "100 Gbps",
+ "MTU": "1500 bytes(Maximum packet size 1522 bytes)",
+ "header": "Eth1/1",
+ "Admin state": "Enabled",
+ "Operational state": "Down"
+ },
+ {
+ "Fec": "auto",
+ "Mac address": "7c:fe:90:e5:ca:3e",
+ "Actual speed": "100 Gbps",
+ "MTU": "1500 bytes(Maximum packet size 1522 bytes)",
+ "header": "Eth1/2",
+ "Admin state": "Enabled",
+ "Operational state": "Down"
+ }
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_module.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_module.cfg
new file mode 100644
index 00000000..a82fcf75
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_module.cfg
@@ -0,0 +1,7 @@
+{
+ "MGMT": [
+ {
+ "Status": "ready"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_version.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_version.cfg
new file mode 100644
index 00000000..9a486e8c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_facts_show_version.cfg
@@ -0,0 +1,19 @@
+{
+ "Uptime": "2d 13h 40m 34.992s",
+ "Product model": "x86onie",
+ "Build date": "2017-11-10 18:14:32",
+ "Target arch": "x86_64",
+ "Target hw": "x86_64",
+ "Number of CPUs": "4",
+ "Build ID": "#1-dev",
+ "CPU load averages": "0.21 / 0.07 / 0.06",
+ "Host ID": "248A07B0141C",
+ "System serial num": "MT1708X07233",
+ "System UUID": "03d242b6-1a24-11e7-8000-248a07f55400",
+ "Swap": "0 MB used / 0 MB free / 0 MB total",
+ "Product name": "MLNX-OS",
+ "Built by": "jenkins@cc45f26cd083",
+ "System memory": "2597 MB used / 5213 MB free / 7810 MB total",
+ "Version summary": "X86_64 3.6.5000 2017-11-10 18:14:32 x86_64",
+ "Product release": "3.6.5000"
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_igmp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_igmp_show.cfg
new file mode 100644
index 00000000..13b19d94
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_igmp_show.cfg
@@ -0,0 +1,14 @@
+[
+ {
+ "Report suppression interval": "5 seconds",
+ "IGMP snooping unregistered multicast": "flood",
+ "IGMP snooping operationally": "disabled",
+ "Mrouter timeout": "125 seconds",
+ "IGMP default version for new VLAN": "V3",
+ "header": "IGMP snooping global configuration",
+ "Last member query interval": "1 seconds",
+ "IGMP snooping globally": "disabled",
+ "Proxy-reporting globally": "disabled",
+ "Port purge timeout": "260 seconds"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_rates.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_rates.cfg
new file mode 100644
index 00000000..11131cc5
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_rates.cfg
@@ -0,0 +1,10 @@
+{
+ "Eth1/1": [
+ {
+ "ingress rate": "9000 b/s",
+ "egress pkts/sec": "10",
+ "egress rate": "10000 b/s",
+ "ingress pkts/sec": "10"
+ }
+ ]
+} \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_show.cfg
new file mode 100644
index 00000000..982e58fd
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_show.cfg
@@ -0,0 +1,74 @@
+[
+ {
+ "Fec": "auto",
+ "Mac address": "7c:fe:90:f0:54:fc",
+ "60 seconds ingress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last clearing of \"show interface\" counters": "Never",
+ "Actual speed": "40 Gbps",
+ "MTU": "1500 bytes(Maximum packet size 1522 bytes)",
+ "header": "Eth1/1",
+ "Telemetry threshold": "Disabled\t TCs: N\\A",
+ "Telemetry threshold level": "N\\A",
+ "Flow-control": "receive off send off",
+ "Forwarding mode": "inherited cut-through",
+ "60 seconds egress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last change in operational status": "Never",
+ "Boot delay time": "0 sec",
+ "Description": "N\\A",
+ "Admin state": "Enabled",
+ "Telemetry sampling": "Disabled\t TCs: N\\A",
+ "Operational state": "Down",
+ "Width reduction mode": "Not supported",
+ "Tx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "hoq discard packets": "0",
+ "broadcast packets": "0"
+ },
+ "MAC learning mode": "Enabled",
+ "Switchport mode": "access",
+ "Rx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "broadcast packets": "0"
+ }
+ },
+ {
+ "Icmp redirect": "Enabled",
+ "Description": "N/A",
+ "Mac Address": "7C:FE:90:F0:54:C1",
+ "Autostate": "Enabled",
+ "Admin state": "Enabled",
+ "header": "Vlan 10",
+ "MTU": "1500 bytes",
+ "DHCP client": "Disabled",
+ "Operational state": "Up",
+ "VRF": "default",
+ "Arp timeout": "1500 seconds",
+ "Counters": "Disabled"
+ },
+ {
+ "Autostate": "Enabled",
+ "Icmp redirect": "Enabled",
+ "Broadcast address": "10.2.2.255",
+ "Description": "N/A",
+ "Mac Address": "7C:FE:90:F0:54:C1",
+ "Internet Address": "10.2.2.3/24",
+ "Admin state": "Enabled",
+ "header": "Vlan 1002",
+ "MTU": "1500 bytes",
+ "DHCP client": "Disabled",
+ "Operational state": "Down",
+ "VRF": "default",
+ "Arp timeout": "1500 seconds",
+ "Counters": "Disabled"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_status.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_status.cfg
new file mode 100644
index 00000000..7a3a974a
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_interfaces_status.cfg
@@ -0,0 +1,15 @@
+{
+ "Eth1/1": [
+ {
+ "Negotiation": "No-Negotiation",
+ "Operational state": "Down",
+ "Speed": "100 Gbps"
+ }
+ ],
+ "Vlan 1002": [
+ {
+ "State": "Down",
+ "Description": "N/A"
+ }
+ ]
+} \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l2_interface_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l2_interface_show.cfg
new file mode 100644
index 00000000..dc3704e4
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l2_interface_show.cfg
@@ -0,0 +1,12 @@
+{
+ "Eth1/11": {
+ "Access vlan": "1",
+ "Allowed vlans": "",
+ "Mode": "access"
+ },
+ "Eth1/10": {
+ "Access vlan": "1",
+ "Allowed vlans": "10",
+ "Mode": "hybrid"
+ }
+} \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_interface_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_interface_show.cfg
new file mode 100644
index 00000000..6298953b
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_interface_show.cfg
@@ -0,0 +1,89 @@
+[
+ {
+ "Broadcast address": "172.3.1.255",
+ "Fec": "auto",
+ "Tx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "hoq discard packets": "0",
+ "broadcast packets": "0"
+ },
+ "Rx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "broadcast packets": "0"
+ },
+ "header": "Eth1/5",
+ "Arp timeout": "1500 seconds",
+ "Actual speed": "40 Gbps",
+ "60 seconds egress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last change in operational status": "Never",
+ "Boot delay time": "0 sec",
+ "Description": "N\\A",
+ "DHCP client": "Disabled",
+ "VRF": "default",
+ "Mac address": "24:8A:07:F5:54:01",
+ "60 seconds ingress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last clearing of \"show interface\" counters": "Never",
+ "MTU": "1500 bytes(Maximum packet size 1522 bytes)",
+ "Telemetry threshold": "Disabled\t TCs: N\\A",
+ "Telemetry threshold level": "N\\A",
+ "Flow-control": "receive off send off",
+ "Forwarding mode": "inherited cut-through",
+ "Admin state": "Enabled",
+ "Telemetry sampling": "Disabled\t TCs: N\\A",
+ "IP Address": "172.3.12.4 /24",
+ "Operational state": "Down",
+ "Width reduction mode": "Not supported"
+ },
+ {
+ "Fec": "auto",
+ "Mac address": "24:8a:07:f5:54:0c",
+ "60 seconds ingress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last clearing of \"show interface\" counters": "Never",
+ "Actual speed": "40 Gbps",
+ "MTU": "1500 bytes(Maximum packet size 1522 bytes)",
+ "header": "Eth1/6",
+ "Telemetry threshold": "Disabled\t TCs: N\\A",
+ "Telemetry threshold level": "N\\A",
+ "Flow-control": "receive off send off",
+ "Forwarding mode": "inherited cut-through",
+ "60 seconds egress rate": "0 bits/sec, 0 bytes/sec, 0 packets/sec",
+ "Last change in operational status": "Never",
+ "Boot delay time": "0 sec",
+ "Description": "N\\A",
+ "Admin state": "Enabled",
+ "Telemetry sampling": "Disabled\t TCs: N\\A",
+ "Operational state": "Down",
+ "Width reduction mode": "Not supported",
+ "Tx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "hoq discard packets": "0",
+ "broadcast packets": "0"
+ },
+ "MAC learning mode": "Enabled",
+ "Switchport mode": "access",
+ "Rx": {
+ "error packets": "0",
+ "packets": "0",
+ "bytes": "0",
+ "multicast packets": "0",
+ "unicast packets": "0",
+ "discard packets": "0",
+ "broadcast packets": "0"
+ }
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_vlan_interface_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_vlan_interface_show.cfg
new file mode 100644
index 00000000..66a5509e
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_l3_vlan_interface_show.cfg
@@ -0,0 +1,18 @@
+[
+ {
+ "Autostate": "Enabled",
+ "Icmp redirect": "Enabled",
+ "Broadcast address": "172.3.12.255",
+ "Description": "N/A",
+ "Mac Address": "7C:FE:90:E5:CA:01",
+ "Internet Address": "172.3.12.4/24",
+ "Admin state": "Enabled",
+ "header": "Vlan 1002",
+ "MTU": "1500 bytes",
+ "DHCP client": "Disabled",
+ "Operational state": "Down",
+ "VRF": "default",
+ "Arp timeout": "1500 seconds",
+ "Counters": "Disabled"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_interface_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_interface_show.cfg
new file mode 100644
index 00000000..d3a364b9
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_interface_show.cfg
@@ -0,0 +1,16 @@
+{
+ "Eth1/1": [
+ {
+ "Receive": "Enabled",
+ "Transmit": "Enabled",
+ "TLVs": "PD, SN, SD, SC, MA, PFC, AP, ETS-C, ETS-R"
+ }
+ ],
+ "Eth1/2": [
+ {
+ "Receive": "Disabled",
+ "Transmit": "Disabled",
+ "TLVs": "PD, SN, SD, SC, MA, PFC, AP, ETS-C, ETS-R"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_show.cfg
new file mode 100644
index 00000000..7bb1cb02
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_lldp_show.cfg
@@ -0,0 +1,14 @@
+[
+ {
+ "LLDP": "enabled"
+ },
+ {
+ "Supported capabilities": "B,R",
+ "Chassis sub type": "Mac Address",
+ "header": "Local global configuration",
+ "System Name": "ufm-switch16",
+ "Supported capabilities enabled": "B",
+ "Chassis id": "7c:fe:90:e5:ca:00",
+ "System Description": "Mellanox MSN2700,MLNX-OS,SWv3.6.5000-04"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_config_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_config_show.cfg
new file mode 100644
index 00000000..235205c2
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_config_show.cfg
@@ -0,0 +1,11 @@
+
+logging trap alert
+logging 10.10.10.10
+logging 10.10.10.10 filter exclude ".*ERR.*"
+logging 10.10.10.10 trap info
+logging 10.10.10.12
+logging 10.10.10.12 port 80
+logging 10.10.10.12 trap override class sx-sdk priority emerg
+logging files rotation criteria size-pct 10.000
+logging local info
+logging receive
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_show.cfg
new file mode 100644
index 00000000..09e21b10
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_logging_show.cfg
@@ -0,0 +1,35 @@
+[
+ {
+ "Log format": "standard",
+ "Log rotation size threshold": "10.000% of partition (986.46 megabytes)",
+ "Allow receiving of messages from remote hosts": "yes",
+ "Override for class debug-module": "notice",
+ "Local logging level": "info",
+ "Number of archived log files to keep": "10",
+ "Default remote logging level": "alert",
+ "Subsecond timestamp field": "disabled",
+ "Log rotation frequency": "weekly",
+ "debug": [
+ "logging debug-files rotation criteria frequency daily",
+ "logging debug-files rotation criteria size 20",
+ "logging debug-files rotation max-num 20"
+ ]
+ },
+ {
+ "Levels at which messages are logged": [
+ {
+ "CLI commands": "notice",
+ "Audit messages": "notice"
+ }
+ ]
+ },
+ {
+ "Remote syslog servers": [
+ {
+ "Lines": [
+ "No remote syslog servers configured"
+ ]
+ }
+ ]
+ }
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_magp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_magp_show.cfg
new file mode 100644
index 00000000..7cc90b7a
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_magp_show.cfg
@@ -0,0 +1,18 @@
+[
+ {
+ "Interface vlan": "1243",
+ "Admin state": "Enabled",
+ "Virtual IP": "10.0.0.43",
+ "header": "MAGP 102",
+ "State": "Init",
+ "Virtual MAC": "01:02:03:04:05:06"
+ },
+ {
+ "Interface vlan": "1200",
+ "Admin state": "Disabled",
+ "Virtual IP": "0.0.0.0",
+ "header": "MAGP 103",
+ "State": "Init",
+ "Virtual MAC": "00:00:00:00:00:00"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_ipl_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_ipl_show.cfg
new file mode 100644
index 00000000..6d1f3df5
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_ipl_show.cfg
@@ -0,0 +1,29 @@
+{
+ "Reload-delay": "30 sec",
+ "Upgrade-timeout": "60 min",
+ "System-mac": "00:00:5E:00:01:4E [Mismatched]",
+ "Admin status": "Disabled",
+ "MLAG Ports Status Summary": {
+ "Active-partial": "0",
+ "Inactive": "0",
+ "Active-full": "0"
+ },
+ "MLAG IPLs Summary": {
+ "1": [
+ {
+ "Local IP address": "10.2.2.3",
+ "Peer IP address": "10.2.2.2",
+ "Operational State": "Down",
+ "Vlan Interface": "1002",
+ "Group Port-Channel": "Po1"
+ }
+ ]
+ },
+ "Keepalive-interval": "1 sec",
+ "MLAG Ports Configuration Summary": {
+ "Disabled": "0",
+ "Configured": "0",
+ "Enabled": "0"
+ },
+ "Operational status": "Down"
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_port_channel_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_port_channel_show.cfg
new file mode 100644
index 00000000..e883ecf3
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_port_channel_show.cfg
@@ -0,0 +1,18 @@
+{
+ "MLAG Port-Channel Flags": "D-Down, U-Up, P-Partial UP, S - suspended by MLAG",
+ "Port Flags": {
+ "I": "Individual",
+ "P": "Up in port-channel (members)",
+ "S": "Suspend in port-channel (members)",
+ "D": "Down"
+ },
+ "MLAG Port-Channel Summary": {
+ "1 Mpo33(S)": [
+ {
+ "Local Ports (D/P/S/I)": "Eth1/8(D)",
+ "Peer Ports (D/P/S/I)": "N/A",
+ "Type": "LACP"
+ }
+ ]
+ }
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_show.cfg
new file mode 100644
index 00000000..1996a6b3
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_show.cfg
@@ -0,0 +1,18 @@
+{
+ "Reload-delay": "30 sec",
+ "Upgrade-timeout": "60 min",
+ "System-mac": "00:00:5E:00:01:4E",
+ "Admin status": "Disabled",
+ "MLAG Ports Status Summary": {
+ "Active-partial": "0",
+ "Inactive": "0",
+ "Active-full": "0"
+ },
+ "Keepalive-interval": "1 sec",
+ "MLAG Ports Configuration Summary": {
+ "Disabled": "0",
+ "Configured": "0",
+ "Enabled": "0"
+ },
+ "Operational status": "Down"
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_vip_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_vip_show.cfg
new file mode 100644
index 00000000..19bee48f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_mlag_vip_show.cfg
@@ -0,0 +1,19 @@
+{
+ "r-neo-sw12": [
+ {
+ "IP Address": "10.209.26.55",
+ "VIP-State": "standby"
+ }
+ ],
+ "r-smg-sw14": [
+ {
+ "IP Address": "10.209.27.172",
+ "VIP-State": "master"
+ }
+ ],
+ "MLAG-VIP": {
+ "MLAG VIP address": "10.209.25.107/24",
+ "MLAG group name": "neo-mlag-vip-500",
+ "Active nodes": "2"
+ }
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_servers_peers_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_servers_peers_show.cfg
new file mode 100644
index 00000000..2f5d3c2f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_servers_peers_show.cfg
@@ -0,0 +1,19 @@
+[
+ {
+ "NTP enabled": "yes",
+ "NTP Authentication enabled": "no"
+ },
+ {
+ "NTP version": "4",
+ "Enabled": "yes",
+ "Key ID": "5",
+ "header": "NTP peer 1.1.1.1"
+ },
+ {
+ "NTP version": "4",
+ "Enabled": "no",
+ "Trusted": "yes",
+ "Key ID": "99",
+ "header": "NTP server 2.2.2.2"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_show.cfg
new file mode 100644
index 00000000..b0b4a8db
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ntp_show.cfg
@@ -0,0 +1,30 @@
+[
+[
+ {
+ "NTP is administratively": "enabled",
+ "NTP Authentication administratively": "disabled"
+ },
+ {
+ "Lines": [
+ "Clock is unsynchronized."
+ ]
+ },
+ {
+ "Active servers and peers": [
+ {
+ "Lines": [
+ "No NTP associations present."
+ ]
+ }
+ ]
+ }
+] ,
+[
+ {
+ "header": "NTP Key 22",
+ "Encryption Type": "sha1",
+ "Trusted": "no"
+ }
+]
+
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_interfaces_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_interfaces_show.cfg
new file mode 100644
index 00000000..75663058
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_interfaces_show.cfg
@@ -0,0 +1,5 @@
+
+OSPF Process ID 2 VRF default
+Total number of interface: 1
+Interface Id Area Cost State Neighbors Status
+Loopback1 0.0.0.0 1 Enabled 0 Up
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_show.cfg
new file mode 100644
index 00000000..72e38568
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_ospf_show.cfg
@@ -0,0 +1 @@
+Routing Process 2 with ID 10.2.3.4 default
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_disabled.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_disabled.cfg
new file mode 100644
index 00000000..0d51d4d5
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_disabled.cfg
@@ -0,0 +1,26 @@
+{
+ "Eth1/1": [
+ {
+ "PFC admin": "Auto",
+ "PFC oper": "Disabled"
+ }
+ ],
+ "Eth1/1/2": [
+ {
+ "PFC admin": "Auto",
+ "PFC oper": "Disabled"
+ }
+ ],
+ "Po1": [
+ {
+ "PFC admin": "Auto",
+ "PFC oper": "Disabled"
+ }
+ ],
+ "Mpo2": [
+ {
+ "PFC admin": "Auto",
+ "PFC oper": "Disabled"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_enabled.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_enabled.cfg
new file mode 100644
index 00000000..471edc8c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_pfc_interface_enabled.cfg
@@ -0,0 +1,26 @@
+{
+ "Eth1/1": [
+ {
+ "PFC admin": "on",
+ "PFC oper": "Enabled"
+ }
+ ],
+ "Eth1/1/2": [
+ {
+ "PFC admin": "on",
+ "PFC oper": "Enabled"
+ }
+ ],
+ "Po1": [
+ {
+ "PFC admin": "on",
+ "PFC oper": "Enabled"
+ }
+ ],
+ "Mpo2": [
+ {
+ "PFC admin": "on",
+ "PFC oper": "Enabled"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_port_channel_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_port_channel_show.cfg
new file mode 100644
index 00000000..805853f4
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_port_channel_show.cfg
@@ -0,0 +1,15 @@
+{
+ "Flags": {
+ "I": "Individual",
+ "P": "Up in port-channel (members)",
+ "S": "Suspend in port-channel (members)",
+ "U": "Up",
+ "D": "Down"
+ },
+ "1 Po22(D)": [
+ {
+ "Type": "STATIC",
+ "Member Ports": "Eth1/7(D)"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_protocols_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_protocols_show.cfg
new file mode 100644
index 00000000..fd4549cd
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_protocols_show.cfg
@@ -0,0 +1,27 @@
+{
+ "pim": "disabled",
+ "dhcp-relay": "disabled",
+ "igmp-snooping": "disabled",
+ "lacp": "disabled",
+ "ptp": "disabled",
+ "lldp": "disabled",
+ "isolation-group": "disabled",
+ "bfd": "disabled",
+ "openflow": "disabled",
+ "telemetry": "disabled",
+ "vrrp": "disabled",
+ "spanning-tree": "rst",
+ "mlag": "disabled",
+ "magp": "disabled",
+ "nve": "disabled",
+ "Ethernet": "enabled",
+ "IP L3": "enabled",
+ "ets": "enabled",
+ "sflow": "disabled",
+ "dhcp-relay(v6)": "disabled",
+ "dot1x": "disabled",
+ "bgp": "disabled",
+ "priority-flow-control": "disabled",
+ "ospf": "disabled",
+ "bfd": "disabled"
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_aaa.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_aaa.cfg
new file mode 100644
index 00000000..40abbf21
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_aaa.cfg
@@ -0,0 +1,16 @@
+[
+ {
+ "Default User": "admin",
+ "header": "AAA authorization",
+ "Fallback on server-err": "yes",
+ "Map Order": "remote-first"
+ },
+ {
+ "header": "Authentication method(s)",
+ "message": "local"
+ },
+ {
+ "header": "Accounting method(s)",
+ "message": "No accounting methods configured."
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_bfd.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_bfd.cfg
new file mode 100644
index 00000000..2e578eb1
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_bfd.cfg
@@ -0,0 +1,14 @@
+{
+ "Lines": [
+ " protocol bfd",
+ " ip bfd shutdown vrf default",
+ " ip bfd vrf 3 interval transmit-rate 55 force",
+ " ip bfd vrf default interval transmit-rate 55 force",
+ " ip bfd vrf 3 interval min-rx 50 force",
+ " ip bfd vrf default interval min-rx 50 force",
+ " ip bfd vrf 3 interval multiplier 7 force",
+ " ip bfd vrf default interval multiplier 7 force",
+ " ip route vrf 3 1.1.1.0/24 3.2.2.2 bfd",
+ " ip route vrf default 1.1.1.0/24 3.2.2.2 bfd"
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_dcb_ets_interface.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_dcb_ets_interface.cfg
new file mode 100644
index 00000000..b6bbc30f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_dcb_ets_interface.cfg
@@ -0,0 +1,99 @@
+[
+ {
+ "Eth1/1": [
+ {
+ "Multicast unaware mapping": "disabled",
+ "Interface Bandwidth Shape [Mbps]": "N/A"
+ },
+ {
+ "Flags": [
+ {
+ "S.Mode": "Scheduling Mode [Strict/WRR]",
+ "Bw.Sh": "Bandwidth Shaper",
+ "D": "-",
+ "W": "Weight",
+ "Bw.Gr": "Bandwidth Guaranteed"
+ }
+ ]
+ },
+ {
+ "ETS per TC": [
+ {
+ "1": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "17",
+ "BW Gr.(Mbps)": "0",
+ "W": "13"
+ }
+ ],
+ "0": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "17",
+ "BW Gr.(Mbps)": "0",
+ "W": "12"
+ }
+ ],
+ "3": [
+ {
+ "S.Mode": "Strict",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "0",
+ "BW Gr.(Mbps)": "0",
+ "W": "0"
+ }
+ ],
+ "2": [
+ {
+ "S.Mode": "Strict",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "0",
+ "BW Gr.(Mbps)": "0",
+ "W": "0"
+ }
+ ],
+ "5": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "17",
+ "BW Gr.(Mbps)": "0",
+ "W": "13"
+ }
+ ],
+ "4": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "16",
+ "BW Gr.(Mbps)": "0",
+ "W": "12"
+ }
+ ],
+ "7": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "17",
+ "BW Gr.(Mbps)": "0",
+ "W": "13"
+ }
+ ],
+ "6": [
+ {
+ "S.Mode": "WRR",
+ "BW Sh.(Mbps)": "N/A",
+ "W(%)": "16",
+ "BW Gr.(Mbps)": "0",
+ "W": "12"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_igmp_interfaces.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_igmp_interfaces.cfg
new file mode 100644
index 00000000..22641d8b
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_igmp_interfaces.cfg
@@ -0,0 +1,162 @@
+{
+ "Eth1/31": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/11": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/10": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/13": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/12": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/15": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/14": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/17": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/16": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/19": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/18": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/5": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/4": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/7": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/6": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/1": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/3": [
+ {
+ "leave-mode": "Fast"
+ }
+ ],
+ "Eth1/2": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/9": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/8": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/32": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/24": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/25": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/26": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/27": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/20": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/21": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/22": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/23": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/30": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/28": [
+ {
+ "leave-mode": "Normal"
+ }
+ ],
+ "Eth1/29": [
+ {
+ "leave-mode": "Normal"
+ }
+ ]
+} \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interface_congestion_control.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interface_congestion_control.cfg
new file mode 100644
index 00000000..e4c1207f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interface_congestion_control.cfg
@@ -0,0 +1,46 @@
+[
+ {
+ "Interface ethernet": "1/1",
+ "ECN marked packets": "0"
+ },
+ {
+ "header": "TC-0",
+ "Mode": "none"
+ },
+ {
+ "header": "TC-1",
+ "Mode": "none"
+ },
+ {
+ "Threshold mode": "relative",
+ "RED dropped packets": "0",
+ "header": "TC-2",
+ "Mode": "RED",
+ "Maximum threshold": "90%",
+ "Minimum threshold": "9%"
+ },
+ {
+ "Threshold mode": "absolute",
+ "RED dropped packets": "0",
+ "header": "TC-3",
+ "Mode": "ECN",
+ "Maximum threshold": "1550 KB",
+ "Minimum threshold": "500 KB"
+ },
+ {
+ "header": "TC-4",
+ "Mode": "none"
+ },
+ {
+ "header": "TC-5",
+ "Mode": "none"
+ },
+ {
+ "header": "TC-6",
+ "Mode": "none"
+ },
+ {
+ "header": "TC-7",
+ "Mode": "none"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve.cfg
new file mode 100644
index 00000000..a907d168
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve.cfg
@@ -0,0 +1,18 @@
+[
+ {
+ "Mlag tunnel IP": "192.10.10.1",
+ "Effective tunnel IP": "(not exist)",
+ "NVE member interfaces": "(not configured)",
+ "Admin state": "up",
+ "Source interface": "loopback 1 (ip 0.0.0.0)",
+ "header": "Interface NVE 1 status",
+ "Controller mode": "BGP",
+ "Global Neigh-Suppression": "Enable",
+ "Counters": {
+ "dropped NVE-encapsulated packets": "0",
+ "decapsulated (Rx) NVE packets": "0",
+ "encapsulated (Tx) NVE packets": "0",
+ "NVE-encapsulated packets with errors": "0"
+ }
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve_detail.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve_detail.cfg
new file mode 100644
index 00000000..e904bcc3
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_interfaces_nve_detail.cfg
@@ -0,0 +1,16 @@
+[
+ {
+ "10":[
+ {
+ "Neigh Suppression":"Enable",
+ "VNI":"10010"
+ }
+ ],
+ "6":[
+ {
+ "Neigh Suppression":"Enable",
+ "VNI":"10060"
+ }
+ ]
+ }
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping.cfg
new file mode 100644
index 00000000..975b6723
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping.cfg
@@ -0,0 +1,10 @@
+[
+ {
+ "mrouter static port list": "none",
+ "mrouter dynamic port list": "none",
+ "header": "Vlan 10 configuration parameters",
+ "message 1": "IGMP snooping is disabled",
+ "message 2": "IGMP version is V3",
+ "message 3": "Snooping switch is acting as Non-Querier"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_groups.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_groups.cfg
new file mode 100644
index 00000000..3d84667b
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_groups.cfg
@@ -0,0 +1,30 @@
+[
+ {
+ "Snooping group information for VLAN 10 and group 224.5.5.1": [
+ {
+ "Group flag": "St",
+ "Filter Mode": "EXCLUDE",
+ "V1/V2 Receiver Ports": "eth1/1, eth1/2",
+ "Exclude sources": "None"
+ },
+ {
+ "V3 Receiver Ports": [
+ {
+ "Exclude sources": [
+ "None",
+ "None"
+ ],
+ "Include sources": [
+ "1.1.1.1, 1.1.1.2",
+ "1.1.1.3"
+ ],
+ "Port Number": [
+ "eth1/1",
+ "eth1/2"
+ ]
+ }
+ ]
+ }
+ ]
+ }
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_querier.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_querier.cfg
new file mode 100644
index 00000000..b64c260d
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ip_igmp_snooping_querier.cfg
@@ -0,0 +1,20 @@
+[
+ {
+ "Snooping querier information for VLAN 10": [
+ {
+ "Lines": [
+ "IGMP Querier Not Present"
+ ]
+ },
+ {
+ "Response interval": "100",
+ "Elected querier IP address": "0.0.0.0",
+ "Group membership interval": "1",
+ "Robustness": "2",
+ "Configured querier IP address": "-",
+ "Query interval": "125",
+ "Version": "3"
+ }
+ ]
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ntp_configured.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ntp_configured.cfg
new file mode 100644
index 00000000..4fa74b30
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ntp_configured.cfg
@@ -0,0 +1,8 @@
+[
+ {
+ "message 2": "No NTP servers configured.",
+ "message 1": "No NTP peers configured.",
+ "NTP enabled": "no",
+ "NTP Authentication enabled": "no"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_clock.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_clock.cfg
new file mode 100644
index 00000000..93092b4e
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_clock.cfg
@@ -0,0 +1,7 @@
+{
+ "Priority1": "128",
+ "Number of PTP ports": "0",
+ "Domain": "127",
+ "Priority2": "128",
+ "Local clock time": "04:50:24 Etc/UTC 2018/09/04"
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_interface.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_interface.cfg
new file mode 100644
index 00000000..389612e0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_ptp_interface.cfg
@@ -0,0 +1,15 @@
+[
+ {
+ "Transport protocol": "UDP IPv4",
+ "PTP interface state": "NONE",
+ "Forced Master": "no",
+ "Port Clock identity": "N/A",
+ "Announce interval(log mean)": "-2",
+ "PTP Port number": "0",
+ "header": "Interface name: Eth1/1",
+ "Delay Mechanism": "End to End",
+ "Sync interval(log mean)": "-3",
+ "Announce receipt time out": "3",
+ "Delay request interval(log mean)": "0"
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_hosts.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_hosts.cfg
new file mode 100644
index 00000000..4a1312cc
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_hosts.cfg
@@ -0,0 +1,38 @@
+[
+ {
+ "Default notification port": "162",
+ "Default notification community": "public",
+ "Notifications enabled": "yes"
+ },
+ {
+ "Notification sinks": [
+ {
+ "1.1.1.1": [
+ {
+ "Enabled": "yes",
+ "Port": "3",
+ "Notification type": "SNMP v3 inform",
+ "Remote engine ID": ""
+ },
+ {
+ "Username": "sara",
+ "Authentication password": "(set)",
+ "Privacy password": "(set)",
+ "Privacy type": "3des",
+ "Authentication type": "md5"
+ }
+ ]
+ },
+ {
+ "2.2.2.2": [
+ {
+ "Community": "public (default)",
+ "Enabled": "yes",
+ "Port": "5",
+ "Notification type": "SNMP v2c trap"
+ }
+ ]
+ }
+ ]
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_users.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_users.cfg
new file mode 100644
index 00000000..6c957ff0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_show_snmp_users.cfg
@@ -0,0 +1,22 @@
+[
+ {
+ "User name sara": [
+ {
+ "Privacy password": "(NOT SET; user disabled)",
+ "Enabled overall": "yes",
+ "Authentication password": "(NOT SET; user disabled)",
+ "Authentication type": "sha",
+ "Require privacy": "no",
+ "Privacy type": "aes-128"
+ },
+ {
+ "SET access": [
+ {
+ "Capability level": "admin",
+ "Enabled": "yes"
+ }
+ ]
+ }
+ ]
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_snmp_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_snmp_show.cfg
new file mode 100644
index 00000000..c3a16215
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_snmp_show.cfg
@@ -0,0 +1,52 @@
+[
+[
+ {
+ "SNMP port": "161",
+ "System contact": "sara",
+ "System location": "Jordan",
+ "SNMP enabled": "yes"
+ },
+ {
+ "Read-only communities": [
+ {
+ "Lines": [
+ "community_1",
+ "public"
+ ]
+ }
+ ]
+ },
+ {
+ "Read-write communities": [
+ {
+ "Lines": [
+ "community_2"
+ ]
+ }
+ ]
+ },
+ {
+ "Interface listen enabled": "yes"
+ },
+ {
+ "Listen Interfaces": [
+ {
+ "Lines": [
+ "No Listen Interfaces."
+ ]
+ }
+ ]
+ }
+],
+{
+ "Lines": [
+ " snmp-server community community_1 ro",
+ " snmp-server community community_2 rw",
+ " snmp-server contact sara",
+ " snmp-server location Jordan",
+ " snmp-server notify port 1",
+ " snmp-server notify community community_1"
+ ]
+}
+
+] \ No newline at end of file
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_username_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_username_show.cfg
new file mode 100644
index 00000000..d5de67bf
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_username_show.cfg
@@ -0,0 +1,51 @@
+{
+ "xmladmin": [
+ {
+ "CAPABILITY": "admin",
+ "ACCOUNT STATUS": "Password set (SHA512)",
+ "FULL NAME": "XML Admin User"
+ }
+ ],
+ "monitor": [
+ {
+ "CAPABILITY": "monitor",
+ "ACCOUNT STATUS": "Password set (SHA512)",
+ "FULL NAME": "System Monitor"
+ }
+ ],
+ "admin": [
+ {
+ "CAPABILITY": "admin",
+ "ACCOUNT STATUS": "No password required for login",
+ "FULL NAME": "System Administrator"
+ }
+ ],
+ "anass": [
+ {
+ "CAPABILITY": "admin",
+ "ACCOUNT STATUS": "Password set (SHA512)",
+ "FULL NAME": ""
+ }
+ ],
+ "root": [
+ {
+ "CAPABILITY": "admin",
+ "ACCOUNT STATUS": "No password required for login",
+ "FULL NAME": "Root User"
+ }
+ ],
+ "anassh": [
+ {
+ "CAPABILITY": "admin",
+ "ACCOUNT STATUS": "Account disabled",
+ "FULL NAME": ""
+ }
+ ],
+ "xmluser": [
+ {
+ "CAPABILITY": "monitor",
+ "ACCOUNT STATUS": "Password set (SHA512)",
+ "FULL NAME": "XML Monitor User"
+ }
+ ]
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_vlan_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_vlan_show.cfg
new file mode 100644
index 00000000..d1ae46bf
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_vlan_show.cfg
@@ -0,0 +1,14 @@
+{
+ "1": {
+ "Name": "default",
+ "Ports": "Eth1/1, Eth1/2, Eth1/3, Eth1/4, Eth1/5,\nEth1/6, Eth1/7, Eth1/8, Eth1/9, Eth1/10,\nEth1/11, Eth1/12, Eth1/13, Eth1/14, Eth1/15,\nEth1/16"
+ },
+ "10": {
+ "Name": "test 10",
+ "Ports": ""
+ },
+ "20": {
+ "Name": "test 20",
+ "Ports": ""
+ }
+}
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_wjh_show.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_wjh_show.cfg
new file mode 100644
index 00000000..d50f4976
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/onyx_wjh_show.cfg
@@ -0,0 +1,3 @@
+
+no what-just-happened auto-export forwarding enable
+no what-just-happened forwarding enable
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/show_qos_interface_ethernet.cfg b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/show_qos_interface_ethernet.cfg
new file mode 100644
index 00000000..cf2bba8f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/fixtures/show_qos_interface_ethernet.cfg
@@ -0,0 +1,134 @@
+[
+ {
+ "Eth1/1": [
+ {
+ "PCP,DEI rewrite": "enabled",
+ "Default switch-priority": "0",
+ "IP PCP;DEI rewrite": "enable",
+ "Default DEI": "0",
+ "Default PCP": "0",
+ "Trust mode": "both",
+ "DSCP rewrite": "disabled"
+ },
+ {
+ "PCP(DEI); DSCP to switch-priority mapping": [
+ {
+ "2(0) 2(1)": [
+ {
+ "switch-priority": "2",
+ "DSCP": "16 17 18 19 20 21 22 23"
+ }
+ ],
+ "3(0) 3(1)": [
+ {
+ "switch-priority": "3",
+ "DSCP": "24 25 26 27 28 29 30 31"
+ }
+ ],
+ "5(0) 5(1)": [
+ {
+ "switch-priority": "5",
+ "DSCP": "40 41 42 43 44 45 46 47"
+ }
+ ],
+ "0(0) 0(1)": [
+ {
+ "switch-priority": "0",
+ "DSCP": "0 1 2 3 4 5 6 7"
+ }
+ ],
+ "7(0) 7(1)": [
+ {
+ "switch-priority": "7",
+ "DSCP": "56 57 58 59 60 61 62 63"
+ }
+ ],
+ "4(0) 4(1)": [
+ {
+ "switch-priority": "4",
+ "DSCP": "32 33 34 35 36 37 38 39"
+ }
+ ],
+ "6(0) 6(1)": [
+ {
+ "switch-priority": "6",
+ "DSCP": "48 49 50 51 52 53 54 55"
+ }
+ ],
+ "1(0) 1(1)": [
+ {
+ "switch-priority": "1",
+ "DSCP": "8 9 10 11 12 13 14 15"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "PCP(DEI); DSCP rewrite mapping (switch-priority to PCP(DEI); DSCP; traffic-class)": [
+ {
+ "Egress Interface": "Eth1/1"
+ },
+ {
+ "1": [
+ {
+ "PCP(DEI)": "1(0)",
+ "TC": "1",
+ "DSCP": "8"
+ }
+ ],
+ "0": [
+ {
+ "PCP(DEI)": "0(0)",
+ "TC": "0",
+ "DSCP": "0"
+ }
+ ],
+ "3": [
+ {
+ "PCP(DEI)": "3(0)",
+ "TC": "3",
+ "DSCP": "24"
+ }
+ ],
+ "2": [
+ {
+ "PCP(DEI)": "2(0)",
+ "TC": "2",
+ "DSCP": "16"
+ }
+ ],
+ "5": [
+ {
+ "PCP(DEI)": "5(0)",
+ "TC": "5",
+ "DSCP": "40"
+ }
+ ],
+ "4": [
+ {
+ "PCP(DEI)": "4(0)",
+ "TC": "4",
+ "DSCP": "32"
+ }
+ ],
+ "7": [
+ {
+ "PCP(DEI)": "7(0)",
+ "TC": "7",
+ "DSCP": "56"
+ }
+ ],
+ "6": [
+ {
+ "PCP(DEI)": "6(0)",
+ "TC": "6",
+ "DSCP": "48"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+]
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/onyx_module.py b/ansible_collections/mellanox/onyx/tests/unit/modules/onyx_module.py
new file mode 100644
index 00000000..b59401a5
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/onyx_module.py
@@ -0,0 +1,91 @@
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+import json
+import os
+
+from .utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase
+
+fixture_path = os.path.join(os.path.dirname(__file__), 'fixtures')
+fixture_data = {}
+
+
+def load_fixture(name):
+ path = os.path.join(fixture_path, name)
+
+ if path in fixture_data:
+ return fixture_data[path]
+
+ with open(path) as f:
+ data = f.read()
+
+ try:
+ data = json.loads(data)
+ except Exception:
+ pass
+
+ fixture_data[path] = data
+ return data
+
+
+class TestOnyxModule(ModuleTestCase):
+
+ def execute_module(self, failed=False, changed=False, commands=None, is_updates=False, sort=True, transport='cli'):
+
+ self.load_fixtures(commands, transport=transport)
+
+ if failed:
+ result = self.failed()
+ self.assertTrue(result['failed'], result)
+ else:
+ result = self.changed(changed)
+ self.assertEqual(result['changed'], changed, result)
+
+ if commands is not None:
+ if is_updates:
+ commands_res = result.get('updates')
+ else:
+ commands_res = result.get('commands')
+ if sort:
+ self.assertEqual(sorted(commands), sorted(commands_res), commands_res)
+ else:
+ self.assertEqual(commands, commands_res, commands_res)
+
+ return result
+
+ def failed(self):
+ with self.assertRaises(AnsibleFailJson) as exc:
+ self.module.main()
+
+ result = exc.exception.args[0]
+ self.assertTrue(result['failed'], result)
+ return result
+
+ def changed(self, changed=False):
+ with self.assertRaises(AnsibleExitJson) as exc:
+ self.module.main()
+
+ result = exc.exception.args[0]
+ self.assertEqual(result['changed'], changed, result)
+ return result
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ pass
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_aaa.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_aaa.py
new file mode 100644
index 00000000..6c0fdcfd
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_aaa.py
@@ -0,0 +1,74 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_aaa
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxAAAModule(TestOnyxModule):
+
+ module = onyx_aaa
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxAAAModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_aaa.OnyxAAAModule, "_show_aaa_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxAAAModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_aaa.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_aaa_accounting_no_change(self):
+ set_module_args(dict(tacacs_accounting_enabled=False))
+ self.execute_module(changed=False)
+
+ def test_aaa_accounting_with_change(self):
+ set_module_args(dict(tacacs_accounting_enabled=True))
+ commands = ['aaa accounting changes default stop-only tacacs+']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_aaa_auth_default_user_no_change(self):
+ set_module_args(dict(auth_default_user='admin'))
+ self.execute_module(changed=False)
+
+ def test_aaa_auth_default_user_with_change(self):
+ set_module_args(dict(auth_default_user='monitor'))
+ commands = ['aaa authorization map default-user monitor']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_aaa_auth_order_no_change(self):
+ set_module_args(dict(auth_order='remote-first'))
+ self.execute_module(changed=False)
+
+ def test_aaa_auth_order_with_change(self):
+ set_module_args(dict(auth_order='local-only'))
+ commands = ['aaa authorization map order local-only']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_aaa_fallback_no_change(self):
+ set_module_args(dict(auth_fallback_enabled=True))
+ self.execute_module(changed=False)
+
+ def test_aaa_fallback_with_change(self):
+ set_module_args(dict(auth_fallback_enabled=False))
+ commands = ['no aaa authorization map fallback server-err']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bfd.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bfd.py
new file mode 100644
index 00000000..33f8d2d0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bfd.py
@@ -0,0 +1,114 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_bfd
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxBFDModule(TestOnyxModule):
+
+ module = onyx_bfd
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxBFDModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_bfd.OnyxBFDModule, "_show_bfd_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxBFDModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_bfd.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_bfd_shutdown_no_change(self):
+ set_module_args(dict(shutdown=True))
+ self.execute_module(changed=False)
+
+ def test_bfd_shutdown_with_change(self):
+ set_module_args(dict(shutdown=False))
+ commands = ['no ip bfd shutdown']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vrf_bfd_shutdown_no_change(self):
+ set_module_args(dict(shutdown=False,
+ vrf='3'))
+ self.execute_module(changed=False)
+
+ def test_vrf_bfd_shutdown_with_change(self):
+ set_module_args(dict(shutdown=True,
+ vrf='3'))
+ commands = ['ip bfd shutdown vrf 3']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bfd_interval_no_change(self):
+ set_module_args(dict(interval_min_rx=50,
+ interval_multiplier=7,
+ interval_transmit_rate=55))
+ self.execute_module(changed=False)
+
+ def test_bfd_interval_with_change(self):
+ set_module_args(dict(interval_min_rx=55,
+ interval_multiplier=7,
+ interval_transmit_rate=100))
+ commands = ['ip bfd interval min-rx 55 multiplier 7 transmit-rate 100 force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vrf_bfd_interval_no_change(self):
+ set_module_args(dict(interval_min_rx=50,
+ interval_multiplier=7,
+ interval_transmit_rate=55,
+ vrf='3'))
+ self.execute_module(changed=False)
+
+ def test_vrf_bfd_interval_with_change(self):
+ set_module_args(dict(interval_min_rx=55,
+ interval_multiplier=7,
+ interval_transmit_rate=100,
+ vrf='3'))
+ commands = ['ip bfd vrf 3 interval min-rx 55 multiplier 7 transmit-rate 100 force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bfd_iproute_no_change(self):
+ set_module_args(dict(iproute_network_prefix='1.1.1.0',
+ iproute_mask_length=24,
+ iproute_next_hop='3.2.2.2'))
+ self.execute_module(changed=False)
+
+ def test_bfd_iproute_with_change(self):
+ set_module_args(dict(iproute_network_prefix='1.1.1.0',
+ iproute_mask_length=24,
+ iproute_next_hop='3.2.2.3'))
+ commands = ['ip route 1.1.1.0 /24 3.2.2.3 bfd']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vrf_bfd_iproute_no_change(self):
+ set_module_args(dict(iproute_network_prefix='1.1.1.0',
+ iproute_mask_length=24,
+ iproute_next_hop='3.2.2.2',
+ vrf='3'))
+ self.execute_module(changed=False)
+
+ def test_vrf_bfd_iproute_with_change(self):
+ set_module_args(dict(iproute_network_prefix='1.1.1.0',
+ iproute_mask_length=24,
+ iproute_next_hop='3.2.2.3',
+ vrf='3'))
+ commands = ['ip route vrf 3 1.1.1.0 /24 3.2.2.3 bfd']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bgp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bgp.py
new file mode 100644
index 00000000..9f9f1b3a
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_bgp.py
@@ -0,0 +1,111 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_bgp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxBgpModule(TestOnyxModule):
+
+ module = onyx_bgp
+
+ def setUp(self):
+ super(TestOnyxBgpModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_bgp.OnyxBgpModule, "_get_bgp_summary")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxBgpModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_bgp_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_bgp_no_change(self):
+ neighbor = dict(remote_as=322, neighbor='10.2.3.5', multihop=255)
+ set_module_args(dict(as_number=172, router_id='1.2.3.4',
+ neighbors=[neighbor],
+ networks=['172.16.1.0/24'],
+ evpn=True, fast_external_fallover=True,
+ max_paths=31, ecmp_bestpath=True,
+ ))
+ self.execute_module(changed=False)
+
+ def test_bgp_remove(self):
+ set_module_args(dict(as_number=172, state='absent'))
+ commands = ['no router bgp 172']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_with_vrf_changed(self):
+ set_module_args(dict(as_number=173, vrf='new_vrf'))
+ commands = ['no router bgp 172 vrf default', 'router bgp 173 vrf new_vrf', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_change(self):
+ neighbor = dict(remote_as=173, neighbor='10.2.3.4')
+ set_module_args(dict(as_number=174, router_id='1.2.3.4',
+ neighbors=[neighbor],
+ evpn=False, fast_external_fallover=False,
+ max_paths=32, ecmp_bestpath=False,
+ ))
+ commands = ['no router bgp 172 vrf default', 'router bgp 174 vrf default', 'exit',
+ 'router bgp 174 vrf default router-id 1.2.3.4 force',
+ 'router bgp 174 vrf default neighbor 10.2.3.4 remote-as 173',
+ 'no router bgp 174 vrf default neighbor evpn peer-group',
+ 'no router bgp 174 vrf default address-family l2vpn-evpn auto-create',
+ 'router bgp 174 vrf default no bgp fast-external-fallover',
+ 'router bgp 174 vrf default maximum-paths 32',
+ 'router bgp 174 vrf default no bestpath as-path multipath-relax force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_add_neighbor(self):
+ neighbors = [dict(remote_as=173, neighbor='10.2.3.4'),
+ dict(remote_as=175, neighbor='10.2.3.5'),
+ dict(remote_as=175, neighbor='10.2.3.6', multihop=250)]
+ set_module_args(dict(as_number=172, router_id='1.2.3.4',
+ neighbors=neighbors,
+ networks=['172.16.1.0/24'],
+ evpn=True))
+ commands = ['router bgp 172 vrf default neighbor 10.2.3.5 remote-as 175',
+ 'router bgp 172 vrf default neighbor 10.2.3.6 remote-as 175',
+ 'router bgp 172 vrf default neighbor 10.2.3.6 ebgp-multihop 250',
+ 'router bgp 172 vrf default neighbor 10.2.3.6 peer-group evpn',
+ 'router bgp 172 vrf default neighbor 10.2.3.4 peer-group evpn']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_del_neighbor(self):
+ set_module_args(dict(as_number=172,
+ networks=['172.16.1.0/24'],
+ purge=True))
+ commands = ['router bgp 172 vrf default no neighbor 10.2.3.4 remote-as 173',
+ 'router bgp 172 vrf default no neighbor 10.2.3.5 remote-as 322']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_add_network(self):
+ neighbors = [dict(remote_as=173, neighbor='10.2.3.4')]
+ set_module_args(dict(as_number=172, router_id='1.2.3.4',
+ neighbors=neighbors,
+ networks=['172.16.1.0/24', '172.16.2.0/24']))
+ commands = ['router bgp 172 vrf default network 172.16.2.0 /24']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_del_network(self):
+ neighbors = [dict(remote_as=173, neighbor='10.2.3.4')]
+ set_module_args(dict(as_number=172, neighbors=neighbors))
+ commands = ['router bgp 172 no network 172.16.1.0 /24']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_buffer_pool.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_buffer_pool.py
new file mode 100644
index 00000000..f69926a3
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_buffer_pool.py
@@ -0,0 +1,78 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_buffer_pool
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxBufferPoolModule(TestOnyxModule):
+
+ module = onyx_buffer_pool
+ buffer_pool_configured = False
+
+ def setUp(self):
+ super(TestOnyxBufferPoolModule, self).setUp()
+ self.mock_get_buffer_pool_config = patch.object(
+ onyx_buffer_pool.OnyxBufferPoolModule, "_show_traffic_pool")
+ self.get_buffer_pool_config = self.mock_get_buffer_pool_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxBufferPoolModule, self).tearDown()
+ self.mock_get_buffer_pool_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ buffer_pool_config_file = 'onyx_buffer_pool.cfg'
+ self.get_buffer_pool_config.return_value = None
+
+ if self.buffer_pool_configured is True:
+ buffer_pool_data = load_fixture(buffer_pool_config_file)
+ self.get_buffer_pool_config.return_value = buffer_pool_data
+
+ self.load_config.return_value = None
+
+ def test_buffer_pool_no_change(self):
+ self.buffer_pool_configured = True
+ set_module_args(dict(name="roce", pool_type="lossless",
+ memory_percent=50.0, switch_priority=3))
+ self.execute_module(changed=False)
+
+ def test_buffer_pool_with_change(self):
+ set_module_args(dict(name="roce", pool_type="lossless",
+ memory_percent=50.0, switch_priority=3))
+ commands = ["traffic pool roce type lossless",
+ "traffic pool roce memory percent 50.0",
+ "traffic pool roce map switch-priority 3"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_memory_percent_with_change(self):
+ self.buffer_pool_configured = True
+ set_module_args(dict(name="roce", pool_type="lossless",
+ memory_percent=60.0, switch_priority=3))
+ commands = ["traffic pool roce memory percent 60.0"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_switch_priority_with_change(self):
+ self.buffer_pool_configured = True
+ set_module_args(dict(name="roce", pool_type="lossless",
+ memory_percent=50.0, switch_priority=5))
+ commands = ["traffic pool roce map switch-priority 5"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_pool_type_with_change(self):
+ self.buffer_pool_configured = True
+ set_module_args(dict(name="roce", memory_percent=50.0, switch_priority=3))
+ commands = ["traffic pool roce type lossy"]
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_command.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_command.py
new file mode 100644
index 00000000..da447dd0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_command.py
@@ -0,0 +1,114 @@
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+import json
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_command
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxCommandModule(TestOnyxModule):
+
+ module = onyx_command
+
+ def setUp(self):
+ super(TestOnyxCommandModule, self).setUp()
+ self.mock_run_commands = patch(
+ 'ansible_collections.mellanox.onyx.plugins.modules.onyx_command.run_commands')
+ self.run_commands = self.mock_run_commands.start()
+
+ def tearDown(self):
+ super(TestOnyxCommandModule, self).tearDown()
+ self.mock_run_commands.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ def load_from_file(*args, **kwargs):
+ module, commands = args
+ output = list()
+
+ for item in commands:
+ try:
+ obj = json.loads(item['command'])
+ command = obj['command']
+ except ValueError:
+ command = item['command']
+ filename = str(command).replace(' ', '_')
+ filename = 'onyx_command_%s.txt' % filename
+ output.append(load_fixture(filename))
+ return output
+
+ self.run_commands.side_effect = load_from_file
+
+ def test_onyx_command_simple(self):
+ set_module_args(dict(commands=['show version']))
+ result = self.execute_module()
+ self.assertEqual(len(result['stdout']), 1)
+ self.assertTrue(result['stdout'][0].startswith('Product name'))
+
+ def test_onyx_command_multiple(self):
+ set_module_args(dict(commands=['show version', 'show version']))
+ result = self.execute_module()
+ self.assertEqual(len(result['stdout']), 2)
+ self.assertTrue(result['stdout'][0].startswith('Product name'))
+
+ def test_onyx_command_wait_for(self):
+ wait_for = 'result[0] contains "MLNX"'
+ set_module_args(dict(commands=['show version'], wait_for=wait_for))
+ self.execute_module()
+
+ def test_onyx_command_wait_for_fails(self):
+ wait_for = 'result[0] contains "test string"'
+ set_module_args(dict(commands=['show version'], wait_for=wait_for))
+ self.execute_module(failed=True)
+ self.assertEqual(self.run_commands.call_count, 10)
+
+ def test_onyx_command_retries(self):
+ wait_for = 'result[0] contains "test string"'
+ set_module_args(
+ dict(commands=['show version'], wait_for=wait_for, retries=2))
+ self.execute_module(failed=True)
+ self.assertEqual(self.run_commands.call_count, 2)
+
+ def test_onyx_command_match_any(self):
+ wait_for = ['result[0] contains "MLNX"',
+ 'result[0] contains "test string"']
+ set_module_args(dict(
+ commands=['show version'],
+ wait_for=wait_for,
+ match='any'))
+ self.execute_module()
+
+ def test_onyx_command_match_all(self):
+ wait_for = ['result[0] contains "MLNX"',
+ 'result[0] contains "Version summary"']
+ set_module_args(
+ dict(commands=['show version'], wait_for=wait_for, match='all'))
+ self.execute_module()
+
+ def test_onyx_command_match_all_failure(self):
+ wait_for = ['result[0] contains "MLNX"',
+ 'result[0] contains "test string"']
+ commands = ['show version', 'show version']
+ set_module_args(
+ dict(commands=commands, wait_for=wait_for, match='all'))
+ self.execute_module(failed=True)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_config.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_config.py
new file mode 100644
index 00000000..f118eb07
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_config.py
@@ -0,0 +1,113 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_config
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxConfigModule(TestOnyxModule):
+
+ module = onyx_config
+
+ def setUp(self):
+ super(TestOnyxConfigModule, self).setUp()
+
+ self.mock_get_config = patch('ansible_collections.mellanox.onyx.plugins.modules.onyx_config.get_config')
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch('ansible_collections.mellanox.onyx.plugins.modules.onyx_config.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_run_commands = patch('ansible_collections.mellanox.onyx.plugins.modules.onyx_config.run_commands')
+ self.run_commands = self.mock_run_commands.start()
+
+ def tearDown(self):
+ super(TestOnyxConfigModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+ self.mock_run_commands.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_config_config.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_onyx_config_unchanged(self):
+ src = load_fixture('onyx_config_config.cfg')
+ set_module_args(dict(src=src))
+ self.execute_module()
+
+ def test_onyx_config_src(self):
+ src = load_fixture('onyx_config_src.cfg')
+ set_module_args(dict(src=src))
+ commands = [
+ 'interface mlag-port-channel 2']
+ self.execute_module(changed=True, commands=commands, is_updates=True)
+
+ def test_onyx_config_backup(self):
+ set_module_args(dict(backup=True))
+ result = self.execute_module()
+ self.assertIn('__backup__', result)
+
+ def test_onyx_config_save(self):
+ set_module_args(dict(lines=['hostname foo'], save='yes'))
+ self.execute_module(changed=True)
+ self.assertEqual(self.run_commands.call_count, 0)
+ self.assertEqual(self.get_config.call_count, 1)
+ self.assertEqual(self.load_config.call_count, 1)
+ args = self.load_config.call_args[0][1]
+ self.assertIn('configuration write', args)
+
+ def test_onyx_config_lines_wo_parents(self):
+ set_module_args(dict(lines=['hostname foo']))
+ commands = ['hostname foo']
+ self.execute_module(changed=True, commands=commands, is_updates=True)
+
+ def test_onyx_config_before(self):
+ set_module_args(dict(lines=['hostname foo'], before=['test1', 'test2']))
+ commands = ['test1', 'test2', 'hostname foo']
+ self.execute_module(changed=True, commands=commands, sort=False, is_updates=True)
+
+ def test_onyx_config_after(self):
+ set_module_args(dict(lines=['hostname foo'], after=['test1', 'test2']))
+ commands = ['hostname foo', 'test1', 'test2']
+ self.execute_module(changed=True, commands=commands, sort=False, is_updates=True)
+
+ def test_onyx_config_before_after(self):
+ set_module_args(dict(lines=['hostname foo'],
+ before=['test1', 'test2'],
+ after=['test3', 'test4']))
+ commands = ['test1', 'test2', 'hostname foo', 'test3', 'test4']
+ self.execute_module(changed=True, commands=commands, sort=False, is_updates=True)
+
+ def test_onyx_config_config(self):
+ config = 'hostname localhost'
+ set_module_args(dict(lines=['hostname router'], config=config))
+ commands = ['hostname router']
+ self.execute_module(changed=True, commands=commands, is_updates=True)
+
+ def test_onyx_config_match_none(self):
+ lines = ['hostname router']
+ set_module_args(dict(lines=lines, match='none'))
+ self.execute_module(changed=True, commands=lines, is_updates=True)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_facts.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_facts.py
new file mode 100644
index 00000000..bb0d4402
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_facts.py
@@ -0,0 +1,71 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_facts
+
+
+class TestOnyxFacts(TestOnyxModule):
+
+ module = onyx_facts
+
+ def setUp(self):
+ super(TestOnyxFacts, self).setUp()
+
+ self.mock_run_command = patch.object(
+ onyx_facts.FactsBase, "_show_cmd")
+ self.run_command = self.mock_run_command.start()
+
+ def tearDown(self):
+ super(TestOnyxFacts, self).tearDown()
+
+ self.mock_run_command.stop()
+
+ def load_fixtures(self, commands=None, transport=None):
+
+ def load_from_file(*args, **kwargs):
+ command = args[0]
+ filename = "onyx_facts_%s.cfg" % command
+ filename = filename.replace(' ', '_')
+ filename = filename.replace('/', '7')
+ output = load_fixture(filename)
+ return output
+
+ self.run_command.side_effect = load_from_file
+
+ def test_onyx_facts_version(self):
+ set_module_args(dict(gather_subset='version'))
+ result = self.execute_module()
+ facts = result.get('ansible_facts')
+ self.assertEqual(len(facts), 2)
+ version = facts['ansible_net_version']
+ self.assertEqual(version['Product name'], 'MLNX-OS')
+
+ def test_onyx_facts_modules(self):
+ set_module_args(dict(gather_subset='modules'))
+ result = self.execute_module()
+ facts = result.get('ansible_facts')
+ self.assertEqual(len(facts), 2)
+ modules = facts['ansible_net_modules']
+ self.assertIn("MGMT", modules)
+
+ def test_onyx_facts_interfaces(self):
+ set_module_args(dict(gather_subset='interfaces'))
+ result = self.execute_module()
+ facts = result.get('ansible_facts')
+ self.assertEqual(len(facts), 2)
+ interfaces = facts['ansible_net_interfaces']
+ self.assertEqual(len(interfaces), 2)
+
+ def test_onyx_facts_all(self):
+ set_module_args(dict(gather_subset='all'))
+ result = self.execute_module()
+ facts = result.get('ansible_facts')
+ self.assertEqual(len(facts), 4)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp.py
new file mode 100644
index 00000000..153b3359
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp.py
@@ -0,0 +1,127 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_igmp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxIgmpModule(TestOnyxModule):
+
+ module = onyx_igmp
+ enabled = False
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxIgmpModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_igmp.OnyxIgmpModule, "_show_igmp")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxIgmpModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_igmp_show.cfg'
+ data = load_fixture(config_file)
+ if self.enabled:
+ data[0]['IGMP snooping globally'] = 'enabled'
+ self.get_config.return_value = data
+ self.load_config.return_value = None
+
+ def test_igmp_no_change(self):
+ set_module_args(dict(state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_igmp_enable(self):
+ set_module_args(dict(state='enabled'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_last_member_query_interval(self):
+ set_module_args(dict(state='enabled',
+ last_member_query_interval=10))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping last-member-query-interval 10']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_mrouter_timeout(self):
+ set_module_args(dict(state='enabled',
+ mrouter_timeout=100))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping mrouter-timeout 100']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_port_purge_timeout(self):
+ set_module_args(dict(state='enabled',
+ port_purge_timeout=150))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping port-purge-timeout 150']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_report_suppression_interval(self):
+ set_module_args(dict(state='enabled',
+ report_suppression_interval=10))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping report-suppression-interval 10']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_proxy_reporting_disabled(self):
+ set_module_args(dict(state='enabled',
+ proxy_reporting='disabled'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_proxy_reporting_enabled(self):
+ set_module_args(dict(state='enabled',
+ proxy_reporting='enabled'))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping proxy reporting']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_unregistered_multicast_flood(self):
+ set_module_args(dict(state='enabled',
+ unregistered_multicast='flood'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_unregistered_multicast_forward(self):
+ set_module_args(
+ dict(state='enabled',
+ unregistered_multicast='forward-to-mrouter-ports'))
+ commands = [
+ 'ip igmp snooping',
+ 'ip igmp snooping unregistered multicast forward-to-mrouter-ports'
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_version_v2(self):
+ set_module_args(dict(state='enabled',
+ default_version='V2'))
+ commands = ['ip igmp snooping',
+ 'ip igmp snooping version 2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_version_v3(self):
+ set_module_args(dict(state='enabled',
+ default_version='V3'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_disable(self):
+ self.enabled = True
+ set_module_args(dict(state='disabled'))
+ commands = ['no ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_interface.py
new file mode 100644
index 00000000..f3cab2bf
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_interface.py
@@ -0,0 +1,69 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_igmp_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxIgmpInterfaceModule(TestOnyxModule):
+
+ module = onyx_igmp_interface
+
+ def setUp(self):
+ super(TestOnyxIgmpInterfaceModule, self).setUp()
+
+ self.mock_get_config = patch.object(onyx_igmp_interface.OnyxIgmpInterfaceModule, "_show_igmp_interfaces")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxIgmpInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_igmp_interfaces.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_igmp_interface_enabled_no_change(self):
+ set_module_args(dict(state='enabled', name='Eth1/3'))
+ self.execute_module(changed=False)
+
+ def test_igmp_interface_enabled_change(self):
+ set_module_args(dict(state='enabled', name='Eth1/1'))
+ commands = ['interface ethernet 1/1 ip igmp snooping fast-leave']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_interface_disabled_no_change(self):
+ set_module_args(dict(state='disabled', name='Eth1/1'))
+ self.execute_module(changed=False)
+
+ def test_igmp_interface_disabled_change(self):
+ set_module_args(dict(state='disabled', name='Eth1/3'))
+ commands = ['interface ethernet 1/3 no ip igmp snooping fast-leave']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_vlan.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_vlan.py
new file mode 100644
index 00000000..f535e95e
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_igmp_vlan.py
@@ -0,0 +1,190 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_igmp_vlan
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxIgmpVlan(TestOnyxModule):
+
+ module = onyx_igmp_vlan
+ enabled = False
+ mrouter_state = False
+ querier_state = False
+ static_groups_enabled = False
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxIgmpVlan, self).setUp()
+ self.mock_get_igmp_config = patch.object(
+ onyx_igmp_vlan.OnyxIgmpVlanModule, "_show_igmp_vlan")
+ self.get_igmp_config = self.mock_get_igmp_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_igmp_guerier_config = patch.object(
+ onyx_igmp_vlan.OnyxIgmpVlanModule, "_show_igmp_querier_config")
+ self.get_igmp_guerier_config = self.mock_get_igmp_guerier_config.start()
+
+ self.mock_get_igmp_static_groups_config = patch.object(
+ onyx_igmp_vlan.OnyxIgmpVlanModule, "_show_igmp_snooping_groups_config")
+ self.get_igmp_static_groups_config = self.mock_get_igmp_static_groups_config.start()
+
+ def tearDown(self):
+ super(TestOnyxIgmpVlan, self).tearDown()
+ self.mock_get_igmp_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_igmp_guerier_config.stop()
+ self.mock_get_igmp_static_groups_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ igmp_vlan_config_file = 'onyx_show_ip_igmp_snooping.cfg'
+ igmp_querier_config_file = 'onyx_show_ip_igmp_snooping_querier.cfg'
+ igmp_static_groups_file = 'onyx_show_ip_igmp_snooping_groups.cfg'
+ igmp_vlan_data = load_fixture(igmp_vlan_config_file)
+ igmp_querier_data = load_fixture(igmp_querier_config_file)
+ igmp_static_groups_data = None
+ if self.enabled:
+ igmp_vlan_data[0]['message 1'] = 'IGMP snooping is enabled'
+
+ if self.querier_state:
+ igmp_vlan_data[0]['message 3'] = 'Snooping switch is acting as Querier'
+
+ if self.mrouter_state:
+ igmp_vlan_data[0]['mrouter static port list'] = 'Eth1/1'
+
+ if self.static_groups_enabled:
+ igmp_static_groups_data = load_fixture(igmp_static_groups_file)
+
+ self.get_igmp_config.return_value = igmp_vlan_data
+ self.get_igmp_guerier_config = igmp_querier_data
+ self.get_igmp_static_groups_config = igmp_static_groups_data
+ self.load_config.return_value = None
+
+ def test_igmp_disabled_no_change(self):
+ set_module_args(dict(state='disabled', vlan_id=10))
+ self.execute_module(changed=False)
+
+ def test_igmp_disabled_with_change(self):
+ self.enabled = True
+ set_module_args(dict(state='disabled', vlan_id=10))
+ commands = ['vlan 10 no ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_enabled_no_change(self):
+ self.enabled = True
+ set_module_args(dict(state='enabled', vlan_id=10))
+ self.execute_module(changed=False)
+
+ def test_igmp_enabled_with_change(self):
+ set_module_args(dict(state='enabled', vlan_id=10))
+ commands = ['vlan 10 ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_mrouter_disabled_no_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, mrouter=dict(state='disabled', name='Eth1/1')))
+ self.execute_module(changed=False)
+
+ def test_igmp_mrouter_disabled_with_change(self):
+ self.enabled = True
+ self.mrouter_state = True
+ set_module_args(dict(vlan_id=10, mrouter=dict(state='disabled', name='Eth1/1')))
+ commands = ['vlan 10 no ip igmp snooping mrouter interface ethernet 1/1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_mrouter_enabled_no_change(self):
+ self.enabled = True
+ self.mrouter_state = True
+ set_module_args(dict(vlan_id=10, mrouter=dict(state='enabled', name='Eth1/1')))
+ self.execute_module(changed=False)
+
+ def test_igmp_mrouter_enabled_with_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, mrouter=dict(state='enabled', name='Eth1/1')))
+ commands = ['vlan 10 ip igmp snooping mrouter interface ethernet 1/1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_mrouter_enabled_withinterface_change(self):
+ self.enabled = True
+ self.mrouter_state = True
+ set_module_args(dict(vlan_id=10, mrouter=dict(state='enabled', name='Eth1/2')))
+ commands = ['vlan 10 ip igmp snooping mrouter interface ethernet 1/2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_querier_disabled_no_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='disabled')))
+ self.execute_module(changed=False)
+
+ def test_igmp_querier_disabled_with_change(self):
+ self.enabled = True
+ self.querier_state = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='disabled')))
+ commands = ['vlan 10 no ip igmp snooping querier']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_querier_enabled_no_change(self):
+ self.enabled = True
+ self.querier_state = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='enabled')))
+ self.execute_module(changed=False)
+
+ def test_igmp_querier_enabled_with_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='enabled')))
+ commands = ['vlan 10 ip igmp snooping querier']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_querier_attr_no_change(self):
+ self.enabled = True
+ self.querier_state = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='enabled', interval=125, address='-')))
+ self.execute_module(changed=True)
+
+ def test_igmp_querier_attr_with_change(self):
+ self.enabled = True
+ self.querier_state = True
+ set_module_args(dict(vlan_id=10, querier=dict(state='enabled', interval=127, address='10.10.10.1')))
+ commands = ['vlan 10 ip igmp snooping querier query-interval 127',
+ 'vlan 10 ip igmp snooping querier address 10.10.10.1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_version_no_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, version='V3'))
+ self.execute_module(changed=False)
+
+ def test_igmp_version_with_change(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, version='V2'))
+ commands = ['vlan 10 ip igmp snooping version 2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_static_groups_multicast_ip_address_not_configured(self):
+ self.enabled = True
+ set_module_args(dict(vlan_id=10, static_groups=[dict(multicast_ip_address='224.5.5.2', name='Eth1/1',
+ sources=["1.1.1.2", "1.1.1.3"])]))
+ commands = ['vlan 10 ip igmp snooping static-group 224.5.5.2 interface ethernet 1/1',
+ 'vlan 10 ip igmp snooping static-group 224.5.5.2 interface ethernet 1/1 source 1.1.1.2',
+ 'vlan 10 ip igmp snooping static-group 224.5.5.2 interface ethernet 1/1 source 1.1.1.3']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_static_groups_multicast_ip_address_configured_with_change(self):
+ self.enabled = True
+ self.static_groups_enabled = True
+ set_module_args(dict(vlan_id=10, static_groups=[dict(multicast_ip_address='224.5.5.1', name='Eth1/3',
+ sources=["1.1.1.1", "1.1.1.2"])]))
+ commands = ['vlan 10 ip igmp snooping static-group 224.5.5.1 interface ethernet 1/3',
+ 'vlan 10 ip igmp snooping static-group 224.5.5.1 interface ethernet 1/3 source 1.1.1.1',
+ 'vlan 10 ip igmp snooping static-group 224.5.5.1 interface ethernet 1/3 source 1.1.1.2']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_interface.py
new file mode 100644
index 00000000..a0a7f128
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_interface.py
@@ -0,0 +1,125 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxInterfaceModule(TestOnyxModule):
+
+ module = onyx_interface
+
+ def setUp(self):
+ super(TestOnyxInterfaceModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_interface.OnyxInterfaceModule, "_get_interfaces_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_get_interfaces_status = patch.object(
+ onyx_interface.OnyxInterfaceModule, "_get_interfaces_status")
+ self.get_interfaces_status = self.mock_get_interfaces_status.start()
+
+ self.mock_get_interfaces_rates = patch.object(
+ onyx_interface.OnyxInterfaceModule, "_get_interfaces_rates")
+ self.get_interfaces_rates = self.mock_get_interfaces_rates.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_version = patch.object(
+ onyx_interface.OnyxInterfaceModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_interfaces_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def test_mtu_no_change(self):
+ set_module_args(dict(name='Eth1/1', mtu=1500))
+ self.execute_module(changed=False)
+
+ def test_mtu_change(self):
+ set_module_args(dict(name='Eth1/1', mtu=1522))
+ commands = ['interface ethernet 1/1', 'mtu 1522 force', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_speed_no_change(self):
+ set_module_args(dict(name='Eth1/1', speed='40G'))
+ self.execute_module(changed=False)
+
+ def test_speed_change(self):
+ set_module_args(dict(name='Eth1/1', speed='100G'))
+ commands = ['interface ethernet 1/1', 'speed 100G force', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mtu_speed_change(self):
+ set_module_args(dict(name='Eth1/1', speed='100G', mtu=1522))
+ commands = ['interface ethernet 1/1', 'speed 100G force',
+ 'mtu 1522 force', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_admin_state_no_change(self):
+ set_module_args(dict(name='Eth1/1', enabled=True))
+ self.execute_module(changed=False)
+
+ def test_admin_state_change(self):
+ set_module_args(dict(name='Eth1/1', enabled=False))
+ commands = ['interface ethernet 1/1', 'shutdown', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_add_loopback_if(self):
+ set_module_args(dict(name='Loopback 1', description='Loopback test'))
+ commands = ['interface loopback 1', 'description Loopback test',
+ 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_add_vlan_if(self):
+ set_module_args(dict(name='Vlan 101', description='Vlan test',
+ enabled=True))
+ commands = ['interface vlan 101', 'description Vlan test',
+ 'no shutdown', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_remove_vlan_if(self):
+ set_module_args(dict(name='Vlan 1002', state='absent'))
+ commands = ['no interface vlan 1002']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_oper_state_check(self):
+ set_module_args(dict(name='Eth1/1', enabled=True, state='down'))
+ config_file = 'onyx_interfaces_status.cfg'
+ self.get_interfaces_status.return_value = load_fixture(config_file)
+ self.execute_module(changed=False)
+
+ def test_vlan_oper_state_check(self):
+ set_module_args(dict(name='Vlan 1002', state='down'))
+ config_file = 'onyx_interfaces_status.cfg'
+ self.get_interfaces_status.return_value = load_fixture(config_file)
+ self.execute_module(changed=False)
+
+ def test_rx_rate_check(self):
+ set_module_args(dict(name='Eth1/1', enabled=True, rx_rate='ge(9000)'))
+ config_file = 'onyx_interfaces_rates.cfg'
+ self.get_interfaces_rates.return_value = load_fixture(config_file)
+ self.execute_module(changed=False)
+
+ def test_tx_rate_check(self):
+ set_module_args(dict(name='Eth1/1', enabled=True, tx_rate='ge(10000)'))
+ config_file = 'onyx_interfaces_rates.cfg'
+ self.get_interfaces_rates.return_value = load_fixture(config_file)
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l2_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l2_interface.py
new file mode 100644
index 00000000..7c49fb0c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l2_interface.py
@@ -0,0 +1,119 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_l2_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxInterfaceModule(TestOnyxModule):
+
+ module = onyx_l2_interface
+
+ def setUp(self):
+ super(TestOnyxInterfaceModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_l2_interface.OnyxL2InterfaceModule, "_get_switchport_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_version = patch.object(
+ onyx_l2_interface.OnyxL2InterfaceModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_l2_interface_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def test_access_vlan_no_change(self):
+ set_module_args(dict(name='Eth1/11', access_vlan=1))
+ self.execute_module(changed=False)
+
+ def test_trunk_vlans_no_change(self):
+ set_module_args(dict(name='Eth1/10', mode='hybrid', access_vlan=1,
+ trunk_allowed_vlans=[10]))
+ self.execute_module(changed=False)
+
+ def test_access_vlan_change(self):
+ set_module_args(dict(name='Eth1/11', access_vlan=10))
+ commands = ['interface ethernet 1/11', 'switchport access vlan 10',
+ 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_trunk_vlan_change(self):
+ set_module_args(dict(name='Eth1/10', mode='hybrid', access_vlan=1,
+ trunk_allowed_vlans=[11]))
+ commands = ['interface ethernet 1/10',
+ 'switchport hybrid allowed-vlan remove 10',
+ 'switchport hybrid allowed-vlan add 11', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_trunk_vlan_add(self):
+ set_module_args(dict(name='Eth1/10', mode='hybrid', access_vlan=1,
+ trunk_allowed_vlans=[10, 11]))
+ commands = ['interface ethernet 1/10',
+ 'switchport hybrid allowed-vlan add 11', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_switch_port_access(self):
+ set_module_args(dict(name='Eth1/12', mode='access', access_vlan=11))
+ commands = ['interface ethernet 1/12', 'switchport mode access',
+ 'switchport access vlan 11', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_switch_port_trunk(self):
+ set_module_args(dict(name='Eth1/12', mode='trunk',
+ trunk_allowed_vlans=[11]))
+ commands = ['interface ethernet 1/12', 'switchport mode trunk',
+ 'switchport trunk allowed-vlan add 11', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_switch_port_hybrid(self):
+ set_module_args(dict(name='Eth1/12', mode='hybrid', access_vlan=10,
+ trunk_allowed_vlans=[11]))
+ commands = ['interface ethernet 1/12', 'switchport mode hybrid',
+ 'switchport access vlan 10',
+ 'switchport hybrid allowed-vlan add 11', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_aggregate(self):
+ aggregate = list()
+ aggregate.append(dict(name='Eth1/10'))
+ aggregate.append(dict(name='Eth1/12'))
+
+ set_module_args(dict(aggregate=aggregate, access_vlan=10))
+ commands = ['interface ethernet 1/10', 'switchport mode access',
+ 'switchport access vlan 10', 'exit',
+ 'interface ethernet 1/12', 'switchport mode access',
+ 'switchport access vlan 10', 'exit']
+ self.execute_module(changed=True, commands=commands, sort=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l3_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l3_interface.py
new file mode 100644
index 00000000..bab8c3b7
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_l3_interface.py
@@ -0,0 +1,113 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_l3_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxL3InterfaceModule(TestOnyxModule):
+
+ module = onyx_l3_interface
+
+ def setUp(self):
+ super(TestOnyxL3InterfaceModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_l3_interface.OnyxL3InterfaceModule,
+ "_get_interfaces_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_version = patch.object(
+ onyx_l3_interface.OnyxL3InterfaceModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxL3InterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def _execute_module(self, failed=False, changed=False, commands=None, sort=True):
+ if failed:
+ result = self.failed()
+ self.assertTrue(result['failed'], result)
+ else:
+ result = self.changed(changed)
+ self.assertEqual(result['changed'], changed, result)
+
+ if commands is not None:
+ commands_res = result.get('commands')
+ if sort:
+ self.assertEqual(sorted(commands), sorted(commands_res), commands_res)
+ else:
+ self.assertEqual(commands, commands_res, commands_res)
+
+ return result
+
+ def load_fixture(self, config_file):
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def load_eth_ifc_fixture(self):
+ config_file = 'onyx_l3_interface_show.cfg'
+ self.load_fixture(config_file)
+
+ def load_vlan_ifc_fixture(self):
+ config_file = 'onyx_l3_vlan_interface_show.cfg'
+ self.load_fixture(config_file)
+
+ def test_vlan_ifc_no_change(self):
+ set_module_args(dict(name='Vlan 1002', state='present',
+ ipv4='172.3.12.4/24'))
+ self.load_vlan_ifc_fixture()
+ self._execute_module(changed=False)
+
+ def test_vlan_ifc_remove(self):
+ set_module_args(dict(name='Vlan 1002', state='absent'))
+ commands = ['interface vlan 1002 no ip address']
+ self.load_vlan_ifc_fixture()
+ self._execute_module(changed=True, commands=commands)
+
+ def test_vlan_ifc_update(self):
+ set_module_args(dict(name='Vlan 1002', state='present',
+ ipv4='172.3.13.4/24'))
+ commands = ['interface vlan 1002 ip address 172.3.13.4/24']
+ self.load_vlan_ifc_fixture()
+ self._execute_module(changed=True, commands=commands)
+
+ def test_eth_ifc_no_change(self):
+ set_module_args(dict(name='Eth1/5', state='present',
+ ipv4='172.3.12.4/24'))
+ self.load_eth_ifc_fixture()
+ self._execute_module(changed=False)
+
+ def test_eth_ifc_remove(self):
+ set_module_args(dict(name='Eth1/5', state='absent'))
+ commands = ['interface ethernet 1/5 no ip address']
+ self.load_eth_ifc_fixture()
+ self._execute_module(changed=True, commands=commands)
+
+ def test_eth_ifc_update(self):
+ set_module_args(dict(name='Eth1/5', state='present',
+ ipv4='172.3.13.4/24'))
+ commands = ['interface ethernet 1/5 ip address 172.3.13.4/24']
+ self.load_eth_ifc_fixture()
+ self._execute_module(changed=True, commands=commands)
+
+ def test_eth_ifc_add_ip(self):
+ set_module_args(dict(name='Eth1/6', state='present',
+ ipv4='172.3.14.4/24'))
+ commands = ['interface ethernet 1/6 no switchport force',
+ 'interface ethernet 1/6 ip address 172.3.14.4/24']
+ self.load_eth_ifc_fixture()
+ self._execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_linkagg.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_linkagg.py
new file mode 100644
index 00000000..dc54698b
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_linkagg.py
@@ -0,0 +1,116 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_linkagg
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxLinkaggModule(TestOnyxModule):
+
+ module = onyx_linkagg
+
+ def setUp(self):
+ super(TestOnyxLinkaggModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_linkagg.OnyxLinkAggModule,
+ "_get_port_channels")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+ self.mock_get_version = patch.object(
+ onyx_linkagg.OnyxLinkAggModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxLinkaggModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_version.stop()
+
+ def load_fixture(self, config_file):
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def load_port_channel_fixture(self):
+ config_file = 'onyx_port_channel_show.cfg'
+ self.load_fixture(config_file)
+
+ def load_mlag_port_channel_fixture(self):
+ config_file = 'onyx_mlag_port_channel_show.cfg'
+ self.load_fixture(config_file)
+
+ def test_port_channel_no_change(self):
+ set_module_args(dict(name='Po22', state='present',
+ members=['Eth1/7']))
+ self.load_port_channel_fixture()
+ self.execute_module(changed=False)
+
+ def test_port_channel_remove(self):
+ set_module_args(dict(name='Po22', state='absent'))
+ self.load_port_channel_fixture()
+ commands = ['no interface port-channel 22']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_port_channel_add(self):
+ set_module_args(dict(name='Po23', state='present',
+ members=['Eth1/8']))
+ self.load_port_channel_fixture()
+ commands = ['interface port-channel 23', 'exit',
+ 'interface ethernet 1/8 channel-group 23 mode on']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_port_channel_add_member(self):
+ set_module_args(dict(name='Po22', state='present',
+ members=['Eth1/7', 'Eth1/8']))
+ self.load_port_channel_fixture()
+ commands = ['interface ethernet 1/8 channel-group 22 mode on']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_port_channel_remove_member(self):
+ set_module_args(dict(name='Po22', state='present'))
+ self.load_port_channel_fixture()
+ commands = ['interface ethernet 1/7 no channel-group']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_port_channel_no_change(self):
+ set_module_args(dict(name='Mpo33', state='present',
+ members=['Eth1/8']))
+ self.load_mlag_port_channel_fixture()
+ self.execute_module(changed=False)
+
+ def test_mlag_port_channel_remove(self):
+ set_module_args(dict(name='Mpo33', state='absent'))
+ self.load_mlag_port_channel_fixture()
+ commands = ['no interface mlag-port-channel 33']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_port_channel_add(self):
+ set_module_args(dict(name='Mpo34', state='present',
+ members=['Eth1/9']))
+ self.load_mlag_port_channel_fixture()
+ commands = ['interface mlag-port-channel 34', 'exit',
+ 'interface ethernet 1/9 mlag-channel-group 34 mode on']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_port_channel_add_member(self):
+ set_module_args(dict(name='Mpo33', state='present',
+ members=['Eth1/8', 'Eth1/9']))
+ self.load_mlag_port_channel_fixture()
+ commands = ['interface ethernet 1/9 mlag-channel-group 33 mode on']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_port_channel_remove_member(self):
+ set_module_args(dict(name='Mpo33', state='present'))
+ self.load_mlag_port_channel_fixture()
+ commands = ['interface ethernet 1/8 no mlag-channel-group']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp.py
new file mode 100644
index 00000000..e0c1bc0c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp.py
@@ -0,0 +1,68 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_lldp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxInterfaceModule(TestOnyxModule):
+
+ module = onyx_lldp
+
+ def setUp(self):
+ super(TestOnyxInterfaceModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_lldp.OnyxLldpModule, "_get_lldp_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if commands == ['lldp']:
+ self.get_config.return_value = None
+ else:
+ config_file = 'onyx_lldp_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_lldp_no_change(self):
+ set_module_args(dict())
+ self.execute_module(changed=False)
+
+ def test_lldp_disable(self):
+ set_module_args(dict(state='absent'))
+ commands = ['no lldp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_enable(self):
+ set_module_args(dict(state='present'))
+ commands = ['lldp']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp_interface.py
new file mode 100644
index 00000000..934c4e64
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_lldp_interface.py
@@ -0,0 +1,76 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_lldp_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxLldpInterfaceModule(TestOnyxModule):
+
+ module = onyx_lldp_interface
+
+ def setUp(self):
+ super(TestOnyxLldpInterfaceModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_lldp_interface.OnyxLldpInterfaceModule,
+ "_get_lldp_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxLldpInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_lldp_interface_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_lldp_no_change(self):
+ set_module_args(dict(name='Eth1/1', state='present'))
+ self.execute_module(changed=False)
+
+ def test_no_lldp_no_change(self):
+ set_module_args(dict(name='Eth1/2', state='absent'))
+ self.execute_module(changed=False)
+
+ def test_no_lldp_change(self):
+ set_module_args(dict(name='Eth1/2', state='present'))
+ commands = ['interface ethernet 1/2 lldp receive',
+ 'interface ethernet 1/2 lldp transmit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_change(self):
+ set_module_args(dict(name='Eth1/1', state='absent'))
+ commands = ['interface ethernet 1/1 no lldp receive',
+ 'interface ethernet 1/1 no lldp transmit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_aggregate(self):
+ aggregate = [dict(name='Eth1/1'), dict(name='Eth1/2')]
+ set_module_args(dict(aggregate=aggregate, state='present'))
+ commands = ['interface ethernet 1/2 lldp receive',
+ 'interface ethernet 1/2 lldp transmit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_aggregate_purge(self):
+ aggregate = [dict(name='Eth1/3'), dict(name='Eth1/2')]
+ set_module_args(dict(aggregate=aggregate, state='present', purge=True))
+ commands = ['interface ethernet 1/2 lldp receive',
+ 'interface ethernet 1/2 lldp transmit',
+ 'interface ethernet 1/3 lldp receive',
+ 'interface ethernet 1/3 lldp transmit',
+ 'interface ethernet 1/1 no lldp receive',
+ 'interface ethernet 1/1 no lldp transmit']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_magp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_magp.py
new file mode 100644
index 00000000..4745af58
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_magp.py
@@ -0,0 +1,110 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_magp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxMagpModule(TestOnyxModule):
+
+ module = onyx_magp
+
+ def setUp(self):
+ super(TestOnyxMagpModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_magp.OnyxMagpModule,
+ "_get_magp_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_version = patch.object(onyx_magp.OnyxMagpModule,
+ "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxMagpModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_version.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_magp_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def test_magp_absent_no_change(self):
+ set_module_args(dict(interface='Vlan 1002', magp_id=110,
+ state='absent'))
+ self.execute_module(changed=False)
+
+ def test_magp_no_change(self):
+ set_module_args(dict(interface='Vlan 1200', magp_id=103,
+ state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_magp_present_no_change(self):
+ set_module_args(dict(interface='Vlan 1200', magp_id=103))
+ self.execute_module(changed=False)
+
+ def test_magp_enable(self):
+ set_module_args(dict(interface='Vlan 1200', magp_id=103,
+ state='enabled'))
+ commands = ['interface vlan 1200 magp 103 no shutdown']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_disable(self):
+ set_module_args(dict(interface='Vlan 1243', magp_id=102,
+ state='disabled', router_ip='10.0.0.43',
+ router_mac='01:02:03:04:05:06'))
+ commands = ['interface vlan 1243 magp 102 shutdown']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_change_address(self):
+ set_module_args(dict(interface='Vlan 1243', magp_id=102,
+ router_ip='10.0.0.44',
+ router_mac='01:02:03:04:05:07'))
+ commands = [
+ 'interface vlan 1243 magp 102 ip virtual-router address 10.0.0.44',
+ 'interface vlan 1243 magp 102 ip virtual-router mac-address 01:02:03:04:05:07']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_remove_address(self):
+ set_module_args(dict(interface='Vlan 1243', magp_id=102))
+ commands = [
+ 'interface vlan 1243 magp 102 no ip virtual-router address',
+ 'interface vlan 1243 magp 102 no ip virtual-router mac-address']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_add(self):
+ set_module_args(dict(interface='Vlan 1244', magp_id=104,
+ router_ip='10.0.0.44',
+ router_mac='01:02:03:04:05:07'))
+ commands = [
+ 'interface vlan 1244 magp 104',
+ 'exit',
+ 'interface vlan 1244 magp 104 ip virtual-router address 10.0.0.44',
+ 'interface vlan 1244 magp 104 ip virtual-router mac-address 01:02:03:04:05:07']
+ self.execute_module(changed=True, commands=commands, sort=False)
+
+ def test_magp_change_vlan(self):
+ set_module_args(dict(interface='Vlan 1244', magp_id=102,
+ router_ip='10.0.0.43',
+ router_mac='01:02:03:04:05:06'))
+ commands = [
+ 'interface vlan 1243 no magp 102',
+ 'interface vlan 1244 magp 102',
+ 'exit',
+ 'interface vlan 1244 magp 102 ip virtual-router address 10.0.0.43',
+ 'interface vlan 1244 magp 102 ip virtual-router mac-address 01:02:03:04:05:06']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_ipl.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_ipl.py
new file mode 100644
index 00000000..a5d0f6b3
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_ipl.py
@@ -0,0 +1,86 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_mlag_ipl
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxMlagIplModule(TestOnyxModule):
+
+ module = onyx_mlag_ipl
+
+ def setUp(self):
+ super(TestOnyxMlagIplModule, self).setUp()
+ self._mlag_enabled = True
+ self.mock_get_config = patch.object(
+ onyx_mlag_ipl.OnyxMlagIplModule,
+ "_show_mlag_data")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxMlagIplModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._mlag_enabled:
+ config_file = 'onyx_mlag_ipl_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ else:
+ self.get_config.return_value = None
+ self.load_config.return_value = None
+
+ def test_no_ipl_no_change(self):
+ self._mlag_enabled = False
+ set_module_args(dict(name="Po1", state='absent'))
+ self.execute_module(changed=False)
+
+ def test_ipl_no_change(self):
+ self._mlag_enabled = True
+ set_module_args(dict(name="Po1", state='present',
+ vlan_interface='Vlan 1002',
+ peer_address='10.2.2.2'))
+ self.execute_module(changed=False)
+
+ def test_ipl_add(self):
+ self._mlag_enabled = False
+ set_module_args(dict(name="Po1", state='present',
+ vlan_interface='Vlan 1002',
+ peer_address='10.2.2.2'))
+ commands = ['interface port-channel 1 ipl 1',
+ 'interface vlan 1002 ipl 1 peer-address 10.2.2.2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ipl_add_peer(self):
+ self._mlag_enabled = True
+ set_module_args(dict(name="Po1", state='present',
+ vlan_interface='Vlan 1002',
+ peer_address='10.2.2.4'))
+ commands = ['interface vlan 1002 ipl 1 peer-address 10.2.2.4']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ipl_remove(self):
+ self._mlag_enabled = True
+ set_module_args(dict(name="Po1", state='absent'))
+ commands = ['interface port-channel 1 no ipl 1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ipl_change_vlan(self):
+ self._mlag_enabled = True
+ set_module_args(dict(name="Po1", state='present',
+ vlan_interface='Vlan 1003',
+ peer_address='10.2.2.4'))
+ commands = ['interface vlan 1002 no ipl 1',
+ 'interface vlan 1003 ipl 1 peer-address 10.2.2.4']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_vip.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_vip.py
new file mode 100644
index 00000000..44c26fe1
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_mlag_vip.py
@@ -0,0 +1,84 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_mlag_vip
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxMlagVipModule(TestOnyxModule):
+
+ module = onyx_mlag_vip
+
+ def setUp(self):
+ super(TestOnyxMlagVipModule, self).setUp()
+ self._mlag_enabled = True
+ self.mock_show_mlag = patch.object(
+ onyx_mlag_vip.OnyxMLagVipModule,
+ "_show_mlag")
+ self.show_mlag = self.mock_show_mlag.start()
+ self.mock_show_mlag_vip = patch.object(
+ onyx_mlag_vip.OnyxMLagVipModule,
+ "_show_mlag_vip")
+ self.show_mlag_vip = self.mock_show_mlag_vip.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxMlagVipModule, self).tearDown()
+ self.mock_show_mlag.stop()
+ self.mock_show_mlag_vip.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._mlag_enabled:
+ config_file = 'onyx_mlag_vip_show.cfg'
+ self.show_mlag_vip.return_value = load_fixture(config_file)
+ config_file = 'onyx_mlag_show.cfg'
+ self.show_mlag.return_value = load_fixture(config_file)
+ else:
+ self.show_mlag_vip.return_value = None
+ self.show_mlag.return_value = None
+ self.load_config.return_value = None
+
+ def test_mlag_no_change(self):
+ set_module_args(dict(ipaddress='10.209.25.107/24',
+ group_name='neo-mlag-vip-500',
+ mac_address='00:00:5E:00:01:4E'))
+ self.execute_module(changed=False)
+
+ def test_mlag_change(self):
+ self._mlag_enabled = False
+ set_module_args(dict(ipaddress='10.209.25.107/24',
+ group_name='neo-mlag-vip-500',
+ mac_address='00:00:5E:00:01:4E',
+ delay=0))
+ commands = ['mlag-vip neo-mlag-vip-500 ip 10.209.25.107 /24 force',
+ 'mlag system-mac 00:00:5e:00:01:4e', 'no mlag shutdown']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_send_group_name_only_change(self):
+ self._mlag_enabled = False
+ set_module_args(dict(group_name='neo-mlag-vip-500',
+ delay=0))
+ commands = ['mlag-vip neo-mlag-vip-500',
+ 'no mlag shutdown']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_absent_no_change(self):
+ self._mlag_enabled = False
+ set_module_args(dict(state='absent'))
+ self.execute_module(changed=False)
+
+ def test_mlag_absent_change(self):
+ set_module_args(dict(state='absent', delay=0))
+ commands = ['no mlag-vip']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp.py
new file mode 100644
index 00000000..2e1b289a
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp.py
@@ -0,0 +1,76 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ntp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxNTP(TestOnyxModule):
+
+ module = onyx_ntp
+ enabled = False
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxNTP, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_ntp.OnyxNTPModule, "_show_ntp_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxNTP, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_ntp_show.cfg'
+ data = load_fixture(config_file)
+ self.get_config.return_value = data
+ self.load_config.return_value = None
+
+ def test_ntp_state_no_change(self):
+ set_module_args(dict(state='enabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_state_with_change(self):
+ set_module_args(dict(state='disabled'))
+ commands = ['no ntp enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_authenticate_state_no_change(self):
+ set_module_args(dict(authenticate_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_authenticate_state_with_change(self):
+ set_module_args(dict(authenticate_state='enabled'))
+ commands = ['ntp authenticate']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_authentication_key_no_change(self):
+ set_module_args(dict(ntp_authentication_keys=[dict(auth_key_id='22',
+ auth_key_encrypt_type='sha1',
+ auth_key_password='12345')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_authentication_key_with_change(self):
+ set_module_args(dict(ntp_authentication_keys=[dict(auth_key_id='22',
+ auth_key_encrypt_type='md5',
+ auth_key_password='12345')]))
+ commands = ['ntp authentication-key 22 md5 12345']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_trusted_keys_with_change(self):
+ set_module_args(dict(trusted_keys='22'))
+ commands = ['ntp trusted-key 22']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp_servers_peers.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp_servers_peers.py
new file mode 100644
index 00000000..616cae52
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ntp_servers_peers.py
@@ -0,0 +1,134 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ntp_servers_peers
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxNtpServersPeersModule(TestOnyxModule):
+
+ module = onyx_ntp_servers_peers
+ enabled = False
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxNtpServersPeersModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_ntp_servers_peers.OnyxNTPServersPeersModule, "_show_peers_servers_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxNtpServersPeersModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_ntp_servers_peers_show.cfg'
+ data = load_fixture(config_file)
+ self.get_config.return_value = data
+ self.load_config.return_value = None
+
+ def test_ntp_peer_state_no_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ enabled='yes')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_peer_state_with_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ enabled='no')]))
+ commands = ['ntp peer 1.1.1.1 disable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_peer_version_no_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ version='4')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_peer_version_with_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ version='3')]))
+ commands = ['ntp peer 1.1.1.1 version 3']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_peer_key_id_no_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ key_id='5')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_peer_key_id_with_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ key_id='6')]))
+ commands = ['ntp peer 1.1.1.1 keyID 6']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_peer_delete_with_change(self):
+ set_module_args(dict(peer=[dict(ip_or_name='1.1.1.1',
+ state='absent')]))
+ commands = ['no ntp peer 1.1.1.1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_server_state_no_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ enabled='no')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_server_state_with_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ enabled='yes')]))
+ commands = ['no ntp server 2.2.2.2 disable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_server_version_no_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ version='4')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_server_version_with_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ version='3')]))
+ commands = ['ntp server 2.2.2.2 version 3']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_server_keyID_no_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ key_id='99')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_server_keyID_with_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ key_id='8')]))
+ commands = ['ntp server 2.2.2.2 keyID 8']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_server_trusted_state_no_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ trusted_enable='yes')]))
+ self.execute_module(changed=False)
+
+ def test_ntp_server_trusted_state_with_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ trusted_enable='no')]))
+ commands = ['no ntp server 2.2.2.2 trusted-enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_server_delete_with_change(self):
+ set_module_args(dict(server=[dict(ip_or_name='2.2.2.2',
+ state='absent')]))
+ commands = ['no ntp server 2.2.2.2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntpdate_with_change(self):
+ set_module_args(dict(ntpdate='192.22.1.66'))
+ commands = ['ntpdate 192.22.1.66']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ospf.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ospf.py
new file mode 100644
index 00000000..bb35e6e8
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ospf.py
@@ -0,0 +1,106 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ospf
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxOspfModule(TestOnyxModule):
+
+ module = onyx_ospf
+
+ def setUp(self):
+ super(TestOnyxOspfModule, self).setUp()
+ self._ospf_exists = True
+ self.mock_get_config = patch.object(
+ onyx_ospf.OnyxOspfModule,
+ "_get_ospf_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_get_interfaces_config = patch.object(
+ onyx_ospf.OnyxOspfModule,
+ "_get_ospf_interfaces_config")
+ self.get_interfaces_config = self.mock_get_interfaces_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxOspfModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._ospf_exists:
+ config_file = 'onyx_ospf_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ config_file = 'onyx_ospf_interfaces_show.cfg'
+ self.get_interfaces_config.return_value = load_fixture(config_file)
+ else:
+ self.get_config.return_value = None
+ self.get_interfaces_config.return_value = None
+ self.load_config.return_value = None
+
+ def test_ospf_absent_no_change(self):
+ set_module_args(dict(ospf=3, state='absent'))
+ self.execute_module(changed=False)
+
+ def test_ospf_present_no_change(self):
+ interface = dict(name='Loopback 1', area='0.0.0.0')
+ set_module_args(dict(ospf=2, router_id='10.2.3.4',
+ interfaces=[interface]))
+ self.execute_module(changed=False)
+
+ def test_ospf_present_remove(self):
+ set_module_args(dict(ospf=2, state='absent'))
+ commands = ['no router ospf 2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ospf_change_router(self):
+ interface = dict(name='Loopback 1', area='0.0.0.0')
+ set_module_args(dict(ospf=2, router_id='10.2.3.5',
+ interfaces=[interface]))
+ commands = ['router ospf 2', 'router-id 10.2.3.5', 'exit']
+ self.execute_module(changed=True, commands=commands, sort=False)
+
+ def test_ospf_remove_router(self):
+ interface = dict(name='Loopback 1', area='0.0.0.0')
+ set_module_args(dict(ospf=2, interfaces=[interface]))
+ commands = ['router ospf 2', 'no router-id', 'exit']
+ self.execute_module(changed=True, commands=commands, sort=False)
+
+ def test_ospf_add_interface(self):
+ interfaces = [dict(name='Loopback 1', area='0.0.0.0'),
+ dict(name='Loopback 2', area='0.0.0.0')]
+ set_module_args(dict(ospf=2, router_id='10.2.3.4',
+ interfaces=interfaces))
+ commands = ['interface loopback 2 ip ospf area 0.0.0.0']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ospf_remove_interface(self):
+ set_module_args(dict(ospf=2, router_id='10.2.3.4'))
+ commands = ['interface loopback 1 no ip ospf area']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ospf_add(self):
+ self._ospf_exists = False
+ interfaces = [dict(name='Loopback 1', area='0.0.0.0'),
+ dict(name='Vlan 210', area='0.0.0.0'),
+ dict(name='Eth1/1', area='0.0.0.0'),
+ dict(name='Po1', area='0.0.0.0')]
+ set_module_args(dict(ospf=2, router_id='10.2.3.4',
+ interfaces=interfaces))
+ commands = ['router ospf 2', 'router-id 10.2.3.4', 'exit',
+ 'interface loopback 1 ip ospf area 0.0.0.0',
+ 'interface vlan 210 ip ospf area 0.0.0.0',
+ 'interface ethernet 1/1 ip ospf area 0.0.0.0',
+ 'interface port-channel 1 ip ospf area 0.0.0.0']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_pfc_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_pfc_interface.py
new file mode 100644
index 00000000..ddd5f089
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_pfc_interface.py
@@ -0,0 +1,114 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_pfc_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxPfcInterfaceModule(TestOnyxModule):
+
+ module = onyx_pfc_interface
+
+ def setUp(self):
+ super(TestOnyxPfcInterfaceModule, self).setUp()
+ self._pfc_enabled = True
+ self.mock_get_config = patch.object(
+ onyx_pfc_interface.OnyxPfcInterfaceModule,
+ "_get_pfc_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+ self.mock_get_version = patch.object(
+ onyx_pfc_interface.OnyxPfcInterfaceModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxPfcInterfaceModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_version.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._pfc_enabled:
+ suffix = 'enabled'
+ else:
+ suffix = 'disabled'
+ config_file = 'onyx_pfc_interface_%s.cfg' % suffix
+
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def _test_pfc_if(self, if_name, enabled, changed, commands):
+ state = 'enabled' if enabled else 'disabled'
+ set_module_args(dict(name=if_name, state=state))
+ self.execute_module(changed=changed, commands=commands)
+
+ def _test_pfc_no_change(self, enabled):
+ interfaces = ('Eth1/1', 'Eth1/1/2', 'Po1', 'Mpo2')
+ changed = False
+ commands = None
+ for ifc in interfaces:
+ self._test_pfc_if(ifc, enabled, changed, commands)
+
+ def test_pfc_enabled_no_change(self):
+ self._pfc_enabled = True
+ enabled = True
+ self._test_pfc_no_change(enabled)
+
+ def test_pfc_disabled_no_change(self):
+ self._pfc_enabled = False
+ enabled = False
+ self._test_pfc_no_change(enabled)
+
+ def _test_pfc_change(self, enabled):
+ cmd_list = [
+ ('Eth1/1', 'interface ethernet 1/1'),
+ ('Eth1/1/2', 'interface ethernet 1/1/2'),
+ ('Po1', 'interface port-channel 1'),
+ ('Mpo2', 'interface mlag-port-channel 2'),
+ ]
+ changed = True
+ suffix = ' dcb priority-flow-control mode on force'
+ if not enabled:
+ suffix = ' no dcb priority-flow-control mode force'
+ for (if_name, cmd) in cmd_list:
+ commands = [cmd + suffix]
+ self._test_pfc_if(if_name, enabled, changed, commands)
+
+ def test_pfc_disabled_change(self):
+ self._pfc_enabled = False
+ enabled = True
+ self._test_pfc_change(enabled)
+
+ def test_pfc_enabled_change(self):
+ self._pfc_enabled = True
+ enabled = False
+ self._test_pfc_change(enabled)
+
+ def test_pfc_aggregate(self):
+ self._pfc_enabled = False
+ aggregate = [dict(name='Eth1/1'), dict(name='Eth1/1/2')]
+ set_module_args(dict(aggregate=aggregate, state='enabled'))
+ commands = [
+ 'interface ethernet 1/1 dcb priority-flow-control mode on force',
+ 'interface ethernet 1/1/2 dcb priority-flow-control mode on force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_pfc_aggregate_purge(self):
+ self._pfc_enabled = True
+ aggregate = [dict(name='Po1'), dict(name='Mpo2')]
+ set_module_args(dict(aggregate=aggregate, state='enabled', purge=True))
+ commands = [
+ 'interface ethernet 1/1 no dcb priority-flow-control mode force',
+ 'interface ethernet 1/1/2 no dcb priority-flow-control mode force']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocol.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocol.py
new file mode 100644
index 00000000..9750074c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocol.py
@@ -0,0 +1,152 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_protocol
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxProtocolModule(TestOnyxModule):
+
+ module = onyx_protocol
+
+ def setUp(self):
+ super(TestOnyxProtocolModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_protocol.OnyxProtocolModule,
+ "_get_protocols")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_get_ip_config = patch.object(
+ onyx_protocol.OnyxProtocolModule,
+ "_get_ip_routing")
+ self.get_ip_config = self.mock_get_ip_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxProtocolModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_protocols_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_ip_config.return_value = "IP routing: enabled"
+
+ def test_mlag_enable(self):
+ set_module_args(dict(mlag='enabled'))
+ commands = ['protocol mlag']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_disable(self):
+ set_module_args(dict(mlag='disabled'))
+ self.execute_module(changed=False)
+
+ def test_magp_enable(self):
+ set_module_args(dict(magp='enabled'))
+ commands = ['protocol magp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_disable(self):
+ set_module_args(dict(magp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_spanning_tree_enable(self):
+ set_module_args(dict(spanning_tree='enabled'))
+ self.execute_module(changed=False)
+
+ def test_spanning_tree_disable(self):
+ set_module_args(dict(spanning_tree='disabled'))
+ commands = ['no spanning-tree']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_dcb_pfc_enable(self):
+ set_module_args(dict(dcb_pfc='enabled'))
+ commands = ['dcb priority-flow-control enable force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_dcb_pfc_disable(self):
+ set_module_args(dict(dcb_pfc='disabled'))
+ self.execute_module(changed=False)
+
+ def test_igmp_snooping_enable(self):
+ set_module_args(dict(igmp_snooping='enabled'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_snooping_disable(self):
+ set_module_args(dict(igmp_snooping='disabled'))
+ self.execute_module(changed=False)
+
+ def test_lacp_enable(self):
+ set_module_args(dict(lacp='enabled'))
+ commands = ['lacp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lacp_disable(self):
+ set_module_args(dict(lacp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ip_routing_enable(self):
+ set_module_args(dict(ip_routing='enabled'))
+ self.execute_module(changed=False)
+
+ def test_ip_routing_disable(self):
+ set_module_args(dict(ip_routing='disabled'))
+ commands = ['no ip routing']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_enable(self):
+ set_module_args(dict(lldp='enabled'))
+ commands = ['lldp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_disable(self):
+ set_module_args(dict(lldp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_bgp_enable(self):
+ set_module_args(dict(bgp='enabled'))
+ commands = ['protocol bgp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_disable(self):
+ set_module_args(dict(bgp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ospf_enable(self):
+ set_module_args(dict(ospf='enabled'))
+ commands = ['protocol ospf']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ospf_disable(self):
+ set_module_args(dict(ospf='disabled'))
+ self.execute_module(changed=False)
+
+ def test_nve_enable(self):
+ set_module_args(dict(nve='enabled'))
+ commands = ['protocol nve']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_nve_disabled(self):
+ set_module_args(dict(nve='disabled'))
+ self.execute_module(changed=False)
+
+ def test_bfd_enable(self):
+ set_module_args(dict(bfd='enabled'))
+ commands = ['protocol bfd']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bfd_disabled(self):
+ set_module_args(dict(bfd='disabled'))
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocols.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocols.py
new file mode 100644
index 00000000..e438a80d
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_protocols.py
@@ -0,0 +1,143 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_protocol
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxProtocolModule(TestOnyxModule):
+
+ module = onyx_protocol
+
+ def setUp(self):
+ super(TestOnyxProtocolModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_protocol.OnyxProtocolModule,
+ "_get_protocols")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_get_ip_config = patch.object(
+ onyx_protocol.OnyxProtocolModule,
+ "_get_ip_routing")
+ self.get_ip_config = self.mock_get_ip_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxProtocolModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_protocols_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_ip_config.return_value = "IP routing: enabled"
+
+ def test_mlag_enable(self):
+ set_module_args(dict(mlag='enabled'))
+ commands = ['protocol mlag']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_disable(self):
+ set_module_args(dict(mlag='disabled'))
+ self.execute_module(changed=False)
+
+ def test_magp_enable(self):
+ set_module_args(dict(magp='enabled'))
+ commands = ['protocol magp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_magp_disable(self):
+ set_module_args(dict(magp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_spanning_tree_enable(self):
+ set_module_args(dict(spanning_tree='enabled'))
+ self.execute_module(changed=False)
+
+ def test_spanning_tree_disable(self):
+ set_module_args(dict(spanning_tree='disabled'))
+ commands = ['no spanning-tree']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_dcb_pfc_enable(self):
+ set_module_args(dict(dcb_pfc='enabled'))
+ commands = ['dcb priority-flow-control enable force']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_dcb_pfc_disable(self):
+ set_module_args(dict(dcb_pfc='disabled'))
+ self.execute_module(changed=False)
+
+ def test_igmp_snooping_enable(self):
+ set_module_args(dict(igmp_snooping='enabled'))
+ commands = ['ip igmp snooping']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_igmp_snooping_disable(self):
+ set_module_args(dict(igmp_snooping='disabled'))
+ self.execute_module(changed=False)
+
+ def test_lacp_enable(self):
+ set_module_args(dict(lacp='enabled'))
+ commands = ['lacp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lacp_disable(self):
+ set_module_args(dict(lacp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ip_routing_enable(self):
+ set_module_args(dict(ip_routing='enabled'))
+ self.execute_module(changed=False)
+
+ def test_ip_routing_disable(self):
+ set_module_args(dict(ip_routing='disabled'))
+ commands = ['no ip routing']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_enable(self):
+ set_module_args(dict(lldp='enabled'))
+ commands = ['lldp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_lldp_disable(self):
+ set_module_args(dict(lldp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_bgp_enable(self):
+ set_module_args(dict(bgp='enabled'))
+ commands = ['protocol bgp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_bgp_disable(self):
+ set_module_args(dict(bgp='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ospf_enable(self):
+ set_module_args(dict(ospf='enabled'))
+ commands = ['protocol ospf']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ospf_disable(self):
+ set_module_args(dict(ospf='disabled'))
+ self.execute_module(changed=False)
+
+ def test_nve_enable(self):
+ set_module_args(dict(nve='enabled'))
+ commands = ['protocol nve']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_nve_disabled(self):
+ set_module_args(dict(nve='disabled'))
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp.py
new file mode 100644
index 00000000..ca2d2ba0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp.py
@@ -0,0 +1,138 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ptp_global
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxPtpModule(TestOnyxModule):
+
+ module = onyx_ptp_global
+
+ def setUp(self):
+ self._ptp_enabled = True
+ self._ntp_enabled = True
+ super(TestOnyxPtpModule, self).setUp()
+
+ self.mock_get_ptp_config = patch.object(onyx_ptp_global.OnyxPtpGlobalModule, "_show_ptp_config")
+ self.get_ptp_config = self.mock_get_ptp_config.start()
+ self.mock_get_ntp_config = patch.object(onyx_ptp_global.OnyxPtpGlobalModule, "_show_ntp_config")
+ self.get_ntp_config = self.mock_get_ntp_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxPtpModule, self).tearDown()
+ self.mock_get_ptp_config.stop()
+ self.mock_get_ntp_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._ptp_enabled:
+ config_file = 'onyx_show_ptp_clock.cfg'
+ self.get_ptp_config.return_value = load_fixture(config_file)
+ else:
+ self.get_ptp_config.return_value = None
+
+ config_file = 'onyx_show_ntp_configured.cfg'
+ ret_val = load_fixture(config_file)
+ if self._ntp_enabled:
+ ret_val[0]['NTP enabled'] = 'yes'
+ self.get_ntp_config.return_value = ret_val
+ self.load_config.return_value = None
+
+ def test_ptp_enabled_no_change(self):
+ set_module_args(dict(ptp_state='enabled'))
+ self.execute_module(changed=False)
+
+ def test_ptp_enabled_with_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ptp_state='enabled'))
+ commands = ['protocol ptp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ptp_disabled_no_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ptp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ptp_disabled_with_change(self):
+ set_module_args(dict(ptp_state='disabled'))
+ commands = ['no protocol ptp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_enabled_no_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ntp_state='enabled',
+ ptp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_enabled_with_change(self):
+ self._ptp_enabled = False
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='enabled',
+ ptp_state='disabled'))
+ commands = ['ntp enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_disabled_no_change(self):
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_disabled_with_change(self):
+ set_module_args(dict(ntp_state='disabled'))
+ commands = ['no ntp enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_domain_no_change(self):
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='disabled',
+ domain=127))
+ self.execute_module(changed=False)
+
+ def test_set_domain_with_change(self):
+ set_module_args(dict(domain=100))
+ commands = ['ptp domain 100']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_primary_priority_no_change(self):
+ set_module_args(dict(primary_priority=128))
+ self.execute_module(changed=False)
+
+ def test_set_primary_priority_with_change(self):
+ set_module_args(dict(primary_priority=250))
+ commands = ['ptp priority1 250']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_secondary_priority_no_change(self):
+ set_module_args(dict(secondary_priority=128))
+ self.execute_module(changed=False)
+
+ def test_set_secondary_priority_with_change(self):
+ set_module_args(dict(secondary_priority=190))
+ commands = ['ptp priority2 190']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_global.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_global.py
new file mode 100644
index 00000000..ca2d2ba0
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_global.py
@@ -0,0 +1,138 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ptp_global
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxPtpModule(TestOnyxModule):
+
+ module = onyx_ptp_global
+
+ def setUp(self):
+ self._ptp_enabled = True
+ self._ntp_enabled = True
+ super(TestOnyxPtpModule, self).setUp()
+
+ self.mock_get_ptp_config = patch.object(onyx_ptp_global.OnyxPtpGlobalModule, "_show_ptp_config")
+ self.get_ptp_config = self.mock_get_ptp_config.start()
+ self.mock_get_ntp_config = patch.object(onyx_ptp_global.OnyxPtpGlobalModule, "_show_ntp_config")
+ self.get_ntp_config = self.mock_get_ntp_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxPtpModule, self).tearDown()
+ self.mock_get_ptp_config.stop()
+ self.mock_get_ntp_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ if self._ptp_enabled:
+ config_file = 'onyx_show_ptp_clock.cfg'
+ self.get_ptp_config.return_value = load_fixture(config_file)
+ else:
+ self.get_ptp_config.return_value = None
+
+ config_file = 'onyx_show_ntp_configured.cfg'
+ ret_val = load_fixture(config_file)
+ if self._ntp_enabled:
+ ret_val[0]['NTP enabled'] = 'yes'
+ self.get_ntp_config.return_value = ret_val
+ self.load_config.return_value = None
+
+ def test_ptp_enabled_no_change(self):
+ set_module_args(dict(ptp_state='enabled'))
+ self.execute_module(changed=False)
+
+ def test_ptp_enabled_with_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ptp_state='enabled'))
+ commands = ['protocol ptp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ptp_disabled_no_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ptp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ptp_disabled_with_change(self):
+ set_module_args(dict(ptp_state='disabled'))
+ commands = ['no protocol ptp']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_enabled_no_change(self):
+ self._ptp_enabled = False
+ set_module_args(dict(ntp_state='enabled',
+ ptp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_enabled_with_change(self):
+ self._ptp_enabled = False
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='enabled',
+ ptp_state='disabled'))
+ commands = ['ntp enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ntp_disabled_no_change(self):
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='disabled'))
+ self.execute_module(changed=False)
+
+ def test_ntp_disabled_with_change(self):
+ set_module_args(dict(ntp_state='disabled'))
+ commands = ['no ntp enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_domain_no_change(self):
+ self._ntp_enabled = False
+ set_module_args(dict(ntp_state='disabled',
+ domain=127))
+ self.execute_module(changed=False)
+
+ def test_set_domain_with_change(self):
+ set_module_args(dict(domain=100))
+ commands = ['ptp domain 100']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_primary_priority_no_change(self):
+ set_module_args(dict(primary_priority=128))
+ self.execute_module(changed=False)
+
+ def test_set_primary_priority_with_change(self):
+ set_module_args(dict(primary_priority=250))
+ commands = ['ptp priority1 250']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_set_secondary_priority_no_change(self):
+ set_module_args(dict(secondary_priority=128))
+ self.execute_module(changed=False)
+
+ def test_set_secondary_priority_with_change(self):
+ set_module_args(dict(secondary_priority=190))
+ commands = ['ptp priority2 190']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_interface.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_interface.py
new file mode 100644
index 00000000..87f8d9cf
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_ptp_interface.py
@@ -0,0 +1,91 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_ptp_interface
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxPtpInterface(TestOnyxModule):
+
+ module = onyx_ptp_interface
+ enabled = False
+ interfaces = {'Eth1/1': ('ethernet', '1/1'), 'Vlan 1': ('vlan', '1')}
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxPtpInterface, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_ptp_interface.OnyxPtpInterfaceModule, "_show_ptp_interface_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxPtpInterface, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_ptp_interface.cfg'
+ data = None
+ if self.enabled:
+ data = load_fixture(config_file)
+
+ self.get_config.return_value = data
+ self.load_config.return_value = None
+
+ def test_ptp_disabled_no_change(self):
+ for interface in self.interfaces:
+ set_module_args(dict(state='disabled', name=interface))
+ self.execute_module(changed=False)
+
+ def test_ptp_disabled_with_change(self):
+ self.enabled = True
+ for interface in self.interfaces:
+ set_module_args(dict(state='disabled', name=interface))
+ interface_type, interface_id = self.interfaces.get(interface)
+ commands = ['no interface %s %s ptp enable' % (interface_type, interface_id)]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ptp_enabled_no_change(self):
+ self.enabled = True
+ for interface in self.interfaces:
+ set_module_args(dict(state='enabled', name=interface))
+ self.execute_module(changed=False)
+
+ def test_ptp_enabled_with_change(self):
+ for interface in self.interfaces:
+ set_module_args(dict(state='disabled', name=interface))
+ interface_type, interface_id = self.interfaces.get(interface)
+ set_module_args(dict(state='enabled', name=interface))
+ commands = ['interface %s %s ptp enable' % (interface_type, interface_id)]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_ptp_attributs_no_change(self):
+ self.enabled = True
+ for interface in self.interfaces:
+ set_module_args(dict(state='enabled', name=interface, delay_request=0,
+ announce_interval=-2, announce_timeout=3,
+ sync_interval=-3))
+ self.execute_module(changed=False)
+
+ def test_ptp_attributs_with_change(self):
+ self.enabled = True
+ for interface in self.interfaces:
+ set_module_args(dict(state='enabled', name=interface, delay_request=2,
+ announce_interval=-1, announce_timeout=5, sync_interval=-1))
+ interface_type, interface_id = self.interfaces.get(interface)
+ commands = ['interface %s %s ptp delay-req interval 2' % (interface_type, interface_id),
+ 'interface %s %s ptp announce interval -1' % (interface_type, interface_id),
+ 'interface %s %s ptp announce timeout 5' % (interface_type, interface_id),
+ 'interface %s %s ptp sync interval -1' % (interface_type, interface_id)]
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_qos.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_qos.py
new file mode 100644
index 00000000..12961734
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_qos.py
@@ -0,0 +1,52 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_qos
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxQosModule(TestOnyxModule):
+
+ module = onyx_qos
+
+ def setUp(self):
+ super(TestOnyxQosModule, self).setUp()
+ self.mock_get_if_qos_config = patch.object(
+ onyx_qos.OnyxQosModule, "_show_interface_qos")
+ self.get_if_qos_config = self.mock_get_if_qos_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxQosModule, self).tearDown()
+ self.mock_get_if_qos_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ qos_interface_ethernet_config_file = 'show_qos_interface_ethernet.cfg'
+ qos_interface_ethernet_data = load_fixture(qos_interface_ethernet_config_file)
+ self.get_if_qos_config.return_value = qos_interface_ethernet_data
+ self.load_config.return_value = None
+
+ def test_qos_interface_ethernet_no_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], trust="both", rewrite_pcp="enabled",
+ rewrite_dscp="disabled"))
+ self.execute_module(changed=False)
+
+ def test_qos_interface_ethernet_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], trust="L2", rewrite_pcp="disabled",
+ rewrite_dscp="enabled"))
+ commands = ["interface ethernet 1/1 no qos rewrite pcp",
+ "interface ethernet 1/1 qos trust L2",
+ "interface ethernet 1/1 qos rewrite dscp"
+ ]
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp.py
new file mode 100644
index 00000000..82fbda2f
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp.py
@@ -0,0 +1,150 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_snmp
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxSNMPModule(TestOnyxModule):
+
+ module = onyx_snmp
+ enabled = False
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxSNMPModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_snmp.OnyxSNMPModule, "_show_snmp_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxSNMPModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_snmp_show.cfg'
+ data = load_fixture(config_file)
+ self.get_config.return_value = data
+ self.load_config.return_value = None
+
+ def test_snmp_state_no_change(self):
+ set_module_args(dict(state_enabled=True))
+ self.execute_module(changed=False)
+
+ def test_snmp_state_with_change(self):
+ set_module_args(dict(state_enabled=False))
+ commands = ['no snmp-server enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_contact_no_change(self):
+ set_module_args(dict(contact_name='sara'))
+ self.execute_module(changed=False)
+
+ def test_snmp_contact_with_change(self):
+ set_module_args(dict(contact_name='Omar'))
+ commands = ['snmp-server contact Omar']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_location_no_change(self):
+ set_module_args(dict(location='Jordan'))
+ self.execute_module(changed=False)
+
+ def test_snmp_location_with_change(self):
+ set_module_args(dict(location='London'))
+ commands = ['snmp-server location London']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_communities_state_no_change(self):
+ set_module_args(dict(communities_enabled=True))
+ self.execute_module(changed=False)
+
+ def test_snmp_communities_state_with_change(self):
+ set_module_args(dict(communities_enabled=False))
+ commands = ['no snmp-server enable communities']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_multi_communities_state_with_no_change(self):
+ set_module_args(dict(multi_communities_enabled=True))
+ self.execute_module(changed=False)
+
+ def test_snmp_multi_communities_state_with_change(self):
+ set_module_args(dict(multi_communities_enabled=False))
+ commands = ['no snmp-server enable mult-communities']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_communities_no_change(self):
+ set_module_args(dict(snmp_communities=[dict(community_name='community_2',
+ community_type='read-write')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_communities_with_change(self):
+ set_module_args(dict(snmp_communities=[dict(community_name='community_2',
+ community_type='read-only')]))
+ commands = ['snmp-server community community_2 ro']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_communities_delete_with_change(self):
+ set_module_args(dict(snmp_communities=[dict(community_name='community_1',
+ state='absent')]))
+ commands = ['no snmp-server community community_1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_notify_state_no_change(self):
+ set_module_args(dict(notify_enabled=True))
+ self.execute_module(changed=False)
+
+ def test_snmp_notify_state_with_change(self):
+ set_module_args(dict(notify_enabled=False))
+ commands = ['no snmp-server enable notify']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_notify_port_no_change(self):
+ set_module_args(dict(notify_port='1'))
+ self.execute_module(changed=False)
+
+ def test_snmp_notify_port_with_change(self):
+ set_module_args(dict(notify_port='2'))
+ commands = ['snmp-server notify port 2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_notify_community_no_change(self):
+ set_module_args(dict(notify_community='community_1'))
+ self.execute_module(changed=False)
+
+ def test_snmp_notify_community_with_change(self):
+ set_module_args(dict(notify_community='community_2'))
+ commands = ['snmp-server notify community community_2']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_notify_send_test_with_change(self):
+ set_module_args(dict(notify_send_test='yes'))
+ commands = ['snmp-server notify send-test']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_notify_event_with_change(self):
+ set_module_args(dict(notify_event='interface-up'))
+ commands = ['snmp-server notify event interface-up']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_permissions_with_change(self):
+ set_module_args(dict(snmp_permissions=[dict(state_enabled=True,
+ permission_type='RFC1213-MIB')]))
+ commands = ['snmp-server enable set-permission RFC1213-MIB']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_engine_id_reset_with_change(self):
+ set_module_args(dict(engine_id_reset='yes'))
+ commands = ['snmp-server engineID reset']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_hosts.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_hosts.py
new file mode 100644
index 00000000..0affdda2
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_hosts.py
@@ -0,0 +1,170 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_snmp_hosts
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxSNMPHostsModule(TestOnyxModule):
+
+ module = onyx_snmp_hosts
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxSNMPHostsModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_snmp_hosts.OnyxSNMPHostsModule, "_show_hosts_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxSNMPHostsModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_snmp_hosts.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_snmp_host_enabled_state_no_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ enabled=True)]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_enabled_state_with_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ enabled=False)]))
+ commands = ['snmp-server host 1.1.1.1 disable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_notification_type_no_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='2c',
+ port='5')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_notification_type_with_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='inform',
+ version='2c',
+ port='5')]))
+ commands = ['snmp-server host 2.2.2.2 informs port 5 version 2c']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_version_no_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='2c',
+ port='5')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_version_with_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='1',
+ port='5')]))
+ commands = ['snmp-server host 2.2.2.2 traps port 5 version 1']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_port_no_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='2c',
+ port='5')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_port_with_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='2c',
+ port='3')]))
+ commands = ['snmp-server host 2.2.2.2 traps port 3 version 2c']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_user_name_no_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='sara',
+ auth_type='md5',
+ auth_password='sara123saea1234678')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_user_name_with_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='masa',
+ auth_type='md5',
+ auth_password='sara123saea1234678')]))
+ commands = ['snmp-server host 1.1.1.1 informs port 3 version 3 user masa auth md5 sara123saea1234678']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_auth_type_no_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='sara',
+ auth_type='md5',
+ auth_password='sara123saea1234678')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_auth_type_with_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='sara',
+ auth_type='sha',
+ auth_password='sara123saea1234678')]))
+ commands = ['snmp-server host 1.1.1.1 informs port 3 version 3 user sara auth sha sara123saea1234678']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_privacy_type_no_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='sara',
+ auth_type='md5',
+ auth_password='sara123saea1234678',
+ privacy_type='3des',
+ privacy_password='pjqriuewjhksjmdoiws')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_host_privacy_type_with_change(self):
+ set_module_args(dict(hosts=[dict(name='1.1.1.1',
+ notification_type='inform',
+ version='3',
+ port='3',
+ user_name='sara',
+ auth_type='md5',
+ auth_password='sara123saea1234678',
+ privacy_type='aes-192',
+ privacy_password='pjqriuewjhksjmdoiws')]))
+ commands = ['snmp-server host 1.1.1.1 informs port 3 version 3 user sara auth md5 sara123saea1234678 priv aes-192 pjqriuewjhksjmdoiws']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_host_state_with_change(self):
+ set_module_args(dict(hosts=[dict(name='2.2.2.2',
+ notification_type='trap',
+ version='2c',
+ port='5',
+ state='absent')]))
+ commands = ['no snmp-server host 2.2.2.2']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_users.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_users.py
new file mode 100644
index 00000000..c2ad4954
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_snmp_users.py
@@ -0,0 +1,95 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_snmp_users
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxSNMPUsersModule(TestOnyxModule):
+
+ module = onyx_snmp_users
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxSNMPUsersModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_snmp_users.OnyxSNMPUsersModule, "_show_users")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxSNMPUsersModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_show_snmp_users.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_snmp_user_state_no_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ enabled='true')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_user_state_with_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ enabled='false')]))
+ commands = ['no snmp-server user sara v3 enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_user_set_access_state_no_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ set_access_enabled='true')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_user_set_access_state_with_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ set_access_enabled='false')]))
+ commands = ['no snmp-server user sara v3 enable sets']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_user_require_privacy_state_no_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ require_privacy='false')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_user_require_privacy_state_with_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ require_privacy='yes')]))
+ commands = ['snmp-server user sara v3 require-privacy']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_user_auth_type_no_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ auth_type='sha',
+ auth_password='12sara123456')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_user_auth_type_with_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ auth_type='md5',
+ auth_password='12sara123456')]))
+ commands = ['snmp-server user sara v3 auth md5 12sara123456']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_snmp_user_capability_level_no_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ capability_level='admin')]))
+ self.execute_module(changed=False)
+
+ def test_snmp_user_capability_level_with_change(self):
+ set_module_args(dict(users=[dict(name='sara',
+ capability_level='monitor')]))
+ commands = ['snmp-server user sara v3 capability monitor']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_files.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_files.py
new file mode 100644
index 00000000..c7721844
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_files.py
@@ -0,0 +1,113 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_syslog_files
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxSyslogFilesModule(TestOnyxModule):
+
+ module = onyx_syslog_files
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxSyslogFilesModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_syslog_files.OnyxSyslogFilesModule, "show_logging")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxSyslogFilesModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_logging_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_syslog_files_force_rotate(self):
+ set_module_args(dict(rotation=dict(force=True)))
+ commands = ["logging files rotation force"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_files_max_num(self):
+ set_module_args(dict(rotation=dict(max_num=30)))
+ commands = ["logging files rotation max-num 30"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_files_freq(self):
+ set_module_args(dict(rotation=dict(frequency="daily")))
+ commands = ["logging files rotation criteria frequency daily"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_files_size(self):
+ set_module_args(dict(rotation=dict(size=10.5)))
+ commands = ["logging files rotation criteria size 10.5"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_files_delete(self):
+ set_module_args(dict(delete_group="oldest"))
+ commands = ["logging files delete oldest"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_debug_files_force_rotate(self):
+ set_module_args(dict(rotation=dict(force=True), debug=True))
+ commands = ["logging debug-files rotation force"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_debug_files_max_num(self):
+ set_module_args(dict(rotation=dict(max_num=30), debug=True))
+ commands = ["logging debug-files rotation max-num 30"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_debug_files_freq(self):
+ set_module_args(dict(rotation=dict(frequency="weekly"), debug=True))
+ commands = ["logging debug-files rotation criteria frequency weekly"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_debug_files_size(self):
+ set_module_args(dict(rotation=dict(size=10.5), debug=True))
+ commands = ["logging debug-files rotation criteria size 10.5"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_debug_files_delete(self):
+ set_module_args(dict(delete_group="oldest", debug=True))
+ commands = ["logging debug-files delete oldest"]
+ self.execute_module(changed=True, commands=commands)
+
+ ''' nochange '''
+ def test_syslog_files_max_num_no_change(self):
+ set_module_args(dict(rotation=dict(max_num=10)))
+ self.execute_module(changed=False)
+
+ def test_syslog_files_freq_no_change(self):
+ set_module_args(dict(rotation=dict(frequency="weekly")))
+ self.execute_module(changed=False)
+
+ def test_syslog_files_size_no_change(self):
+ set_module_args(dict(rotation=dict(size_pct=10)))
+ self.execute_module(changed=False)
+
+ def test_syslog_debug_files_max_num_no_change(self):
+ set_module_args(dict(rotation=dict(max_num=20), debug=True))
+ self.execute_module(changed=False)
+
+ def test_syslog_debug_files_freq_no_change(self):
+ set_module_args(dict(rotation=dict(frequency="daily"), debug=True))
+ self.execute_module(changed=False)
+
+ def test_syslog_debug_files_size_no_change(self):
+ set_module_args(dict(rotation=dict(size=20), debug=True))
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_remote.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_remote.py
new file mode 100644
index 00000000..aee71536
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_syslog_remote.py
@@ -0,0 +1,91 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_syslog_remote
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxSysLogRemoteModule(TestOnyxModule):
+
+ module = onyx_syslog_remote
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxSysLogRemoteModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_syslog_remote.OnyxSyslogRemoteModule, "show_logging")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxSysLogRemoteModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_logging_config_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_syslog_new_host(self):
+ set_module_args(dict(host="10.10.20.20"))
+ commands = ["logging 10.10.20.20"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_new_host_port(self):
+ set_module_args(dict(host="10.10.20.20", port=8080))
+ commands = ['logging 10.10.20.20', 'logging 10.10.20.20 port 8080']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_override(self):
+ set_module_args(dict(host="10.10.10.12", trap_override=[dict(override_class="sx-sdk", override_priority='emerg'),
+ dict(override_class="mgmt-back", override_priority='emerg')]))
+ commands = ["logging 10.10.10.12 trap override class mgmt-back priority emerg"] # no sx-sdk its already configured
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_trap(self):
+ set_module_args(dict(host="10.10.10.10", trap="notice"))
+ commands = ["logging 10.10.10.10 trap notice"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_include_filter(self):
+ set_module_args(dict(host="10.10.10.10", filter="include", filter_str=".*ERR.*"))
+ commands = ['logging 10.10.10.10 filter include .*ERR.*']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_no_override(self):
+ set_module_args(dict(host="10.10.10.12", trap_override=[dict(override_class="sx-sdk", override_enabled=False),
+ dict(override_class="mgmt-front", override_enabled=False)]))
+ commands = ['no logging 10.10.10.12 trap override class sx-sdk'] # no mgmt-front because doesn't configured
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_no_port(self):
+ set_module_args(dict(host="10.10.10.12", enabled=False))
+ commands = ['no logging 10.10.10.12']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_syslog_filter_no_change(self):
+ set_module_args(dict(host="10.10.10.10", filter="exclude", filter_str=".*ERR.*"))
+ self.execute_module(changed=False)
+
+ def test_syslog_trap_no_change(self):
+ set_module_args(dict(host="10.10.10.10", trap="info"))
+ self.execute_module(changed=False)
+
+ def test_syslog_add_port_no_change(self):
+ set_module_args(dict(host="10.10.10.12", port=80))
+ self.execute_module(changed=False)
+
+ def test_syslog_override_no_change(self):
+ set_module_args(dict(host="10.10.10.12", trap_override=[dict(override_priority="emerg", override_class="sx-sdk")]))
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_traffic_class.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_traffic_class.py
new file mode 100644
index 00000000..da7411e9
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_traffic_class.py
@@ -0,0 +1,108 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_traffic_class
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxTrafficClassModule(TestOnyxModule):
+
+ module = onyx_traffic_class
+ arp_suppression = True
+
+ def setUp(self):
+ super(TestOnyxTrafficClassModule, self).setUp()
+ self.mock_get_congestion_control_config = patch.object(
+ onyx_traffic_class.OnyxTrafficClassModule, "_show_interface_congestion_control")
+ self.get_congestion_control_config = self.mock_get_congestion_control_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_dcb_config = patch.object(
+ onyx_traffic_class.OnyxTrafficClassModule, "_show_interface_dcb_ets")
+ self.get_dcb_config = self.mock_get_dcb_config.start()
+
+ def tearDown(self):
+ super(TestOnyxTrafficClassModule, self).tearDown()
+ self.mock_get_congestion_control_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_dcb_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ interfaces_congestion_control_config_file = 'onyx_show_interface_congestion_control.cfg'
+ interfaces_dcb_config_file = 'onyx_show_dcb_ets_interface.cfg'
+ interfaces_congestion_control_data = load_fixture(interfaces_congestion_control_config_file)
+ interfaces_dcb_config_data = load_fixture(interfaces_dcb_config_file)
+ self.get_congestion_control_config.return_value = interfaces_congestion_control_data
+ self.get_dcb_config.return_value = interfaces_dcb_config_data
+ self.load_config.return_value = None
+
+ def test_configure_congestion_control_disabled_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=1,
+ congestion_control=dict(control="ecn", threshold_mode="absolute",
+ min_threshold=500, max_threshold=1500)))
+ commands = [
+ "interface ethernet 1/1 traffic-class 1 congestion-control ecn minimum-absolute 500 maximum-absolute 1500"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_configure_congestion_control_disabled_with_no_change(self):
+ set_module_args(dict(state="disabled", interfaces=["Eth1/1"], tc=0))
+
+ self.execute_module(changed=False)
+
+ def test_configure_congestion_control_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=2,
+ congestion_control=dict(control="ecn", threshold_mode="relative",
+ min_threshold=9, max_threshold=88)))
+ commands = [
+ "interface ethernet 1/1 traffic-class 2 congestion-control ecn minimum-relative 9 maximum-relative 88"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_configure_congestion_control_absolute_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=3,
+ congestion_control=dict(control="ecn", threshold_mode="absolute",
+ min_threshold=500, max_threshold=1500)))
+ commands = [
+ "interface ethernet 1/1 traffic-class 3 congestion-control ecn minimum-absolute 500 maximum-absolute 1500"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_configure_congestion_control_with_no_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=3,
+ congestion_control=dict(control="ecn", threshold_mode="absolute",
+ min_threshold=500, max_threshold=1550)))
+ self.execute_module(changed=False)
+
+ def test_configure_dcb_mode_with_no_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=3, dcb=dict(mode="strict")))
+ self.execute_module(changed=False)
+
+ def test_configure_dcb_strict_mode_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=1, dcb=dict(mode="strict")))
+ commands = [
+ "interface ethernet 1/1 traffic-class 1 dcb ets strict"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_configure_dcb_wrr_mode_with_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=0, dcb=dict(mode="wrr", weight=10)))
+ commands = [
+ "interface ethernet 1/1 traffic-class 0 dcb ets wrr 10"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_configure_dcb_wrr_mode_with_no_change(self):
+ set_module_args(dict(interfaces=["Eth1/1"], tc=0, dcb=dict(mode="wrr", weight=12)))
+
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_username.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_username.py
new file mode 100644
index 00000000..bfd95b6d
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_username.py
@@ -0,0 +1,99 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_username
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxUsernameModule(TestOnyxModule):
+
+ module = onyx_username
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxUsernameModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_username.OnyxUsernameModule, "_get_username_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxUsernameModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_username_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_new_username(self):
+ set_module_args(dict(username='test'))
+ commands = ['username test']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_change_full_username(self):
+ set_module_args(dict(username='anass', full_name="anasshami"))
+ commands = ['username anass full-name anasshami']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_change_username_password(self):
+ set_module_args(dict(username='anass', password="12345"))
+ commands = ['username anass password 12345']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_change_username_password_encrypted(self):
+ set_module_args(dict(username='anass', password="12345", encrypted_password=True))
+ commands = ['username anass password 7 12345']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_disable_username(self):
+ set_module_args(dict(username='anass', disabled="all"))
+ commands = ['username anass disable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_disable_username_login(self):
+ set_module_args(dict(username='anass', disabled="login"))
+ commands = ['username anass disable login']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_disable_username_password(self):
+ set_module_args(dict(username='anass', disabled="password"))
+ commands = ['username anass disable password']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_change_username_capability(self):
+ set_module_args(dict(username='anass', capability="monitor"))
+ commands = ['username anass capability monitor']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_disconnect_username(self):
+ set_module_args(dict(username='anass', disconnected=True))
+ commands = ['username anass disconnect']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_no_change_username_capability(self):
+ set_module_args(dict(username='anass', capability="admin"))
+ self.execute_module(changed=False)
+
+ def test_no_change_username_disabled(self):
+ set_module_args(dict(username='anassh', disabled="all"))
+ self.execute_module(changed=False)
+
+ def test_no_change_username_nopass(self):
+ set_module_args(dict(username='admin', nopassword=True))
+ self.execute_module(changed=False)
+
+ def test_no_change_full_username(self):
+ set_module_args(dict(username='admin', full_name="System Administrator"))
+ self.execute_module(changed=False)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vlan.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vlan.py
new file mode 100644
index 00000000..0511b7c1
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vlan.py
@@ -0,0 +1,106 @@
+#
+# (c) 2016 Red Hat Inc.
+#
+# This file is part of Ansible
+#
+# Ansible is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Ansible is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_vlan
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxVlanModule(TestOnyxModule):
+
+ module = onyx_vlan
+
+ def setUp(self):
+ super(TestOnyxVlanModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_vlan.OnyxVlanModule, "_get_vlan_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_version = patch.object(
+ onyx_vlan.OnyxVlanModule, "_get_os_version")
+ self.get_version = self.mock_get_version.start()
+
+ def tearDown(self):
+ super(TestOnyxVlanModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_version.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_vlan_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+ self.get_version.return_value = "3.6.5000"
+
+ def test_vlan_no_change(self):
+ set_module_args(dict(vlan_id=20))
+ self.execute_module(changed=False)
+
+ def test_vlan_remove_name(self):
+ set_module_args(dict(vlan_id=10, name=''))
+ commands = ['vlan 10 no name']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_change_name(self):
+ set_module_args(dict(vlan_id=10, name='test-test'))
+ commands = ['vlan 10 name test-test']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_create(self):
+ set_module_args(dict(vlan_id=30))
+ commands = ['vlan 30', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_create_with_name(self):
+ set_module_args(dict(vlan_id=30, name='test-test'))
+ commands = ['vlan 30', 'exit', 'vlan 30 name test-test']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_remove(self):
+ set_module_args(dict(vlan_id=20, state='absent'))
+ commands = ['no vlan 20']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_remove_not_exist(self):
+ set_module_args(dict(vlan_id=30, state='absent'))
+ self.execute_module(changed=False)
+
+ def test_vlan_aggregate(self):
+ aggregate = list()
+ aggregate.append(dict(vlan_id=30))
+ aggregate.append(dict(vlan_id=20))
+ set_module_args(dict(aggregate=aggregate))
+ commands = ['vlan 30', 'exit']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vlan_aggregate_purge(self):
+ aggregate = list()
+ aggregate.append(dict(vlan_id=30))
+ aggregate.append(dict(vlan_id=20))
+ set_module_args(dict(aggregate=aggregate, purge=True))
+ commands = ['vlan 30', 'exit', 'no vlan 10', 'no vlan 1']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vxlan.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vxlan.py
new file mode 100644
index 00000000..99df6eb6
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_vxlan.py
@@ -0,0 +1,101 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_vxlan
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxVxlanModule(TestOnyxModule):
+
+ module = onyx_vxlan
+ arp_suppression = True
+
+ def setUp(self):
+ super(TestOnyxVxlanModule, self).setUp()
+ self.mock_get_vxlan_config = patch.object(
+ onyx_vxlan.OnyxVxlanModule, "_show_vxlan_config")
+ self.get_vxlan_config = self.mock_get_vxlan_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ self.mock_get_nve_detail = patch.object(
+ onyx_vxlan.OnyxVxlanModule, "_show_nve_detail")
+ self.get_nve_detail = self.mock_get_nve_detail.start()
+
+ def tearDown(self):
+ super(TestOnyxVxlanModule, self).tearDown()
+ self.mock_get_vxlan_config.stop()
+ self.mock_load_config.stop()
+ self.mock_get_nve_detail.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ interfaces_nve_config_file = 'onyx_show_interfaces_nve.cfg'
+ interfaces_nve_detail_config_file = 'onyx_show_interfaces_nve_detail.cfg'
+ self.get_nve_detail.return_value = None
+ interfaces_nve_detail_data = load_fixture(interfaces_nve_detail_config_file)
+ interfaces_nv_data = load_fixture(interfaces_nve_config_file)
+ self.get_nve_detail.return_value = interfaces_nve_detail_data
+ if self.arp_suppression is False:
+ interfaces_nve_detail_data[0]["10"][0]["Neigh Suppression"] = "Disable"
+ interfaces_nve_detail_data[0]["6"][0]["Neigh Suppression"] = "Disable"
+ self.get_nve_detail.return_value = interfaces_nve_detail_data
+ self.get_vxlan_config.return_value = interfaces_nv_data
+
+ self.load_config.return_value = None
+
+ def test_configure_vxlan_no_change(self):
+ set_module_args(dict(nve_id=1, loopback_id=1, bgp=True, mlag_tunnel_ip='192.10.10.1',
+ vni_vlan_list=[dict(vlan_id=10, vni_id=10010), dict(vlan_id=6, vni_id=10060)],
+ arp_suppression=True))
+ self.execute_module(changed=False)
+
+ def test_configure_vxlan_with_change(self):
+ set_module_args(dict(nve_id=2, loopback_id=1, bgp=True, mlag_tunnel_ip='192.10.10.1',
+ vni_vlan_list=[dict(vlan_id=10, vni_id=10010), dict(vlan_id=6, vni_id=10060)],
+ arp_suppression=True))
+ commands = [
+ "no interface nve 1", "interface nve 2", "exit",
+ "interface nve 2 vxlan source interface loopback 1 ",
+ "interface nve 2 nve controller bgp", "interface nve 2 vxlan mlag-tunnel-ip 192.10.10.1",
+ "interface nve 2 nve neigh-suppression", "interface nve 2 nve vni 10010 vlan 10",
+ "interface vlan 10", "exit", "interface nve 2 nve vni 10060 vlan 6", "interface vlan 6", "exit"
+ ]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_loopback_id_with_change(self):
+ set_module_args(dict(nve_id=1, loopback_id=2, bgp=True, mlag_tunnel_ip='192.10.10.1',
+ vni_vlan_list=[dict(vlan_id=10, vni_id=10010), dict(vlan_id=6, vni_id=10060)],
+ arp_suppression=True))
+ commands = ["interface nve 1 vxlan source interface loopback 2 "]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_mlag_tunnel_ip_with_change(self):
+ set_module_args(dict(nve_id=1, loopback_id=1, bgp=True, mlag_tunnel_ip='192.10.10.10',
+ vni_vlan_list=[dict(vlan_id=10, vni_id=10010), dict(vlan_id=6, vni_id=10060)],
+ arp_suppression=True))
+ commands = ["interface nve 1 vxlan mlag-tunnel-ip 192.10.10.10"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_vni_vlan_list_with_change(self):
+ set_module_args(dict(nve_id=1, loopback_id=1, bgp=True, mlag_tunnel_ip='192.10.10.1',
+ vni_vlan_list=[dict(vlan_id=11, vni_id=10011), dict(vlan_id=7, vni_id=10061)],
+ arp_suppression=False))
+ commands = ["interface nve 1 nve vni 10011 vlan 11", "interface nve 1 nve vni 10061 vlan 7"]
+ self.execute_module(changed=True, commands=commands)
+
+ def test_arp_suppression_with_change(self):
+ self.arp_suppression = False
+ set_module_args(dict(nve_id=1, loopback_id=1, bgp=True, mlag_tunnel_ip='192.10.10.1',
+ vni_vlan_list=[dict(vlan_id=10, vni_id=10010), dict(vlan_id=6, vni_id=10060)],
+ arp_suppression=True))
+ commands = ["interface vlan 10", "exit", "interface vlan 6", "exit"]
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_wjh.py b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_wjh.py
new file mode 100644
index 00000000..32fa0e54
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/test_onyx_wjh.py
@@ -0,0 +1,66 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+from unittest.mock import patch
+from ansible_collections.mellanox.onyx.plugins.modules import onyx_wjh
+from .utils import set_module_args
+from .onyx_module import TestOnyxModule, load_fixture
+
+
+class TestOnyxWJHModule(TestOnyxModule):
+
+ module = onyx_wjh
+
+ def setUp(self):
+ self.enabled = False
+ super(TestOnyxWJHModule, self).setUp()
+ self.mock_get_config = patch.object(
+ onyx_wjh.OnyxWJHModule, "_get_wjh_config")
+ self.get_config = self.mock_get_config.start()
+
+ self.mock_load_config = patch(
+ 'ansible_collections.mellanox.onyx.plugins.module_utils.network.onyx.onyx.load_config')
+ self.load_config = self.mock_load_config.start()
+
+ def tearDown(self):
+ super(TestOnyxWJHModule, self).tearDown()
+ self.mock_get_config.stop()
+ self.mock_load_config.stop()
+
+ def load_fixtures(self, commands=None, transport='cli'):
+ config_file = 'onyx_wjh_show.cfg'
+ self.get_config.return_value = load_fixture(config_file)
+ self.load_config.return_value = None
+
+ def test_wjh_no_change(self):
+ set_module_args(dict(group='forwarding', enabled=False))
+ self.execute_module(changed=False)
+
+ def test_wjh_enable(self):
+ set_module_args(dict(group='forwarding', enabled=True))
+ commands = ['what-just-happened forwarding enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_wjh_export_no_change(self):
+ set_module_args(dict(export_group='forwarding', auto_export=False))
+ self.execute_module(changed=False)
+
+ def test_wjh_export_enable(self):
+ set_module_args(dict(export_group='forwarding', auto_export=True))
+ commands = ['what-just-happened auto-export forwarding enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_wjh_export_disable(self):
+ set_module_args(dict(export_group='all', auto_export=False))
+ commands = ['no what-just-happened auto-export all enable']
+ self.execute_module(changed=True, commands=commands)
+
+ def test_wjh_clear(self):
+ set_module_args(dict(clear_group='all'))
+ commands = ['clear what-just-happened pcap-files all']
+ self.execute_module(changed=True, commands=commands)
diff --git a/ansible_collections/mellanox/onyx/tests/unit/modules/utils.py b/ansible_collections/mellanox/onyx/tests/unit/modules/utils.py
new file mode 100644
index 00000000..07258f8c
--- /dev/null
+++ b/ansible_collections/mellanox/onyx/tests/unit/modules/utils.py
@@ -0,0 +1,56 @@
+#
+# Copyright: Ansible Project
+# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
+
+# Make coding more python3-ish
+from __future__ import (absolute_import, division, print_function)
+__metaclass__ = type
+
+import json
+
+from unittest import TestCase
+from unittest.mock import patch
+
+from ansible.module_utils import basic
+from ansible.module_utils._text import to_bytes
+
+
+def set_module_args(args):
+ if '_ansible_remote_tmp' not in args:
+ args['_ansible_remote_tmp'] = '/tmp'
+ if '_ansible_keep_remote_files' not in args:
+ args['_ansible_keep_remote_files'] = False
+
+ args = json.dumps({'ANSIBLE_MODULE_ARGS': args})
+ basic._ANSIBLE_ARGS = to_bytes(args)
+
+
+class AnsibleExitJson(Exception):
+ pass
+
+
+class AnsibleFailJson(Exception):
+ pass
+
+
+def exit_json(*args, **kwargs):
+ if 'changed' not in kwargs:
+ kwargs['changed'] = False
+ raise AnsibleExitJson(kwargs)
+
+
+def fail_json(*args, **kwargs):
+ kwargs['failed'] = True
+ raise AnsibleFailJson(kwargs)
+
+
+class ModuleTestCase(TestCase):
+
+ def setUp(self):
+ self.mock_module = patch.multiple(basic.AnsibleModule, exit_json=exit_json, fail_json=fail_json)
+ self.mock_module.start()
+ self.mock_sleep = patch('time.sleep')
+ self.mock_sleep.start()
+ set_module_args({})
+ self.addCleanup(self.mock_module.stop)
+ self.addCleanup(self.mock_sleep.stop)