diff options
Diffstat (limited to 'ansible_collections/junipernetworks/junos/tests/unit')
20 files changed, 1472 insertions, 611 deletions
diff --git a/ansible_collections/junipernetworks/junos/tests/unit/compat/builtins.py b/ansible_collections/junipernetworks/junos/tests/unit/compat/builtins.py deleted file mode 100644 index e898a081e..000000000 --- a/ansible_collections/junipernetworks/junos/tests/unit/compat/builtins.py +++ /dev/null @@ -1,35 +0,0 @@ -# (c) 2014, Toshio Kuratomi <tkuratomi@ansible.com> -# -# 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 - -# -# Compat for python2.7 -# - -# One unittest needs to import builtins via __import__() so we need to have -# the string that represents it -try: - import __builtin__ -except ImportError: - BUILTINS = "builtins" -else: - BUILTINS = "__builtin__" diff --git a/ansible_collections/junipernetworks/junos/tests/unit/compat/mock.py b/ansible_collections/junipernetworks/junos/tests/unit/compat/mock.py index 1d51d36e8..860a9e84b 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/compat/mock.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/compat/mock.py @@ -105,7 +105,6 @@ if sys.version_info >= (3,) and sys.version_info < (3, 4, 4): global file_spec if file_spec is None: - file_spec = list( set(dir(_io.TextIOWrapper)).union(set(dir(_io.BytesIO))), ) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/mock/loader.py b/ansible_collections/junipernetworks/junos/tests/unit/mock/loader.py index 2b5eb36a1..0fc53edcd 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/mock/loader.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/mock/loader.py @@ -31,7 +31,7 @@ from ansible.parsing.dataloader import DataLoader class DictDataLoader(DataLoader): def __init__(self, file_mapping=None): file_mapping = {} if file_mapping is None else file_mapping - assert type(file_mapping) == dict + assert isinstance(file_mapping, dict) super(DictDataLoader, self).__init__() @@ -47,12 +47,12 @@ class DictDataLoader(DataLoader): # TODO: the real _get_file_contents returns a bytestring, so we actually convert the # unicode/text it's created with to utf-8 - def _get_file_contents(self, path): - path = to_text(path) - if path in self._file_mapping: - return (to_bytes(self._file_mapping[path]), False) + def _get_file_contents(self, file_name): + file_name = to_text(file_name) + if file_name in self._file_mapping: + return (to_bytes(self._file_mapping[file_name]), False) else: - raise AnsibleParserError("file not found: %s" % path) + raise AnsibleParserError("file not found: %s" % file_name) def path_exists(self, path): path = to_text(path) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_l2_interfaces_config.cfg b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_l2_interfaces_config.cfg new file mode 100644 index 000000000..26d323fcc --- /dev/null +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_l2_interfaces_config.cfg @@ -0,0 +1,53 @@ +<?xml version="1.0" encoding="UTF-8"?> +<rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> + <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> + <interfaces> + <interface> + <name>ge-0/0/1</name> + <description>Configured by Ansible</description> + <disable/> + <speed>100m</speed> + <mtu>1024</mtu> + <hold-time> + <up>2000</up> + <down>2200</down> + </hold-time> + <link-mode>full-duplex</link-mode> + <unit> + <name>0</name> + <family> + <ethernet-switching> + <interface-mode>access</interface-mode> + <vlan> + <members>vlan100</members> + </vlan> + </ethernet-switching> + </family> + </unit> + </interface> + <interface> + <name>ge-0/0/2</name> + <description>Configured by Ansible</description> + <native-vlan-id>400</native-vlan-id> + <speed>10m</speed> + <mtu>2048</mtu> + <hold-time> + <up>3000</up> + <down>3200</down> + </hold-time> + <unit> + <name>0</name> + <family> + <ethernet-switching> + <interface-mode>trunk</interface-mode> + <vlan> + <members>vlan200</members> + <members>vlan300</members> + </vlan> + </ethernet-switching> + </family> + </unit> + </interface> + </interfaces> + </configuration> +</rpc-reply> diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_ospfv2_config.cfg b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_ospfv2_config.cfg index 67b18028c..94784b875 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_ospfv2_config.cfg +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/fixtures/junos_ospfv2_config.cfg @@ -1,34 +1,214 @@ <?xml version="1.0" encoding="UTF-8"?> <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> - <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> - <protocols> - <ospf> - <area> - <name>0.0.0.10</name> - <stub> - <default-metric>200</default-metric> - </stub> - <interface> - <name>so-0/0/0.0</name> - <passive></passive> - <metric>5</metric> - <priority>3</priority> - <flood-reduction/> - </interface> - </area> - <area> - <name>0.0.0.20</name> - <interface> - <name>ge-1/1/0.0</name> - </interface> - <interface> - <name>ge-2/2/0.0</name> - </interface> - </area> - </ospf> - </protocols> - <routing-options> - <router-id>10.200.16.77</router-id> - </routing-options> - </configuration> + <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> + <protocols> + <ospf> + <spf-options> + <delay>3000</delay> + <holddown>4000</holddown> + <rapid-runs>9</rapid-runs> + <no-ignore-our-externals/> + </spf-options> + <prefix-export-limit>20000</prefix-export-limit> + <overload> + <timeout>1200</timeout> + <allow-route-leaking/> + <stub-network/> + <as-external/> + </overload> + <reference-bandwidth>10g</reference-bandwidth> + <no-rfc-1583/> + <area> + <name>0.0.0.100</name> + <stub> + <default-metric>100</default-metric> + </stub> + <area-range> + <name>10.200.17.0/24</name> + <restrict/> + <exact/> + <override-metric>2000</override-metric> + </area-range> + <area-range> + <name>10.200.15.0/24</name> + <restrict/> + <exact/> + <override-metric>2000</override-metric> + </area-range> + <interface> + <name>so-0/0/0.0</name> + <passive> + </passive> + <bandwidth-based-metrics> + <bandwidth> + <name>1g</name> + <metric>5</metric> + </bandwidth> + <bandwidth> + <name>10g</name> + <metric>40</metric> + </bandwidth> + </bandwidth-based-metrics> + <metric>5</metric> + <priority>3</priority> + <retransmit-interval>2</retransmit-interval> + <hello-interval>2</hello-interval> + <dead-interval>4</dead-interval> + <poll-interval>2</poll-interval> + </interface> + </area> + <area> + <name>0.0.0.200</name> + <stub> + <default-metric>100</default-metric> + </stub> + <area-range> + <name>10.400.17.0/24</name> + <restrict/> + <exact/> + <override-metric>2000</override-metric> + </area-range> + <interface> + <name>so-0/0/1.0</name> + <passive> + </passive> + <bandwidth-based-metrics> + <bandwidth> + <name>1g</name> + <metric>5</metric> + </bandwidth> + </bandwidth-based-metrics> + <authentication> + <md5> + <name>20</name> + <key>$9$.fz6pu1crvEc-w2gDjz36</key> + <start-time>2023-7-12.03:00:00 +0000</start-time> + </md5> + <md5> + <name>10</name> + <key>$9$m5F/u0ISlMhSdsg4jiFn/</key> + <start-time>2023-7-12.03:00:00 +0000</start-time> + </md5> + </authentication> + </interface> + <interface> + <name>so-0/0/2.0</name> + <authentication> + <md5> + <name>20</name> + <key>$9$.fz6pu1crvEc-w2gDjz36</key> + <start-time>2023-7-12.03:00:00 +0000</start-time> + </md5> + </authentication> + </interface> + <interface> + <name>so-0/0/3.0</name> + <authentication> + <md5> + <name>20</name> + <key>$9$.fz6pu1crvEc-w2gDjz36</key> + <start-time>2023-7-12.03:00:00 +0000</start-time> + </md5> + </authentication> + </interface> + </area> + </ospf> + <bgp> + <family> + <inet> + <unicast> + <local-ipv4-address>9.9.9.9</local-ipv4-address> + <extended-nexthop/> + <extended-nexthop-color/> + </unicast> + <flow> + <loops> + <loops>4</loops> + </loops> + <no-install/> + <output-queue-priority> + <expedited/> + </output-queue-priority> + <legacy-redirect-ip-action> + <receive/> + <send/> + </legacy-redirect-ip-action> + <secondary-independent-resolution/> + </flow> + <any> + <accepted-prefix-limit> + <maximum>20</maximum> + <teardown> + <limit-threshold>99</limit-threshold> + <idle-timeout> + <timeout>2000</timeout> + </idle-timeout> + </teardown> + </accepted-prefix-limit> + <damping/> + <delay-route-advertisements> + <minimum-delay> + <routing-uptime>23000</routing-uptime> + <inbound-convergence>32000</inbound-convergence> + </minimum-delay> + <maximum-delay> + <route-age>20</route-age> + <routing-uptime>32000</routing-uptime> + </maximum-delay> + </delay-route-advertisements> + <defer-initial-multipath-build> + <maximum-delay>2</maximum-delay> + </defer-initial-multipath-build> + <graceful-restart> + <forwarding-state-bit>from-fib</forwarding-state-bit> + </graceful-restart> + </any> + <labeled-unicast> + <prefix-limit> + <maximum>20</maximum> + <teardown> + <limit-threshold>99</limit-threshold> + <idle-timeout> + <forever/> + </idle-timeout> + </teardown> + </prefix-limit> + <route-refresh-priority> + <priority>3</priority> + </route-refresh-priority> + <per-prefix-label/> + <per-group-label/> + <rib> + <inet.3/> + </rib> + <explicit-null> + <connected-only/> + </explicit-null> + <resolve-vpn/> + <entropy-label> + <no-next-hop-validation/> + </entropy-label> + </labeled-unicast> + </inet> + <evpn> + <signaling> + <accepted-prefix-limit> + <maximum>20</maximum> + <teardown> + <limit-threshold>98</limit-threshold> + <idle-timeout> + <timeout>2001</timeout> + </idle-timeout> + </teardown> + </accepted-prefix-limit> + <damping/> + <defer-initial-multipath-build> + <maximum-delay>2</maximum-delay> + </defer-initial-multipath-build> + </signaling> + </evpn> + </family> + </bgp> + </protocols> +</configuration> </rpc-reply> diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/junos_module.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/junos_module.py index fe4c37b33..b847e3eef 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/junos_module.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/junos_module.py @@ -73,7 +73,6 @@ class TestJunosModule(ModuleTestCase): defaults=False, format="text", ): - self.load_fixtures(commands, format, changed=changed) if failed: diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_command.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_command.py index 9494eb2b2..720b32981 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_command.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_command.py @@ -37,7 +37,6 @@ RPC_CLI_MAP = {"get-software-information": "show version"} class TestJunosCommandModule(TestJunosModule): - module = junos_command def setUp(self): diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_config.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_config.py index a8e134050..f3adb4767 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_config.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_config.py @@ -32,7 +32,6 @@ from .junos_module import TestJunosModule, load_fixture class TestJunosConfigModule(TestJunosModule): - module = junos_config def setUp(self): @@ -169,6 +168,16 @@ class TestJunosConfigModule(TestJunosModule): load_configuration_args = self.load_configuration.call_args self.assertEqual(rollback, load_configuration_args[1].get("rollback")) + def test_junos_config_rollback_0(self): + rollback = 0 + set_module_args(dict(rollback=rollback)) + self.execute_module(changed=True) + self.assertEqual(self.get_diff.call_count, 1) + self.assertEqual(self.load_configuration.call_count, 1) + self.assertEqual(self.commit_configuration.call_count, 1) + load_configuration_args = self.load_configuration.call_args + self.assertEqual(rollback, load_configuration_args[1].get("rollback")) + def test_junos_config_src_text(self): src = load_fixture("junos_config.text", content="str") set_module_args(dict(src=src)) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_facts.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_facts.py index 0b5b7890c..1e6bc12d3 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_facts.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_facts.py @@ -44,7 +44,6 @@ RPC_CLI_MAP = { class TestJunosCommandModule(TestJunosModule): - module = junos_facts def setUp(self): diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_interfaces.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_interfaces.py index ad4efe9ef..55ee8c766 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_interfaces.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_interfaces.py @@ -103,12 +103,10 @@ class TestJunosInterfacesModule(TestJunosModule): ) commands = [ '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' - "<nc:interface><nc:name>ge-0/0/1</nc:name>" - "<nc:description>This is configured with ansible resource module</nc:description>" - "<nc:speed>100m</nc:speed>" - "<nc:mtu>1024</nc:mtu>" - "</nc:interface></nc:interfaces>", + "<nc:interface><nc:name>ge-0/0/1</nc:name><nc:description>This is configured with ansible resource module</nc:description>" + "<nc:speed>100m</nc:speed><nc:mtu>1024</nc:mtu><nc:enable/></nc:interface></nc:interfaces>", ] + result = self.execute_module(changed=True) self.assertEqual(sorted(result["commands"]), sorted(commands)) @@ -146,12 +144,11 @@ class TestJunosInterfacesModule(TestJunosModule): ), ) result = self.execute_module(changed=True) - commands = [ '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' "<nc:interface><nc:name>ge-0/0/2</nc:name>" "<nc:description>This is configured with ansible</nc:description>" - "<nc:speed>100m</nc:speed><nc:mtu>1024</nc:mtu></nc:interface></nc:interfaces>", + "<nc:speed>100m</nc:speed><nc:mtu>1024</nc:mtu><nc:enable/></nc:interface></nc:interfaces>", ] self.assertEqual(sorted(result["commands"]), commands) @@ -194,7 +191,7 @@ class TestJunosInterfacesModule(TestJunosModule): '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' "<nc:interface><nc:name>ge-0/0/2</nc:name>" "<nc:description>This is configured with ansible</nc:description>" - "<nc:speed>100m</nc:speed><nc:mtu>1024</nc:mtu></nc:interface></nc:interfaces>", + "<nc:speed>100m</nc:speed><nc:mtu>1024</nc:mtu><nc:enable/></nc:interface></nc:interfaces>", ] result = self.execute_module(changed=True) self.assertEqual(sorted(result["commands"]), commands) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_l2_interfaces.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_l2_interfaces.py index d2dd5c687..1524047f5 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_l2_interfaces.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_l2_interfaces.py @@ -50,49 +50,45 @@ class TestJunosL2InterfacesModule(TestJunosModule): "ansible_collections.junipernetworks.junos.plugins.module_utils.network.junos.config.l2_interfaces.l2_interfaces.load_config", ) self.load_config = self.mock_load_config.start() - - self.mock_validate_config = patch( - "ansible_collections.ansible.netcommon.plugins.module_utils.network.common.utils.validate_config", - ) - self.validate_config = self.mock_validate_config.start() - self.mock_commit_configuration = patch( "ansible_collections.junipernetworks.junos.plugins.module_utils.network.junos.config.l2_interfaces.l2_interfaces.commit_configuration", ) self.mock_commit_configuration = self.mock_commit_configuration.start() - - self.mock_get_config = patch( + self.mock_execute_show_command = patch( "ansible_collections.junipernetworks.junos.plugins.module_utils.network.junos.facts.l2_interfaces.l2_interfaces." - "L2_interfacesFacts.get_config", + "L2_interfacesFacts.get_device_data", ) - self.get_config = self.mock_get_config.start() - self.mock_get_res_config = patch( "ansible_collections.junipernetworks.junos.plugins.module_utils.network.junos.config.l2_interfaces.l2_interfaces." "L2_interfaces.get_res_config", ) self.get_res_config = self.mock_get_res_config.start() + self.execute_show_command = self.mock_execute_show_command.start() def tearDown(self): super(TestJunosL2InterfacesModule, self).tearDown() - self.mock_get_config.stop() - self.mock_get_res_config.stop() self.mock_load_config.stop() - self.mock_validate_config.stop() + self.mock_get_res_config.stop() self.mock_lock_configuration.stop() self.mock_unlock_configuration.stop() self.mock_commit_configuration.stop() + self.mock_execute_show_command.stop() - def load_fixtures(self, commands=None, format="text", changed=False): - self.get_config.return_value = load_fixture( - "junos_interfaces_config.xml", - ) - if changed: - self.load_config.return_value = load_fixture( - "get_configuration_rpc_reply_diff.txt", - ) - else: - self.load_config.return_value = None + def load_fixtures( + self, + commands=None, + format="text", + changed=False, + filename=None, + ): + def load_from_file(*args, **kwargs): + if filename: + output = load_fixture(filename) + else: + output = load_fixture("junos_l2_interfaces_config.cfg") + return output + + self.execute_show_command.side_effect = load_from_file def test_junos_l2_interfaces_merged(self): set_module_args( @@ -112,91 +108,113 @@ class TestJunosL2InterfacesModule(TestJunosModule): result = self.execute_module(changed=True) self.assertEqual(sorted(result["commands"]), sorted(commands)) + def test_junos_l2_interfaces_gathered(self): + """ + :return: + """ + set_module_args(dict(state="gathered")) + result = self.execute_module(changed=False) + with open("gathered_outout.py", "w") as file: + file.write(str(result["gathered"])) + gather_list = [ + {"access": {"vlan": "vlan100"}, "name": "ge-0/0/1", "unit": 0, "enhanced_layer": True}, + { + "name": "ge-0/0/2", + "trunk": {"allowed_vlans": ["vlan200", "vlan300"], "native_vlan": "400"}, + "unit": 0, + "enhanced_layer": True, + }, + ] + self.assertEqual(gather_list, result["gathered"]) + def test_junos_l2_interfaces_merged_idempotent(self): - self.get_config.return_value = load_fixture( - "junos_interfaces_config.xml", - ) - src = load_fixture("junos_l2_interfaces.cfg", content="str") - set_module_args(dict(src=src)) set_module_args( dict( - config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"))], + config=[ + dict(name="ge-0/0/1", access=dict(vlan="vlan100"), unit=0, enhanced_layer=True), + dict( + name="ge-0/0/2", + trunk=dict(allowed_vlans=["vlan200", "vlan300"], native_vlan="400"), + unit=0, + enhanced_layer=True, + ), + ], state="merged", ), ) - self.execute_module(changed=False, commands=[]) + result = self.execute_module(changed=True) + self.assertEqual(result["before"], result["after"]) def test_junos_l2_interfaces_replaced(self): - self.get_res_config.return_value = load_fixture( - "junos_interfaces_config.xml", - ) set_module_args( dict( - config=[dict(name="ge-0/0/2", access=dict(vlan="vlan200"))], + config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"), enhanced_layer=False)], state="replaced", ), ) commands = [ '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:interface>' - "<nc:name>ge-0/0/2</nc:name><nc:unit><nc:name>0</nc:name>" - "<nc:family><nc:ethernet-switching>" - '<nc:interface-mode delete="delete"/><nc:vlan delete="delete"/>' - '</nc:ethernet-switching></nc:family></nc:unit><nc:native-vlan-id delete="delete"/>' - "</nc:interface><nc:interface><nc:name>ge-0/0/2</nc:name>" - "<nc:unit><nc:name>0</nc:name><nc:family>" - "<nc:ethernet-switching><nc:interface-mode>access</nc:interface-mode>" - "<nc:vlan><nc:members>vlan200</nc:members></nc:vlan>" - "</nc:ethernet-switching></nc:family></nc:unit></nc:interface></nc:interfaces>", + "<nc:name>ge-0/0/1</nc:name><nc:unit><nc:name>0</nc:name>" + "<nc:family><nc:ethernet-switching><nc:port-mode>access</nc:port-mode>" + "<nc:vlan><nc:members>vlan100</nc:members></nc:vlan></nc:ethernet-switching></nc:family>" + "</nc:unit></nc:interface></nc:interfaces>", ] result = self.execute_module(changed=True) self.assertEqual(sorted(result["commands"]), sorted(commands)) def test_junos_l2_interfaces_replaced_idempotent(self): - self.get_res_config.return_value = load_fixture( - "junos_interfaces_config.xml", - ) - src = load_fixture("junos_l2_interfaces.cfg", content="str") - set_module_args(dict(src=src)) set_module_args( dict( - config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"))], + config=[ + dict(name="ge-0/0/1", access=dict(vlan="vlan100"), unit=0, enhanced_layer=True), + dict( + name="ge-0/0/2", + trunk=dict(allowed_vlans=["vlan200", "vlan300"], native_vlan="400"), + unit=0, + enhanced_layer=True, + ), + ], state="replaced", ), ) - self.execute_module(changed=False, commands=[]) + result = self.execute_module(changed=True) + self.assertEqual(result["before"], result["after"]) def test_junos_l2_interfaces_overridden(self): set_module_args( dict( - config=[dict(name="ge-0/0/3", access=dict(vlan="vlan300"))], + config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"), enhanced_layer=False)], state="overridden", ), ) commands = [ '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:interface>' - "<nc:name>ge-0/0/3</nc:name><nc:unit><nc:name>0</nc:name>" - "<nc:family><nc:ethernet-switching>" - "<nc:interface-mode>access</nc:interface-mode><nc:vlan><nc:members>vlan300</nc:members></nc:vlan>" - "</nc:ethernet-switching></nc:family></nc:unit></nc:interface></nc:interfaces>", + "<nc:name>ge-0/0/1</nc:name><nc:unit><nc:name>0</nc:name>" + "<nc:family><nc:ethernet-switching><nc:port-mode>access</nc:port-mode>" + "<nc:vlan><nc:members>vlan100</nc:members></nc:vlan></nc:ethernet-switching></nc:family>" + "</nc:unit></nc:interface></nc:interfaces>", ] result = self.execute_module(changed=True) - self.assertEqual(sorted(result["commands"]), commands) def test_junos_l2_interfaces_overridden_idempotent(self): - self.get_res_config.return_value = load_fixture( - "junos_interfaces_config.xml", - ) - src = load_fixture("junos_l2_interfaces.cfg", content="str") - set_module_args(dict(src=src)) set_module_args( dict( - config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"))], + config=[ + dict(name="ge-0/0/1", access=dict(vlan="vlan100"), unit=0, enhanced_layer=True), + dict( + name="ge-0/0/2", + trunk=dict(allowed_vlans=["vlan200", "vlan300"], native_vlan="400"), + unit=0, + enhanced_layer=True, + ), + ], state="overridden", ), ) - self.execute_module(changed=False, commands=[]) + result = self.execute_module(changed=True) + self.assertEqual(result["before"], result["after"]) def test_junos_l2_interfaces_delete(self): self.get_res_config.return_value = load_fixture( @@ -216,22 +234,82 @@ class TestJunosL2InterfacesModule(TestJunosModule): self.assertEqual(sorted(result["commands"]), commands) def test_junos_l2_interfaces_delete_idempotent(self): - set_module_args(dict(config=[dict(name="ge-0/0/4")], state="deleted")) - self.execute_module(changed=False, commands=[]) + set_module_args(dict(config=[dict(name="ge-0/0/3")], state="deleted")) + result = self.execute_module(changed=True) + self.assertEqual(result["before"], result["after"]) + + def test_junos_l2_interfaces_parsed(self): + parsed_str = """ + <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> + <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> + <interfaces> + <interface> + <name>ge-0/0/6</name> + <unit> + <name>0</name> + <family> + <ethernet-switching> + <interface-mode>trunk</interface-mode> + <vlan> + <members>vlan02</members> + </vlan> + </ethernet-switching> + </family> + </unit> + </interface> + + <interface> + <name>ge-0/0/37</name> + <unit> + <name>0</name> + <family> + <ethernet-switching> + <vlan> + <members>vlan31</members> + </vlan> + </ethernet-switching> + </family> + </unit> + </interface> + </interfaces> + </configuration> + </rpc-reply> + """ + set_module_args(dict(running_config=parsed_str, state="parsed")) + result = self.execute_module(changed=False) + parsed_list = [ + { + "name": "ge-0/0/6", + "trunk": { + "allowed_vlans": ["vlan02"], + }, + "unit": 0, + "enhanced_layer": True, + }, + { + "access": { + "vlan": "vlan31", + }, + "name": "ge-0/0/37", + "unit": 0, + "enhanced_layer": False, + }, + ] + self.assertEqual(result["parsed"], parsed_list) def test_junos_l2_interfaces_rendered(self): set_module_args( dict( - config=[dict(name="ge-0/0/1", access=dict(vlan="vlan100"))], - state="merged", + config=[dict(name="ge-0/0/4", access=dict(vlan="vlan100"))], + state="rendered", ), ) - commands = [ + rendered = ( '<nc:interfaces xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:interface>' - "<nc:name>ge-0/0/1</nc:name><nc:unit><nc:name>0</nc:name>" - "<nc:family><nc:ethernet-switching><nc:interface-mode>access</nc:interface-mode>" - "<nc:vlan><nc:members>vlan100</nc:members>" - "</nc:vlan></nc:ethernet-switching></nc:family></nc:unit>" - "</nc:interface></nc:interfaces>", - ] - self.execute_module(changed=False, commands=commands) + "<nc:name>ge-0/0/4</nc:name><nc:unit><nc:name>0</nc:name><nc:family>" + "<nc:ethernet-switching><nc:interface-mode>access</nc:interface-mode><nc:vlan>" + "<nc:members>vlan100</nc:members></nc:vlan></nc:ethernet-switching></nc:family>" + "</nc:unit></nc:interface></nc:interfaces>" + ) + result = self.execute_module(changed=False) + self.assertEqual(sorted(result["rendered"]), sorted(rendered)) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_netconf.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_netconf.py index 2a4806839..8f98536c7 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_netconf.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_netconf.py @@ -29,7 +29,6 @@ from .junos_module import TestJunosModule class TestJunosCommandModule(TestJunosModule): - module = junos_netconf def setUp(self): diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv2.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv2.py index 786057021..593acd831 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv2.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv2.py @@ -86,8 +86,24 @@ class TestJunosOspfv2Module(TestJunosModule): self.execute_show_command.side_effect = load_from_file - def sort_ospf(self, entry_list): - entry_list.sort(key=lambda i: i.get("name")) + def sorted_xml(self, xml_string): + temp = [] + index = 0 + while index < len(xml_string): + temp_line = "" + if xml_string[index] == "<": + while index < len(xml_string) and xml_string[index] != ">": + temp_line += xml_string[index] + index += 1 + temp_line += ">" + index += 1 + temp.append(temp_line) + else: + while index < len(xml_string) and xml_string[index] != "<": + temp_line += xml_string[index] + index += 1 + temp.append(temp_line) + return sorted(temp) def test_junos_ospfv2_merged(self): set_module_args( @@ -95,15 +111,52 @@ class TestJunosOspfv2Module(TestJunosModule): config=[ dict( router_id="10.200.16.75", + rfc1583compatibility="False", + external_preference=10, + overload=dict( + allow_route_leaking=True, + as_external=True, + stub_network=True, + timeout=1200, + ), + spf_options=dict( + delay=3000, + holddown=4000, + rapid_runs=9, + no_ignore_our_externals=True, + ), + prefix_export_limit=30000, areas=[ dict( area_id="0.0.0.100", stub=dict(default_metric=200, set=True), + area_ranges=[ + dict( + address="10.200.17.0/24", + exact=True, + restrict=True, + override_metric=2000, + ), + ], interfaces=[ dict( name="so-0/0/0.0", priority=3, metric=5, + flood_reduction=False, + passive=True, + bandwidth_based_metrics=[ + dict( + bandwidth="1g", + metric=5, + ), + ], + timers=dict( + dead_interval=4, + hello_interval=2, + poll_interval=2, + retransmit_interval=2, + ), ), ], ), @@ -115,84 +168,74 @@ class TestJunosOspfv2Module(TestJunosModule): ) commands = [ '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:ospf>' - "<nc:area><nc:name>0.0.0.100</nc:name><nc:interface><nc:name>so-0/0/0.0</nc:name>" - "<nc:priority>3</nc:priority><nc:metric>5</nc:metric></nc:interface><nc:stub>" - "<nc:default-metric>200</nc:default-metric></nc:stub></nc:area></nc:ospf></nc:protocols>", + "<nc:spf-options><nc:delay>3000</nc:delay><nc:holddown>4000</nc:holddown>" + "<nc:rapid-runs>9</nc:rapid-runs><nc:no-ignore-our-externals/></nc:spf-options>" + "<nc:overload><nc:timeout>1200</nc:timeout><nc:allow-route-leaking/><nc:as-external/><nc:stub-network/></nc:overload>" + "<nc:external-preference>10</nc:external-preference>" + "<nc:prefix-export-limit>30000</nc:prefix-export-limit>" + "<nc:no-rfc-1583/>" + "<nc:area><nc:name>0.0.0.100</nc:name><nc:area-range><nc:name>10.200.17.0/24</nc:name>" + "<nc:exact/><nc:restrict/><nc:override-metric>2000</nc:override-metric></nc:area-range>" + "<nc:interface><nc:name>so-0/0/0.0</nc:name><nc:priority>3</nc:priority><nc:metric>5</nc:metric>" + "<nc:passive/><nc:bandwidth-based-metrics><nc:bandwidth><nc:name>1g</nc:name><nc:metric>5</nc:metric>" + "</nc:bandwidth></nc:bandwidth-based-metrics><nc:dead-interval>4</nc:dead-interval><nc:hello-interval>2</nc:hello-interval>" + "<nc:poll-interval>2</nc:poll-interval><nc:retransmit-interval>2</nc:retransmit-interval></nc:interface>" + "<nc:stub><nc:default-metric>200</nc:default-metric></nc:stub></nc:area></nc:ospf></nc:protocols>", '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' "<nc:router-id>10.200.16.75</nc:router-id></nc:routing-options>", ] result = self.execute_module(changed=True, commands=commands) self.assertEqual(sorted(result["commands"]), sorted(commands)) - def test_junos_ospfv2_merged_bandwith(self): + def test_junos_ospfv2_merged_areas(self): set_module_args( dict( config=[ dict( - router_id="10.200.16.77", areas=[ dict( - area_id="0.0.0.10", + area_id="0.0.0.100", + stub=dict(default_metric=200, set=True), + area_ranges=[ + dict( + address="10.200.17.0/24", + ), + dict( + address="10.200.18.0/24", + ), + ], interfaces=[ dict( - name="so-0/0/0.0", - metric=5, + name="so-0/1/0.0", bandwidth_based_metrics=[ - dict(bandwidth="10g", metric=5), + dict( + bandwidth="1g", + metric=5, + ), + dict( + bandwidth="10g", + metric=5, + ), ], ), + dict( + name="so-0/1/0.0", + priority=3, + ), ], ), - ], - ), - ], - state="merged", - ), - ) - result = self.execute_module(changed=True) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn("<nc:name>0.0.0.10</nc:name>", str(result["commands"])) - self.assertIn( - "<nc:interface><nc:name>so-0/0/0.0</nc:name>", - str(result["commands"]), - ) - self.assertIn( - "<nc:bandwidth-based-metrics><nc:bandwidth><nc:name>10g</nc:name>", - str(result["commands"]), - ) - self.assertIn("<nc:metric>5</nc:metric>", str(result["commands"])) - - def test_junos_ospfv2_merged_02(self): - set_module_args( - dict( - config=[ - dict( - router_id="10.200.16.75", - areas=[ dict( - area_id="0.0.0.100", - area_range="3:3::/64", - stub=dict(set=True), + area_id="0.0.0.200", + area_range="10.200.20.0/24", interfaces=[ dict( - name="so-0/0/0.0", - priority=3, - metric=5, - flood_reduction=True, - passive=True, - timers=dict( - dead_interval=100, - hello_interval=80, - retransmit_interval=90, - transit_delay=True, - ), + name="so-0/1/0.0", + bandwidth_based_metrics=[ + dict( + bandwidth="1g", + metric=5, + ), + ], ), ], ), @@ -202,472 +245,564 @@ class TestJunosOspfv2Module(TestJunosModule): state="merged", ), ) - result = self.execute_module(changed=True) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - "<nc:ospf><nc:area><nc:name>0.0.0.100</nc:name>", - str(result["commands"]), - ) - self.assertIn( - "<nc:interface><nc:name>so-0/0/0.0</nc:name>", - str(result["commands"]), - ) - self.assertIn("<nc:priority>3</nc:priority>", str(result["commands"])) - self.assertIn("<nc:flood-reduction/>", str(result["commands"])) - self.assertIn("<nc:metric>5</nc:metric>", str(result["commands"])) - self.assertIn("<nc:passive/>", str(result["commands"])) - self.assertIn( - "<nc:dead-interval>100</nc:dead-interval>", - str(result["commands"]), - ) - self.assertIn( - "<nc:hello-interval>80</nc:hello-interval>", - str(result["commands"]), - ) - self.assertIn( - "<nc:retransmit-interval>90</nc:retransmit-interval>", - str(result["commands"]), - ) - self.assertIn("</nc:interface>", str(result["commands"])) - self.assertIn( - "<nc:stub/></nc:area></nc:ospf></nc:protocols>", - str(result["commands"]), - ) - self.assertIn("</nc:interface>", str(result["commands"])) - self.assertIn( - '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - "<nc:router-id>10.200.16.75</nc:router-id></nc:routing-options>", - str(result["commands"]), - ) + commands = [ + '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' + "<nc:ospf><nc:area><nc:name>0.0.0.100</nc:name><nc:area-range>" + "<nc:name>10.200.17.0/24</nc:name></nc:area-range><nc:area-range>" + "<nc:name>10.200.18.0/24</nc:name></nc:area-range><nc:interface>" + "<nc:name>so-0/1/0.0</nc:name><nc:bandwidth-based-metrics><nc:bandwidth>" + "<nc:name>1g</nc:name><nc:metric>5</nc:metric></nc:bandwidth><nc:bandwidth>" + "<nc:name>10g</nc:name><nc:metric>5</nc:metric></nc:bandwidth></nc:bandwidth-based-metrics>" + "</nc:interface><nc:interface><nc:name>so-0/1/0.0</nc:name><nc:priority>3</nc:priority>" + "</nc:interface><nc:stub><nc:default-metric>200</nc:default-metric></nc:stub></nc:area>" + "<nc:area><nc:name>0.0.0.200</nc:name><nc:area-range><nc:name>10.200.20.0/24</nc:name>" + "</nc:area-range><nc:interface><nc:name>so-0/1/0.0</nc:name><nc:bandwidth-based-metrics>" + "<nc:bandwidth><nc:name>1g</nc:name><nc:metric>5</nc:metric></nc:bandwidth>" + "</nc:bandwidth-based-metrics></nc:interface></nc:area></nc:ospf></nc:protocols>", + ] + result = self.execute_module(changed=True, commands=commands) + self.assertEqual(sorted(result["commands"]), sorted(commands)) - def test_junos_ospfv2_merged_03(self): + def test_junos_ospfv2_gathered(self): + """ + :return: + """ + set_module_args(dict(state="gathered")) + result = self.execute_module(changed=False) + gather_list = [ + { + "areas": [ + { + "area_id": "0.0.0.100", + "area_range": "['10.200.17.0/24', '10.200.15.0/24']", + "area_ranges": [ + { + "address": "10.200.17.0/24", + "exact": True, + "override_metric": 2000, + "restrict": True, + }, + { + "address": "10.200.15.0/24", + "exact": True, + "override_metric": 2000, + "restrict": True, + }, + ], + "interfaces": [ + { + "bandwidth_based_metrics": [ + { + "bandwidth": "1g", + "metric": 5, + }, + { + "bandwidth": "10g", + "metric": 40, + }, + ], + "metric": 5, + "name": "so-0/0/0.0", + "passive": True, + "priority": 3, + "timers": { + "dead_interval": 4, + "hello_interval": 2, + "poll_interval": 2, + "retransmit_interval": 2, + }, + }, + ], + "stub": { + "default_metric": 100, + "set": True, + }, + }, + { + "area_id": "0.0.0.200", + "area_range": "['10.200.19.0/24']", + "area_ranges": [ + { + "address": "10.200.19.0/24", + "exact": True, + "override_metric": 2000, + "restrict": True, + }, + ], + "interfaces": [ + { + "authentication": { + "password": "$9$eX2vMLoaUH.5bsgJZjPf369", + "type": { + "simple_password": "$9$eX2vMLoaUH.5bsgJZjPf369", + }, + }, + "name": "so-0/1/0.0", + "priority": 3, + }, + { + "authentication": { + "md5": [ + { + "key": "$9$vBL87Vg4ZiqfDi/t0OSy7-V", + "key_id": 10, + }, + ], + }, + "name": "so-0/2/0.0", + "priority": 2, + }, + ], + }, + { + "area_id": "0.0.0.120", + "area_range": "['10.200.20.0/24']", + "area_ranges": [ + { + "address": "10.200.20.0/24", + "exact": True, + "override_metric": 2000, + "restrict": True, + }, + ], + "interfaces": [ + { + "authentication": { + "md5": [ + { + "key": "$9$IIShrvx7V2oGs2mTF3purev", + "key_id": 10, + }, + ], + }, + "name": "so-0/2/0.1", + "priority": 2, + }, + ], + }, + ], + "overload": { + "allow_route_leaking": True, + "as_external": True, + "stub_network": True, + "timeout": 1200, + }, + "reference_bandwidth": "10g", + "rfc1583compatibility": False, + "router_id": "10.200.16.75", + }, + ] + + def test_junos_ospfv2_replaced(self): set_module_args( dict( config=[ dict( router_id="10.200.16.75", - external_preference=2, - overload=dict(timeout=80), - preference=1, - prefix_export_limit=20000, - reference_bandwidth="10g", - rfc1583compatibility=False, + rfc1583compatibility="False", + external_preference=10, + overload=dict( + allow_route_leaking=True, + as_external=True, + stub_network=True, + timeout=1200, + ), spf_options=dict( - delay=1000, - holddown=15000, + delay=3000, + holddown=4000, rapid_runs=9, + no_ignore_our_externals=True, ), - ), - ], - state="merged", - ), - ) - result = self.execute_module(changed=True) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - "<nc:spf-options><nc:delay>1000</nc:delay>", - str(result["commands"]), - ) - self.assertIn( - "<nc:overload><nc:timeout>80</nc:timeout></nc:overload>", - str(result["commands"]), - ) - self.assertIn( - "<nc:external-preference>2</nc:external-preference>", - str(result["commands"]), - ) - self.assertIn( - "<nc:preference>1</nc:preference>", - str(result["commands"]), - ) - self.assertIn( - "<nc:prefix-export-limit>20000</nc:prefix-export-limit>", - str(result["commands"]), - ) - self.assertIn( - "<nc:reference-bandwidth>10g</nc:reference-bandwidth>", - str(result["commands"]), - ) - self.assertIn("<nc:no-rfc-1583/>", str(result["commands"])) - self.assertIn( - "<nc:router-id>10.200.16.75</nc:router-id></nc:routing-options>", - str(result["commands"]), - ) - - def test_junos_ospfv2_replaced_01(self): - set_module_args( - dict( - config=[ - dict( - router_id="10.200.16.77", + prefix_export_limit=30000, areas=[ dict( - area_id="0.0.0.10", + area_id="0.0.0.100", stub=dict(default_metric=200, set=True), - interfaces=[ - dict( - name="so-0/0/0.0", - priority=3, - metric=2, - passive=True, - ), + area_ranges=[ dict( - name="so-0/0/0.1", - priority=4, - metric=4, + address="10.200.17.0/24", + exact=True, + restrict=True, + override_metric=2000, ), ], - ), - dict( - area_id="0.0.0.1=30", - interfaces=[ - dict(name="ge-1/1/1.0"), - dict(name="ge-2/2/2.0"), - ], - ), - ], - ), - ], - state="replaced", - ), - ) - result = self.execute_module(changed=True) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - '<nc:ospf><nc:area delete="delete">0.0.0.20</nc:area></nc:ospf>', - str(result["commands"]), - ) - self.assertIn( - '<nc:ospf><nc:area delete="delete">0.0.0.10</nc:area></nc:ospf>', - str(result["commands"]), - ) - self.assertIn( - '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn("<nc:metric>2</nc:metric>", str(result["commands"])) - self.assertIn("<nc:priority>3</nc:priority>", str(result["commands"])) - self.assertIn( - "<nc:interface><nc:name>so-0/0/0.1</nc:name>", - str(result["commands"]), - ) - self.assertIn( - "<nc:stub><nc:default-metric>200</nc:default-metric></nc:stub>", - str(result["commands"]), - ) - self.assertIn( - "<nc:router-id>10.200.16.77</nc:router-id></nc:routing-options>", - str(result["commands"]), - ) - - def test_junos_ospfv2_merged_01(self): - set_module_args( - dict( - config=[ - dict( - router_id="10.200.16.77", - areas=[ - dict( - area_id="0.0.0.10", - stub=dict(default_metric=200, set=True), interfaces=[ dict( name="so-0/0/0.0", priority=3, - metric=2, + metric=5, + flood_reduction=False, passive=True, - ), - dict( - name="so-0/0/0.1", - priority=4, - metric=4, + bandwidth_based_metrics=[ + dict( + bandwidth="1g", + metric=5, + ), + ], + timers=dict( + dead_interval=4, + hello_interval=2, + poll_interval=2, + retransmit_interval=2, + ), ), ], ), - dict( - area_id="0.0.0.1=30", - interfaces=[ - dict(name="ge-1/1/1.0"), - dict(name="ge-2/2/2.0"), - ], - ), ], ), ], - state="overridden", + state="replaced", ), ) - result = self.execute_module(changed=True) - self.assertIn( - '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn( - '<nc:ospf><nc:area delete="delete">0.0.0.20</nc:area></nc:ospf>', - str(result["commands"]), - ) - self.assertIn( - '<nc:ospf><nc:area delete="delete">0.0.0.10</nc:area></nc:ospf>', - str(result["commands"]), - ) - self.assertIn( - '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', - str(result["commands"]), - ) - self.assertIn("<nc:metric>2</nc:metric>", str(result["commands"])) - self.assertIn("<nc:priority>3</nc:priority>", str(result["commands"])) - self.assertIn( - "<nc:interface><nc:name>so-0/0/0.1</nc:name>", - str(result["commands"]), - ) - self.assertIn( - "<nc:stub><nc:default-metric>200</nc:default-metric></nc:stub>", - str(result["commands"]), - ) - self.assertIn( - "<nc:router-id>10.200.16.77</nc:router-id></nc:routing-options>", - str(result["commands"]), - ) - - def test_junos_ospfv2_deleted(self): - """ - :return: - """ - set_module_args(dict(config=[], state="deleted")) - commands = [ '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' - '<nc:ospf><nc:area delete="delete">0.0.0.10</nc:area></nc:ospf>' - '<nc:ospf><nc:area delete="delete">0.0.0.20</nc:area></nc:ospf>' - "</nc:protocols>", + '<nc:ospf><nc:area delete="delete">0.0.0.100</nc:area><nc:area delete="delete">0.0.0.200</nc:area>' + '<nc:spf-options delete="delete"/><nc:reference-bandwidth delete="delete"/>' + '<nc:no-rfc-1583 delete="delete"/><nc:overload delete="delete"/>' + '<nc:prefix-export-limit delete="delete"/></nc:ospf><nc:ospf>' + "<nc:spf-options><nc:delay>3000</nc:delay><nc:holddown>4000</nc:holddown><nc:rapid-runs>9</nc:rapid-runs>" + "<nc:no-ignore-our-externals/></nc:spf-options><nc:overload><nc:timeout>1200</nc:timeout>" + "<nc:allow-route-leaking/><nc:as-external/><nc:stub-network/></nc:overload>" + "<nc:external-preference>10</nc:external-preference><nc:prefix-export-limit>30000</nc:prefix-export-limit>" + "<nc:no-rfc-1583/><nc:area><nc:name>0.0.0.100</nc:name><nc:area-range><nc:name>10.200.17.0/24</nc:name>" + "<nc:exact/><nc:restrict/><nc:override-metric>2000</nc:override-metric></nc:area-range><nc:interface>" + "<nc:name>so-0/0/0.0</nc:name><nc:priority>3</nc:priority><nc:metric>5</nc:metric><nc:passive/>" + "<nc:bandwidth-based-metrics><nc:bandwidth><nc:name>1g</nc:name><nc:metric>5</nc:metric></nc:bandwidth>" + "</nc:bandwidth-based-metrics><nc:dead-interval>4</nc:dead-interval><nc:hello-interval>2</nc:hello-interval>" + "<nc:poll-interval>2</nc:poll-interval><nc:retransmit-interval>2</nc:retransmit-interval></nc:interface>" + "<nc:stub><nc:default-metric>200</nc:default-metric></nc:stub></nc:area></nc:ospf></nc:protocols>", + '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' + "<nc:router-id>10.200.16.75</nc:router-id></nc:routing-options>", ] - result = self.execute_module(changed=True) + result = self.execute_module(changed=True, commands=commands) self.assertEqual(sorted(result["commands"]), sorted(commands)) - def test_junos_ospfv2_rendered(self): + def test_junos_ospfv2_overridden(self): set_module_args( dict( config=[ dict( router_id="10.200.16.75", + rfc1583compatibility="False", + external_preference=10, + overload=dict( + allow_route_leaking=True, + as_external=True, + stub_network=True, + timeout=1200, + ), + spf_options=dict( + delay=3000, + holddown=4000, + rapid_runs=9, + no_ignore_our_externals=True, + ), + prefix_export_limit=30000, areas=[ dict( area_id="0.0.0.100", stub=dict(default_metric=200, set=True), + area_ranges=[ + dict( + address="10.200.17.0/24", + exact=True, + restrict=True, + override_metric=2000, + ), + ], interfaces=[ dict( name="so-0/0/0.0", priority=3, metric=5, + flood_reduction=False, + passive=True, + bandwidth_based_metrics=[ + dict( + bandwidth="1g", + metric=5, + ), + ], + timers=dict( + dead_interval=4, + hello_interval=2, + poll_interval=2, + retransmit_interval=2, + ), ), ], ), ], ), ], - state="rendered", + state="overridden", ), ) - rendered = ( + commands = [ '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' - "<nc:ospf><nc:area><nc:name>0.0.0.100</nc:name><nc:interface>" - "<nc:name>so-0/0/0.0</nc:name><nc:priority>3</nc:priority>" - "<nc:metric>5</nc:metric></nc:interface>" - "<nc:stub><nc:default-metric>200</nc:default-metric></nc:stub></nc:area></nc:ospf></nc:protocols>" - ) - result = self.execute_module(changed=False) - self.assertEqual(sorted(result["rendered"]), sorted(rendered)) + '<nc:ospf><nc:area delete="delete">0.0.0.100</nc:area>' + '<nc:area delete="delete">0.0.0.200</nc:area><nc:spf-options delete="delete"/>' + '<nc:reference-bandwidth delete="delete"/><nc:no-rfc-1583 delete="delete"/>' + '<nc:overload delete="delete"/>' + '<nc:prefix-export-limit delete="delete"/></nc:ospf><nc:ospf><nc:spf-options>' + "<nc:delay>3000</nc:delay><nc:holddown>4000</nc:holddown>" + "<nc:rapid-runs>9</nc:rapid-runs><nc:no-ignore-our-externals/>" + "</nc:spf-options><nc:overload><nc:timeout>1200</nc:timeout>" + "<nc:allow-route-leaking/><nc:as-external/><nc:stub-network/>" + "</nc:overload><nc:external-preference>10</nc:external-preference>" + "<nc:prefix-export-limit>30000</nc:prefix-export-limit><nc:no-rfc-1583/>" + "<nc:area><nc:name>0.0.0.100</nc:name><nc:area-range>" + "<nc:name>10.200.17.0/24</nc:name><nc:exact/><nc:restrict/>" + "<nc:override-metric>2000</nc:override-metric></nc:area-range><nc:interface>" + "<nc:name>so-0/0/0.0</nc:name><nc:priority>3</nc:priority><nc:metric>5</nc:metric>" + "<nc:passive/><nc:bandwidth-based-metrics><nc:bandwidth>" + "<nc:name>1g</nc:name><nc:metric>5</nc:metric></nc:bandwidth></nc:bandwidth-based-metrics>" + "<nc:dead-interval>4</nc:dead-interval><nc:hello-interval>2</nc:hello-interval>" + "<nc:poll-interval>2</nc:poll-interval><nc:retransmit-interval>2</nc:retransmit-interval>" + "</nc:interface><nc:stub><nc:default-metric>200</nc:default-metric>" + "</nc:stub></nc:area></nc:ospf></nc:protocols>", + '<nc:routing-options xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">' + "<nc:router-id>10.200.16.75</nc:router-id></nc:routing-options>", + ] + result = self.execute_module(changed=True, commands=commands) + self.assertEqual(sorted(result["commands"]), sorted(commands)) - def test_junos_vlans_gathered(self): - """ - :return: - """ - set_module_args(dict(state="gathered")) - result = self.execute_module(changed=False) - gather_list = [ + def test_junos_ospfv2_rendered(self): + set_module_args( dict( - router_id="10.200.16.77", - areas=[ - dict( - area_id="0.0.0.10", - stub=dict(default_metric=200, set=True), - interfaces=[ - dict( - name="so-0/0/0.0", - priority=3, - metric=5, - passive=True, - flood_reduction=True, - ), - ], - ), - dict( - area_id="0.0.0.20", - interfaces=[ - dict(name="ge-1/1/0.0"), - dict(name="ge-2/2/0.0"), - ], - ), - ], + config=[], + state="deleted", ), + ) + commands = [ + '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:ospf>' + '<nc:area delete="delete">0.0.0.100</nc:area><nc:spf-options delete="delete"/>' + '<nc:reference-bandwidth delete="delete"/><nc:no-rfc-1583 delete="delete"/>' + '<nc:overload delete="delete"/></nc:ospf></nc:protocols>', ] - self.assertEqual(sorted(gather_list), sorted(result["gathered"])) + result = self.execute_module(changed=True, commands=commands) + self.assertEqual(sorted(result["commands"]), sorted(commands)) - def test_junos_vlans_parsed(self): + def test_junos_ospfv2_parsed(self): parsed_str = """ - <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> - <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> - <version>18.4R1-S2.4</version> - <protocols> - <ospf> - <area> - <name>0.0.0.200</name> - <interface> - <name>so-0/0/0.1</name> - <metric>3</metric> - <priority>5</priority> - </interface> - </area> - <area> - <name>0.0.0.100</name> - <stub> - <default-metric>200</default-metric> - </stub> - <interface> - <name>so-0/0/0.0</name> - <metric>5</metric> - <priority>3</priority> - <bandwidth-based-metrics> - <bandwidth> - <name>10g</name> - <metric>5</metric> - </bandwidth> - </bandwidth-based-metrics> - </interface> - </area> - </ospf> - </protocols> - <routing-options> - <router-id>10.200.16.7</router-id> - </routing-options> - </configuration> - </rpc-reply> + <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> + <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> + <protocols> + <ospf> + <spf-options> + <delay>3000</delay> + <holddown>4000</holddown> + <rapid-runs>9</rapid-runs> + <no-ignore-our-externals/> + </spf-options> + <prefix-export-limit>20000</prefix-export-limit> + <overload> + <timeout>1200</timeout> + <allow-route-leaking/> + <stub-network/> + <as-external/> + </overload> + <reference-bandwidth>10g</reference-bandwidth> + <no-rfc-1583/> + <area> + <name>0.0.0.100</name> + <stub> + <default-metric>100</default-metric> + </stub> + <area-range> + <name>10.200.17.0/24</name> + <restrict/> + <exact/> + <override-metric>2000</override-metric> + </area-range> + <area-range> + <name>10.200.15.0/24</name> + <restrict/> + <exact/> + <override-metric>2000</override-metric> + </area-range> + <interface> + <name>so-0/0/0.0</name> + <passive> + </passive> + <bandwidth-based-metrics> + <bandwidth> + <name>1g</name> + <metric>5</metric> + </bandwidth> + <bandwidth> + <name>10g</name> + <metric>40</metric> + </bandwidth> + </bandwidth-based-metrics> + <metric>5</metric> + <priority>3</priority> + <retransmit-interval>2</retransmit-interval> + <hello-interval>2</hello-interval> + <dead-interval>4</dead-interval> + <poll-interval>2</poll-interval> + </interface> + </area> + </ospf> + + </protocols> + </configuration> + </rpc-reply> """ set_module_args(dict(running_config=parsed_str, state="parsed")) result = self.execute_module(changed=False) - parsed_list = [ + parsed_dict = [ { "areas": [ { - "area_id": "0.0.0.200", - "interfaces": [ - {"metric": 3, "name": "so-0/0/0.1", "priority": 5}, - ], - }, - { "area_id": "0.0.0.100", "interfaces": [ { - "bandwidth_based_metrics": [ - {"metric": 5, "bandwidth": "10g"}, - ], - "metric": 5, "name": "so-0/0/0.0", "priority": 3, + "metric": 5, + "timers": { + "hello_interval": 2, + "dead_interval": 4, + "retransmit_interval": 2, + "poll_interval": 2, + }, + "passive": True, + "bandwidth_based_metrics": [ + { + "metric": 5, + "bandwidth": "1g", + }, + { + "metric": 40, + "bandwidth": "10g", + }, + ], + }, + ], + "area_range": "['10.200.17.0/24', '10.200.15.0/24']", + "area_ranges": [ + { + "address": "10.200.17.0/24", + "override_metric": 2000, + "exact": True, + "restrict": True, + }, + { + "address": "10.200.15.0/24", + "override_metric": 2000, + "exact": True, + "restrict": True, }, ], - "stub": {"default_metric": 200, "set": True}, + "stub": { + "set": True, + "default_metric": 100, + }, }, ], - "router_id": "10.200.16.7", + "overload": { + "allow_route_leaking": True, + "as_external": True, + "stub_network": True, + "timeout": 1200, + }, + "prefix_export_limit": 20000, + "reference_bandwidth": "10g", + "rfc1583compatibility": False, + "spf_options": { + "delay": 3000, + "holddown": 4000, + "rapid_runs": 9, + "no_ignore_our_externals": True, + }, }, ] - self.assertEqual(result["parsed"], parsed_list) - def test_junos_vlans_parsed_02(self): - parsed_str = """ - <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> - <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> - <version>18.4R1-S2.4</version> - <protocols> - <ospf> - <area> - <name>0.0.0.200</name> - <interface> - <name>so-0/0/0.1</name> - <metric>3</metric> - <priority>5</priority> - </interface> - </area> - <area> - <name>0.0.0.100</name> - <stub> - <default-metric>200</default-metric> - </stub> - <interface> - <name>so-0/0/0.0</name> - <metric>5</metric> - <priority>3</priority> - <bandwidth-based-metrics> - <bandwidth> - <name>10g</name> - <metric>5</metric> - </bandwidth> - <bandwidth> - <name>1g</name> - <metric>5</metric> - </bandwidth> - </bandwidth-based-metrics> - </interface> - </area> - </ospf> - </protocols> - <routing-options> - <router-id>10.200.16.7</router-id> - </routing-options> - </configuration> - </rpc-reply> - """ - set_module_args(dict(running_config=parsed_str, state="parsed")) - result = self.execute_module(changed=False) - parsed_list = [ - { - "areas": [ - { - "area_id": "0.0.0.200", - "interfaces": [ - {"metric": 3, "name": "so-0/0/0.1", "priority": 5}, - ], - }, - { - "area_id": "0.0.0.100", - "interfaces": [ - { - "bandwidth_based_metrics": [ - {"metric": 5, "bandwidth": "10g"}, - {"metric": 5, "bandwidth": "1g"}, + def test_junos_ospfv2_rendered(self): + set_module_args( + dict( + config=[ + dict( + router_id="10.200.16.75", + rfc1583compatibility="False", + external_preference=10, + overload=dict( + allow_route_leaking=True, + as_external=True, + stub_network=True, + timeout=1200, + ), + spf_options=dict( + delay=3000, + holddown=4000, + rapid_runs=9, + no_ignore_our_externals=True, + ), + prefix_export_limit=30000, + areas=[ + dict( + area_id="0.0.0.100", + stub=dict(default_metric=200, set=True), + area_ranges=[ + dict( + address="10.200.17.0/24", + exact=True, + restrict=True, + override_metric=2000, + ), ], - "metric": 5, - "name": "so-0/0/0.0", - "priority": 3, - }, + interfaces=[ + dict( + name="so-0/0/0.0", + priority=3, + metric=5, + flood_reduction=False, + passive=True, + bandwidth_based_metrics=[ + dict( + bandwidth="1g", + metric=5, + ), + ], + timers=dict( + dead_interval=4, + hello_interval=2, + poll_interval=2, + retransmit_interval=2, + ), + ), + ], + ), ], - "stub": {"default_metric": 200, "set": True}, - }, + ), ], - "router_id": "10.200.16.7", - }, - ] - self.assertEqual(result["parsed"], parsed_list) + state="rendered", + ), + ) + rendered = ( + '<nc:protocols xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:ospf>' + "<nc:spf-options><nc:delay>3000</nc:delay><nc:holddown>4000</nc:holddown>" + "<nc:rapid-runs>9</nc:rapid-runs><nc:no-ignore-our-externals/></nc:spf-options>" + "<nc:overload><nc:timeout>1200</nc:timeout><nc:allow-route-leaking/><nc:as-external/>" + "<nc:stub-network/></nc:overload>" + "<nc:external-preference>10</nc:external-preference>" + "<nc:prefix-export-limit>30000</nc:prefix-export-limit>" + "<nc:no-rfc-1583/><nc:area><nc:name>0.0.0.100</nc:name><nc:area-range>" + "<nc:name>10.200.17.0/24</nc:name><nc:exact/><nc:restrict/>" + "<nc:override-metric>2000</nc:override-metric></nc:area-range><nc:interface>" + "<nc:name>so-0/0/0.0</nc:name>" + "<nc:priority>3</nc:priority><nc:metric>5</nc:metric><nc:passive/>" + "<nc:bandwidth-based-metrics><nc:bandwidth><nc:name>1g</nc:name>" + "<nc:metric>5</nc:metric></nc:bandwidth></nc:bandwidth-based-metrics>" + "<nc:dead-interval>4</nc:dead-interval><nc:hello-interval>2</nc:hello-interval>" + "<nc:poll-interval>2</nc:poll-interval>" + "<nc:retransmit-interval>2</nc:retransmit-interval></nc:interface><nc:stub>" + "<nc:default-metric>200</nc:default-metric></nc:stub></nc:area></nc:ospf>" + "</nc:protocols>" + ) + result = self.execute_module(changed=False) + self.assertEqual( + self.sorted_xml(result["rendered"]), + self.sorted_xml(rendered), + ) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv3.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv3.py index 054947448..a96d95bac 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv3.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_ospfv3.py @@ -352,7 +352,6 @@ class TestJunosOspfv3Module(TestJunosModule): self.execute_module(changed=False, commands=[]) def test_junos_ospfv3_parsed(self): - set_module_args( dict( running_config='<?xml version="1.0" encoding="UTF-8"?>\n' diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_package.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_package.py index 38e3599d0..f679fa5a3 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_package.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_package.py @@ -41,7 +41,6 @@ from ansible_collections.junipernetworks.junos.plugins.modules import junos_pack class TestJunosPackageModule(TestJunosModule): - module = junos_package def setUp(self): @@ -79,3 +78,14 @@ class TestJunosPackageModule(TestJunosModule): args, kwargs = jnpr_mock.junos.utils.sw.SW().install.call_args self.assertEqual(args, ("junos-vsrx-12.1X46-D10.2-domestic.tgz",)) self.assertEqual(kwargs["no_copy"], True) + + def test_junos_package_src_unlink(self): + jnpr_mock.junos.utils.sw.SW().install.return_value = 1 + set_module_args( + dict(src="junos-vsrx-12.1X46-D10.2-domestic.tgz", unlink=True), + ) + self.execute_module(changed=True) + + args, kwargs = jnpr_mock.junos.utils.sw.SW().install.call_args + self.assertEqual(args, ("junos-vsrx-12.1X46-D10.2-domestic.tgz",)) + self.assertEqual(kwargs["unlink"], True) diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_rpc.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_rpc.py index de66f103d..4c914aa3d 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_rpc.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_rpc.py @@ -44,7 +44,6 @@ RPC_CLI_MAP = { class TestJunosCommandModule(TestJunosModule): - module = junos_rpc def setUp(self): diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_scp.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_scp.py index 6286d57de..0788d6523 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_scp.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_scp.py @@ -43,7 +43,6 @@ from ansible_collections.junipernetworks.junos.plugins.modules import junos_scp class TestJunosScpModule(TestJunosModule): - module = junos_scp def setUp(self): diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_policies.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_policies.py index bdb94ed6c..b41161672 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_policies.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_policies.py @@ -346,7 +346,6 @@ class TestJunosSecurity_policiesModule(TestJunosModule): ) def test_junos_security_policies_merged_02(self): - set_module_args( dict( config={ diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_zones.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_zones.py index e593037dc..764d1a7e8 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_zones.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_security_zones.py @@ -246,6 +246,256 @@ class TestJunosSecurity_zonesModule(TestJunosModule): self.sorted_xml(str(result["commands"])), ) + def test_junos_security_zones_parsed(self): + parsed_str = """ + <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> + <configuration changed-seconds="1590139550" changed-localtime="2020-05-22 09:25:50 UTC"> + <version>18.4R1-S2.4</version> + <security> + <zones> + <functional-zone> + <management> + <description>test description</description> + <host-inbound-traffic> + <protocols> + <name>all</name> + </protocols> + <protocols> + <name>bgp</name> + <except /> + </protocols> + <system-services> + <name>all</name> + </system-services> + <system-services> + <name>dhcp</name> + <except /> + </system-services> + </host-inbound-traffic> + <interfaces> + <name>ge-0/0/1.0</name> + </interfaces> + <interfaces> + <name>ge-0/0/2.0</name> + </interfaces> + <screen>test_screen</screen> + </management> + </functional-zone> + <security-zone> + <name>test_sec_zone1</name> + <address-book> + <address> + <name>test_adr1</name> + <ip-prefix>10.0.0.0/24</ip-prefix> + <description>test desc</description> + </address> + <address> + <name>test_adr2</name> + <dns-name> + <name>1.1.1.1</name> + <ipv6-only /> + </dns-name> + </address> + <address> + <name>test_adr3</name> + <range-address> + <name>10.2.0.1</name> + <to> + <range-high>10.2.0.2</range-high> + </to> + </range-address> + </address> + <address> + <name>test_adr4</name> + <wildcard-address> + <name>10.3.0.1/24</name> + </wildcard-address> + </address> + <address> + <name>test_adr5</name> + <ip-prefix>10.1.0.0/24</ip-prefix> + <description>test desc</description> + </address> + <address-set> + <name>test_adrset1</name> + <address> + <name>test_adr1</name> + </address> + <address> + <name>test_adr2</name> + </address> + </address-set> + <address-set> + <name>test_adrset2</name> + <address> + <name>test_adr3</name> + </address> + <address> + <name>test_adr4</name> + </address> + </address-set> + <address-set> + <name>test_adrset3</name> + <address> + <name>test_adr5</name> + </address> + <address-set> + <name>test_adrset1</name> + </address-set> + <address-set> + <name>test_adrset2</name> + </address-set> + <description>test description</description> + </address-set> + </address-book> + <advance-policy-based-routing-profile> + <profile>test_profile</profile> + </advance-policy-based-routing-profile> + <advanced-connection-tracking> + <mode>allow-any-host</mode> + <timeout>20</timeout> + <track-all-policies-to-this-zone/> + </advanced-connection-tracking> + <application-tracking /> + <description>test description</description> + <enable-reverse-reroute /> + <host-inbound-traffic> + <protocols> + <name>all</name> + </protocols> + <protocols> + <name>bgp</name> + <except /> + </protocols> + <system-services> + <name>all</name> + </system-services> + <system-services> + <name>dhcp</name> + <except /> + </system-services> + </host-inbound-traffic> + <interfaces> + <name>ge-0/0/3.0</name> + </interfaces> + <screen>test_screen</screen> + <source-identity-log /> + <tcp-rst /> + <unidirectional-session-refreshing /> + </security-zone> + </zones> + </security> + </configuration> + </rpc-reply> + """ + set_module_args(dict(running_config=parsed_str, state="parsed")) + result = self.execute_module(changed=False) + parsed_dict = { + "functional_zone_management": { + "description": "test description 2", + "host_inbound_traffic": { + "protocols": [ + {"name": "all"}, + {"except": True, "name": "bgp"}, + {"except": True, "name": "bfd"}, + ], + "system_services": [ + {"name": "all"}, + {"except": True, "name": "dhcp"}, + {"except": True, "name": "dhcpv6"}, + ], + }, + "interfaces": ["ge-0/0/1.0", "ge-0/0/2.0"], + "screen": "test_screen", + }, + "zones": [ + { + "address_book": { + "address_sets": [ + { + "addresses": ["test_adr1", "test_adr2"], + "name": "test_adrset1", + }, + { + "addresses": ["test_adr3", "test_adr4"], + "name": "test_adrset2", + }, + { + "address_sets": [ + "test_adrset1", + "test_adrset2", + ], + "addresses": ["test_adr5"], + "description": "test description", + "name": "test_adrset3", + }, + ], + "addresses": [ + { + "description": "test desc", + "ip_prefix": "10.0.0.0/24", + "name": "test_adr1", + }, + { + "dns_name": { + "ipv6_only": True, + "name": "1.1.1.1", + }, + "name": "test_adr2", + }, + { + "name": "test_adr3", + "range_address": { + "from": "10.2.0.1", + "to": "10.2.0.2", + }, + }, + { + "name": "test_adr4", + "wildcard_address": "10.3.0.1/24", + }, + { + "description": "test desc", + "ip_prefix": "10.1.0.0/24", + "name": "test_adr5", + }, + ], + }, + "advance_policy_based_routing_profile": "test_profile", + "advanced_connection_tracking": { + "mode": "allow-any-host", + "timeout": "20", + "track_all_policies_to_this_zone": True, + }, + "application_tracking": True, + "description": "test description", + "enable_reverse_reroute": True, + "host_inbound_traffic": { + "protocols": [ + {"name": "all"}, + {"except": True, "name": "bgp"}, + ], + "system_services": [ + {"name": "all"}, + {"except": True, "name": "dhcp"}, + ], + }, + "interfaces": {"ge-0/0/3.0"}, + "name": "test_sec_zone1", + "screen": "test_screen", + "source_identity_log": True, + "tcp_rst": True, + "unidirectional_session_refreshing": True, + }, + { + "name": "test_sec_zone2", + "source_identity_log": True, + "tcp_rst": True, + }, + ], + } + self.assertEqual(sorted(parsed_dict), sorted(result["parsed"])) + def test_junos_security_zones_parsed_01(self): parsed_str = """ <rpc-reply message-id="urn:uuid:0cadb4e8-5bba-47f4-986e-72906227007f"> diff --git a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_snmp_server.py b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_snmp_server.py index db31904e8..ed73b8c5a 100644 --- a/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_snmp_server.py +++ b/ansible_collections/junipernetworks/junos/tests/unit/modules/network/junos/test_junos_snmp_server.py @@ -103,6 +103,199 @@ class TestJunosSnmp_serverModule(TestJunosModule): str(result["commands"]), ) + def test_junos_snmp_server_merged_views(self): + set_module_args( + dict( + config=dict( + views=[ + dict( + name="all", + oids=[dict(oid=".1")], + ), + ], + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:view><nc:name>all</nc:name><nc:oid><nc:name>.1</nc:name>", + str(result["commands"]), + ) + self.assertIn( + "</nc:oid></nc:view></nc:snmp>", + str(result["commands"]), + ) + + def test_junos_snmp_server_merged_trap_options(self): + set_module_args( + dict( + config=dict( + trap_options=dict( + agent_address=dict( + outgoing_interface=True, + ), + context_oid=True, + ), + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:trap-options><nc:agent-address>outgoing-interface</nc:agent-address><nc:context-oid/>", + str(result["commands"]), + ) + self.assertIn( + "</nc:trap-options></nc:snmp>", + str(result["commands"]), + ) + + def test_junos_snmp_server_merged_trap_groups(self): + set_module_args( + dict( + config=dict( + trap_groups=[ + dict( + categories=dict( + authentication=True, + ), + name="egress", + ), + ], + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:trap-group><nc:categories><nc:authentication/></nc:categories><nc:name>egress</nc:name>", + str(result["commands"]), + ) + self.assertIn( + "</nc:trap-group></nc:snmp>", + str(result["commands"]), + ) + + def test_junos_snmp_server_merged_trap_groups_02(self): + set_module_args( + dict( + config=dict( + trap_groups=[ + dict( + categories=dict( + chassis=True, + chassis_cluster=True, + configuration=True, + dot3oam_events=True, + link=True, + ), + name="monitor", + ), + ], + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:trap-group><nc:categories><nc:chassis/><nc:chassis-cluster/><nc:configuration/>", + str(result["commands"]), + ) + + def test_junos_snmp_server_merged_trap_groups_otn_alrams(self): + set_module_args( + dict( + config=dict( + trap_groups=[ + dict( + categories=dict( + otn_alarms=dict( + oc_lof=True, + oc_lom=True, + oc_los=True, + ), + ), + name="monitor", + ), + ], + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:trap-group><nc:categories><nc:otn-alarms><nc:oc-lof/><nc:oc-lom/><nc:oc-los/></nc:otn-alarms></nc:categories>", + str(result["commands"]), + ) + self.assertIn( + "<nc:name>monitor</nc:name></nc:trap-group></nc:snmp>", + str(result["commands"]), + ) + + def test_junos_snmp_server_merged_trap_options_set(self): + set_module_args( + dict( + config=dict( + trap_options=dict( + set=True, + ), + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + expected_commands = '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0"><nc:trap-options/></nc:snmp>' + self.assertEqual(expected_commands, "/n".join(result["commands"])) + + def test_junos_snmp_server_merged_trap_options_02(self): + set_module_args( + dict( + config=dict( + trap_options=dict( + enterprise_oid=True, + source_address=dict( + address="192.168.2.0", + ), + ), + ), + state="merged", + ), + ) + result = self.execute_module(changed=True) + self.assertIn( + '<nc:snmp xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0">', + str(result["commands"]), + ) + self.assertIn( + "<nc:trap-options><nc:source-address><nc:address>192.168.2.0</nc:address></nc:source-address>", + str(result["commands"]), + ) + self.assertIn( + "</nc:trap-options></nc:snmp>", + str(result["commands"]), + ) + def test_junos_snmp_server_merged_client_02(self): set_module_args( dict( |