mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-24 13:04:00 -07:00 
			
		
		
		
	Refactors bigip_virtual_server (#34412)
This refactors the bigip_virtual_server module to address several issues and missing features. Additionally it adds tests and updates the coding standards to the recent version used by f5. Finally, it removes deprecated items that were announced in 2.4
This commit is contained in:
		
					parent
					
						
							
								4d5533c597
							
						
					
				
			
			
				commit
				
					
						c132b977e8
					
				
			
		
					 6 changed files with 2761 additions and 682 deletions
				
			
		|  | @ -0,0 +1,43 @@ | |||
| { | ||||
|   "kind": "tm:ltm:virtual:virtualstate", | ||||
|   "name": "my-virtual-server", | ||||
|   "partition": "Common", | ||||
|   "fullPath": "/Common/my-virtual-server", | ||||
|   "generation": 65, | ||||
|   "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server?ver=12.1.2", | ||||
|   "addressStatus": "yes", | ||||
|   "autoLasthop": "default", | ||||
|   "cmpEnabled": "yes", | ||||
|   "connectionLimit": 0, | ||||
|   "destination": "/Common/10.10.10.10:443", | ||||
|   "enabled": true, | ||||
|   "gtmScore": 0, | ||||
|   "ipProtocol": "any", | ||||
|   "mask": "255.255.255.255", | ||||
|   "mirror": "disabled", | ||||
|   "mobileAppTunnel": "disabled", | ||||
|   "nat64": "disabled", | ||||
|   "rateLimit": "disabled", | ||||
|   "rateLimitDstMask": 0, | ||||
|   "rateLimitMode": "object", | ||||
|   "rateLimitSrcMask": 0, | ||||
|   "serviceDownImmediateAction": "none", | ||||
|   "source": "0.0.0.0/0", | ||||
|   "sourceAddressTranslation": { | ||||
|     "type": "automap" | ||||
|   }, | ||||
|   "sourcePort": "preserve", | ||||
|   "synCookieStatus": "not-activated", | ||||
|   "translateAddress": "enabled", | ||||
|   "translatePort": "enabled", | ||||
|   "vlansDisabled": true, | ||||
|   "vsIndex": 2, | ||||
|   "policiesReference": { | ||||
|     "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/policies?ver=12.1.2", | ||||
|     "isSubcollection": true | ||||
|   }, | ||||
|   "profilesReference": { | ||||
|     "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles?ver=12.1.2", | ||||
|     "isSubcollection": true | ||||
|   } | ||||
| } | ||||
|  | @ -0,0 +1,25 @@ | |||
| { | ||||
|   "kind": "tm:ltm:virtual-address:virtual-addressstate", | ||||
|   "name": "10.10.10.10", | ||||
|   "partition": "Common", | ||||
|   "fullPath": "/Common/10.10.10.10", | ||||
|   "generation": 116, | ||||
|   "selfLink": "https://localhost/mgmt/tm/ltm/virtual-address/~Common~10.10.10.10?ver=12.1.2", | ||||
|   "address": "10.10.10.10", | ||||
|   "arp": "enabled", | ||||
|   "autoDelete": "true", | ||||
|   "connectionLimit": 0, | ||||
|   "enabled": "yes", | ||||
|   "floating": "enabled", | ||||
|   "icmpEcho": "enabled", | ||||
|   "inheritedTrafficGroup": "false", | ||||
|   "mask": "255.255.255.255", | ||||
|   "routeAdvertisement": "enabled", | ||||
|   "serverScope": "any", | ||||
|   "spanning": "disabled", | ||||
|   "trafficGroup": "/Common/traffic-group-1", | ||||
|   "trafficGroupReference": { | ||||
|     "link": "https://localhost/mgmt/tm/cm/traffic-group/~Common~traffic-group-1?ver=12.1.2" | ||||
|   }, | ||||
|   "unit": 1 | ||||
| } | ||||
|  | @ -0,0 +1,65 @@ | |||
| { | ||||
|   "kind": "tm:ltm:virtual:virtualstate", | ||||
|   "name": "my-virtual-server", | ||||
|   "partition": "Common", | ||||
|   "fullPath": "/Common/my-virtual-server", | ||||
|   "generation": 152, | ||||
|   "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server?ver=12.1.2", | ||||
|   "addressStatus": "yes", | ||||
|   "autoLasthop": "default", | ||||
|   "cmpEnabled": "yes", | ||||
|   "connectionLimit": 0, | ||||
|   "destination": "/Common/10.10.10.10:443", | ||||
|   "enabled": true, | ||||
|   "gtmScore": 0, | ||||
|   "ipProtocol": "any", | ||||
|   "mask": "255.255.255.255", | ||||
|   "mirror": "disabled", | ||||
|   "mobileAppTunnel": "disabled", | ||||
|   "nat64": "disabled", | ||||
|   "rateLimit": "disabled", | ||||
|   "rateLimitDstMask": 0, | ||||
|   "rateLimitMode": "object", | ||||
|   "rateLimitSrcMask": 0, | ||||
|   "serviceDownImmediateAction": "none", | ||||
|   "source": "0.0.0.0/0", | ||||
|   "sourceAddressTranslation": { | ||||
|     "type": "automap" | ||||
|   }, | ||||
|   "sourcePort": "preserve", | ||||
|   "synCookieStatus": "not-activated", | ||||
|   "translateAddress": "enabled", | ||||
|   "translatePort": "enabled", | ||||
|   "vlansDisabled": true, | ||||
|   "vsIndex": 19, | ||||
|   "vlans": [ | ||||
|     "/Common/net1" | ||||
|   ], | ||||
|   "vlansReference": [ | ||||
|     { | ||||
|       "link": "https://localhost/mgmt/tm/net/vlan/~Common~net1?ver=12.1.2" | ||||
|     } | ||||
|   ], | ||||
|   "policiesReference": { | ||||
|     "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/policies?ver=12.1.2", | ||||
|     "isSubcollection": true | ||||
|   }, | ||||
|   "profilesReference": { | ||||
|     "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles?ver=12.1.2", | ||||
|     "isSubcollection": true, | ||||
|     "items": [ | ||||
|       { | ||||
|         "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|         "name": "fastL4", | ||||
|         "partition": "Common", | ||||
|         "fullPath": "/Common/fastL4", | ||||
|         "generation": 148, | ||||
|         "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~fastL4?ver=12.1.2", | ||||
|         "context": "all", | ||||
|         "nameReference": { | ||||
|           "link": "https://localhost/mgmt/tm/ltm/profile/fastl4/~Common~fastL4?ver=12.1.2" | ||||
|         } | ||||
|       } | ||||
|     ] | ||||
|   } | ||||
| } | ||||
							
								
								
									
										115
									
								
								test/units/modules/network/f5/fixtures/load_ltm_virtual_3.json
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								test/units/modules/network/f5/fixtures/load_ltm_virtual_3.json
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,115 @@ | |||
| { | ||||
|     "kind": "tm:ltm:virtual:virtualstate", | ||||
|     "name": "my-virtual-server", | ||||
|     "partition": "Common", | ||||
|     "fullPath": "/Common/my-virtual-server", | ||||
|     "generation": 340, | ||||
|     "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server?expandSubcollections=true&ver=12.0.0", | ||||
|     "addressStatus": "yes", | ||||
|     "autoLasthop": "default", | ||||
|     "cmpEnabled": "yes", | ||||
|     "connectionLimit": 0, | ||||
|     "description": "Test Virtual Server", | ||||
|     "destination": "/Common/10.10.10.10:443", | ||||
|     "enabled": true, | ||||
|     "gtmScore": 0, | ||||
|     "ipProtocol": "tcp", | ||||
|     "mask": "255.255.255.255", | ||||
|     "mirror": "disabled", | ||||
|     "mobileAppTunnel": "disabled", | ||||
|     "nat64": "disabled", | ||||
|     "rateLimit": "disabled", | ||||
|     "rateLimitDstMask": 0, | ||||
|     "rateLimitMode": "object", | ||||
|     "rateLimitSrcMask": 0, | ||||
|     "serviceDownImmediateAction": "none", | ||||
|     "source": "0.0.0.0/0", | ||||
|     "sourceAddressTranslation": { | ||||
|         "type": "automap" | ||||
|     }, | ||||
|     "sourcePort": "preserve", | ||||
|     "synCookieStatus": "not-activated", | ||||
|     "translateAddress": "enabled", | ||||
|     "translatePort": "enabled", | ||||
|     "vlansDisabled": true, | ||||
|     "vsIndex": 38, | ||||
|     "rules": [ | ||||
|         "/Common/web_logging" | ||||
|     ], | ||||
|     "rulesReference": [ | ||||
|         { | ||||
|             "link": "https://localhost/mgmt/tm/ltm/rule/~Common~web_logging?ver=12.0.0" | ||||
|         } | ||||
|     ], | ||||
|     "policiesReference": { | ||||
|         "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/policies?ver=12.0.0", | ||||
|         "isSubcollection": true, | ||||
|         "items": [ | ||||
|             { | ||||
|                 "kind": "tm:ltm:virtual:policies:policiesstate", | ||||
|                 "name": "policy1", | ||||
|                 "partition": "Common", | ||||
|                 "fullPath": "/Common/policy1", | ||||
|                 "generation": 340, | ||||
|                 "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/policies/~Common~policy1?ver=12.0.0", | ||||
|                 "nameReference": { | ||||
|                     "link": "https://localhost/mgmt/tm/ltm/policy/~Common~policy1?ver=12.0.0" | ||||
|                 } | ||||
|             } | ||||
|         ] | ||||
|     }, | ||||
|     "profilesReference": { | ||||
|         "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles?ver=12.0.0", | ||||
|         "isSubcollection": true, | ||||
|         "items": [ | ||||
|             { | ||||
|                 "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                 "name": "clientssl", | ||||
|                 "partition": "Common", | ||||
|                 "fullPath": "/Common/clientssl", | ||||
|                 "generation": 338, | ||||
|                 "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~clientssl?ver=12.0.0", | ||||
|                 "context": "clientside", | ||||
|                 "nameReference": { | ||||
|                     "link": "https://localhost/mgmt/tm/ltm/profile/client-ssl/~Common~clientssl?ver=12.0.0" | ||||
|                 } | ||||
|             }, | ||||
|             { | ||||
|                 "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                 "name": "http", | ||||
|                 "partition": "Common", | ||||
|                 "fullPath": "/Common/http", | ||||
|                 "generation": 338, | ||||
|                 "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~http?ver=12.0.0", | ||||
|                 "context": "all", | ||||
|                 "nameReference": { | ||||
|                     "link": "https://localhost/mgmt/tm/ltm/profile/http/~Common~http?ver=12.0.0" | ||||
|                 } | ||||
|             }, | ||||
|             { | ||||
|                 "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                 "name": "tcp", | ||||
|                 "partition": "Common", | ||||
|                 "fullPath": "/Common/tcp", | ||||
|                 "generation": 338, | ||||
|                 "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~tcp?ver=12.0.0", | ||||
|                 "context": "clientside", | ||||
|                 "nameReference": { | ||||
|                     "link": "https://localhost/mgmt/tm/ltm/profile/tcp/~Common~tcp?ver=12.0.0" | ||||
|                 } | ||||
|             }, | ||||
|             { | ||||
|                 "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                 "name": "tcp-legacy", | ||||
|                 "partition": "Common", | ||||
|                 "fullPath": "/Common/tcp-legacy", | ||||
|                 "generation": 338, | ||||
|                 "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~tcp-legacy?ver=12.0.0", | ||||
|                 "context": "serverside", | ||||
|                 "nameReference": { | ||||
|                     "link": "https://localhost/mgmt/tm/ltm/profile/tcp/~Common~tcp-legacy?ver=12.0.0" | ||||
|                 } | ||||
|             } | ||||
|         ] | ||||
|     } | ||||
| } | ||||
							
								
								
									
										773
									
								
								test/units/modules/network/f5/test_bigip_virtual_server.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										773
									
								
								test/units/modules/network/f5/test_bigip_virtual_server.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,773 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # Copyright (c) 2017 F5 Networks Inc. | ||||
| # GNU General Public License v3.0 (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) | ||||
| 
 | ||||
| from __future__ import (absolute_import, division, print_function) | ||||
| __metaclass__ = type | ||||
| 
 | ||||
| import os | ||||
| import json | ||||
| import sys | ||||
| 
 | ||||
| from nose.plugins.skip import SkipTest | ||||
| if sys.version_info < (2, 7): | ||||
|     raise SkipTest("F5 Ansible modules require Python >= 2.7") | ||||
| 
 | ||||
| from ansible.compat.tests import unittest | ||||
| from ansible.compat.tests.mock import Mock | ||||
| from ansible.compat.tests.mock import patch | ||||
| from ansible.module_utils.f5_utils import AnsibleF5Client | ||||
| 
 | ||||
| try: | ||||
|     from library.bigip_virtual_server import VirtualAddressParameters | ||||
|     from library.bigip_virtual_server import VirtualServerModuleParameters | ||||
|     from library.bigip_virtual_server import VirtualServerApiParameters | ||||
|     from library.bigip_virtual_server import ModuleManager | ||||
|     from library.bigip_virtual_server import VirtualServerManager | ||||
|     from library.bigip_virtual_server import VirtualAddressManager | ||||
|     from library.bigip_virtual_server import ArgumentSpec | ||||
|     from ansible.module_utils.f5_utils import iControlUnexpectedHTTPError | ||||
|     from test.unit.modules.utils import set_module_args | ||||
| except ImportError: | ||||
|     try: | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import VirtualAddressParameters | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import VirtualServerApiParameters | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import VirtualServerModuleParameters | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import ModuleManager | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import VirtualServerManager | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import VirtualAddressManager | ||||
|         from ansible.modules.network.f5.bigip_virtual_server import ArgumentSpec | ||||
|         from ansible.module_utils.f5_utils import iControlUnexpectedHTTPError | ||||
|         from units.modules.utils import set_module_args | ||||
|     except ImportError: | ||||
|         raise SkipTest("F5 Ansible modules require the f5-sdk Python library") | ||||
| 
 | ||||
| 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 TestParameters(unittest.TestCase): | ||||
|     def test_destination_mutex_1(self): | ||||
|         args = dict( | ||||
|             destination='1.1.1.1' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
| 
 | ||||
|     def test_destination_mutex_2(self): | ||||
|         args = dict( | ||||
|             destination='1.1.1.1%2' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
|     def test_destination_mutex_3(self): | ||||
|         args = dict( | ||||
|             destination='1.1.1.1:80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.port == 80 | ||||
| 
 | ||||
|     def test_destination_mutex_4(self): | ||||
|         args = dict( | ||||
|             destination='1.1.1.1%2:80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.port == 80 | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
|     def test_api_destination_mutex_5(self): | ||||
|         args = dict( | ||||
|             destination='/Common/1.1.1.1' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
| 
 | ||||
|     def test_api_destination_mutex_6(self): | ||||
|         args = dict( | ||||
|             destination='/Common/1.1.1.1%2' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
|     def test_api_destination_mutex_7(self): | ||||
|         args = dict( | ||||
|             destination='/Common/1.1.1.1:80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.port == 80 | ||||
| 
 | ||||
|     def test_api_destination_mutex_8(self): | ||||
|         args = dict( | ||||
|             destination='/Common/1.1.1.1%2:80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '1.1.1.1' | ||||
|         assert p.destination_tuple.port == 80 | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
|     def test_destination_mutex_9(self): | ||||
|         args = dict( | ||||
|             destination='2700:bc00:1f10:101::6' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
| 
 | ||||
|     def test_destination_mutex_10(self): | ||||
|         args = dict( | ||||
|             destination='2700:bc00:1f10:101::6%2' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
|     def test_destination_mutex_11(self): | ||||
|         args = dict( | ||||
|             destination='2700:bc00:1f10:101::6.80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
|         assert p.destination_tuple.port == 80 | ||||
| 
 | ||||
|     def test_destination_mutex_12(self): | ||||
|         args = dict( | ||||
|             destination='2700:bc00:1f10:101::6%2.80' | ||||
|         ) | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
|         assert p.destination_tuple.port == 80 | ||||
|         assert p.destination_tuple.route_domain == 2 | ||||
| 
 | ||||
| # | ||||
| #    def test_destination_mutex_6(self): | ||||
| #        args = dict( | ||||
| #            destination='/Common/2700:bc00:1f10:101::6' | ||||
| #        ) | ||||
| #        p = VirtualServerParameters(args) | ||||
| #        assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
| # | ||||
| #    def test_destination_mutex_5(self): | ||||
| #        args = dict( | ||||
| #            destination='/Common/2700:bc00:1f10:101::6' | ||||
| #        ) | ||||
| #        p = VirtualServerParameters(args) | ||||
| #        assert p.destination_tuple.ip == '2700:bc00:1f10:101::6' | ||||
| 
 | ||||
|     def test_module_no_partition_prefix_parameters(self): | ||||
|         args = dict( | ||||
|             server='localhost', | ||||
|             user='admin', | ||||
|             password='secret', | ||||
|             state='present', | ||||
|             partition='Common', | ||||
|             name='my-virtual-server', | ||||
|             destination='10.10.10.10', | ||||
|             port=443, | ||||
|             pool='my-pool', | ||||
|             snat='Automap', | ||||
|             description='Test Virtual Server', | ||||
|             profiles=[ | ||||
|                 dict( | ||||
|                     name='fix', | ||||
|                     context='all' | ||||
|                 ) | ||||
|             ], | ||||
|             enabled_vlans=['vlan2'] | ||||
|         ) | ||||
|         p = VirtualServerModuleParameters(args) | ||||
|         assert p.name == 'my-virtual-server' | ||||
|         assert p.partition == 'Common' | ||||
|         assert p.port == 443 | ||||
|         assert p.server == 'localhost' | ||||
|         assert p.user == 'admin' | ||||
|         assert p.password == 'secret' | ||||
|         assert p.destination == '/Common/10.10.10.10:443' | ||||
|         assert p.pool == '/Common/my-pool' | ||||
|         assert p.snat == {'type': 'automap'} | ||||
|         assert p.description == 'Test Virtual Server' | ||||
|         assert len(p.profiles) == 1 | ||||
|         assert 'context' in p.profiles[0] | ||||
|         assert 'name' in p.profiles[0] | ||||
|         assert '/Common/vlan2' in p.enabled_vlans | ||||
| 
 | ||||
|     def test_module_partition_prefix_parameters(self): | ||||
|         args = dict( | ||||
|             server='localhost', | ||||
|             user='admin', | ||||
|             password='secret', | ||||
|             state='present', | ||||
|             partition='Common', | ||||
|             name='my-virtual-server', | ||||
|             destination='10.10.10.10', | ||||
|             port=443, | ||||
|             pool='/Common/my-pool', | ||||
|             snat='Automap', | ||||
|             description='Test Virtual Server', | ||||
|             profiles=[ | ||||
|                 dict( | ||||
|                     name='fix', | ||||
|                     context='all' | ||||
|                 ) | ||||
|             ], | ||||
|             enabled_vlans=['/Common/vlan2'] | ||||
|         ) | ||||
|         p = VirtualServerModuleParameters(args) | ||||
|         assert p.name == 'my-virtual-server' | ||||
|         assert p.partition == 'Common' | ||||
|         assert p.port == 443 | ||||
|         assert p.server == 'localhost' | ||||
|         assert p.user == 'admin' | ||||
|         assert p.password == 'secret' | ||||
|         assert p.destination == '/Common/10.10.10.10:443' | ||||
|         assert p.pool == '/Common/my-pool' | ||||
|         assert p.snat == {'type': 'automap'} | ||||
|         assert p.description == 'Test Virtual Server' | ||||
|         assert len(p.profiles) == 1 | ||||
|         assert 'context' in p.profiles[0] | ||||
|         assert 'name' in p.profiles[0] | ||||
|         assert '/Common/vlan2' in p.enabled_vlans | ||||
| 
 | ||||
|     def test_api_parameters_variables(self): | ||||
|         args = { | ||||
|             "kind": "tm:ltm:virtual:virtualstate", | ||||
|             "name": "my-virtual-server", | ||||
|             "partition": "Common", | ||||
|             "fullPath": "/Common/my-virtual-server", | ||||
|             "generation": 54, | ||||
|             "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server?expandSubcollections=true&ver=12.1.2", | ||||
|             "addressStatus": "yes", | ||||
|             "autoLasthop": "default", | ||||
|             "cmpEnabled": "yes", | ||||
|             "connectionLimit": 0, | ||||
|             "description": "Test Virtual Server", | ||||
|             "destination": "/Common/10.10.10.10:443", | ||||
|             "enabled": True, | ||||
|             "gtmScore": 0, | ||||
|             "ipProtocol": "tcp", | ||||
|             "mask": "255.255.255.255", | ||||
|             "mirror": "disabled", | ||||
|             "mobileAppTunnel": "disabled", | ||||
|             "nat64": "disabled", | ||||
|             "rateLimit": "disabled", | ||||
|             "rateLimitDstMask": 0, | ||||
|             "rateLimitMode": "object", | ||||
|             "rateLimitSrcMask": 0, | ||||
|             "serviceDownImmediateAction": "none", | ||||
|             "source": "0.0.0.0/0", | ||||
|             "sourceAddressTranslation": { | ||||
|                 "type": "automap" | ||||
|             }, | ||||
|             "sourcePort": "preserve", | ||||
|             "synCookieStatus": "not-activated", | ||||
|             "translateAddress": "enabled", | ||||
|             "translatePort": "enabled", | ||||
|             "vlansEnabled": True, | ||||
|             "vsIndex": 3, | ||||
|             "vlans": [ | ||||
|                 "/Common/net1" | ||||
|             ], | ||||
|             "vlansReference": [ | ||||
|                 { | ||||
|                     "link": "https://localhost/mgmt/tm/net/vlan/~Common~net1?ver=12.1.2" | ||||
|                 } | ||||
|             ], | ||||
|             "policiesReference": { | ||||
|                 "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/policies?ver=12.1.2", | ||||
|                 "isSubcollection": True | ||||
|             }, | ||||
|             "profilesReference": { | ||||
|                 "link": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles?ver=12.1.2", | ||||
|                 "isSubcollection": True, | ||||
|                 "items": [ | ||||
|                     { | ||||
|                         "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                         "name": "http", | ||||
|                         "partition": "Common", | ||||
|                         "fullPath": "/Common/http", | ||||
|                         "generation": 54, | ||||
|                         "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~http?ver=12.1.2", | ||||
|                         "context": "all", | ||||
|                         "nameReference": { | ||||
|                             "link": "https://localhost/mgmt/tm/ltm/profile/http/~Common~http?ver=12.1.2" | ||||
|                         } | ||||
|                     }, | ||||
|                     { | ||||
|                         "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                         "name": "serverssl", | ||||
|                         "partition": "Common", | ||||
|                         "fullPath": "/Common/serverssl", | ||||
|                         "generation": 54, | ||||
|                         "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~serverssl?ver=12.1.2", | ||||
|                         "context": "serverside", | ||||
|                         "nameReference": { | ||||
|                             "link": "https://localhost/mgmt/tm/ltm/profile/server-ssl/~Common~serverssl?ver=12.1.2" | ||||
|                         } | ||||
|                     }, | ||||
|                     { | ||||
|                         "kind": "tm:ltm:virtual:profiles:profilesstate", | ||||
|                         "name": "tcp", | ||||
|                         "partition": "Common", | ||||
|                         "fullPath": "/Common/tcp", | ||||
|                         "generation": 54, | ||||
|                         "selfLink": "https://localhost/mgmt/tm/ltm/virtual/~Common~my-virtual-server/profiles/~Common~tcp?ver=12.1.2", | ||||
|                         "context": "all", | ||||
|                         "nameReference": { | ||||
|                             "link": "https://localhost/mgmt/tm/ltm/profile/tcp/~Common~tcp?ver=12.1.2" | ||||
|                         } | ||||
|                     } | ||||
|                 ] | ||||
|             } | ||||
|         } | ||||
|         p = VirtualServerApiParameters(args) | ||||
|         assert p.name == 'my-virtual-server' | ||||
|         assert p.partition == 'Common' | ||||
|         assert p.port == 443 | ||||
|         assert p.destination == '/Common/10.10.10.10:443' | ||||
|         assert p.snat == {'type': 'automap'} | ||||
|         assert p.description == 'Test Virtual Server' | ||||
|         assert 'context' in p.profiles[0] | ||||
|         assert 'name' in p.profiles[0] | ||||
|         assert 'fullPath' in p.profiles[0] | ||||
|         assert p.profiles[0]['context'] == 'all' | ||||
|         assert p.profiles[0]['name'] == 'http' | ||||
|         assert p.profiles[0]['fullPath'] == '/Common/http' | ||||
|         assert '/Common/net1' in p.vlans | ||||
| 
 | ||||
| 
 | ||||
| @patch('ansible.module_utils.f5_utils.AnsibleF5Client._get_mgmt_root', | ||||
|        return_value=True) | ||||
| class TestManager(unittest.TestCase): | ||||
| 
 | ||||
|     def setUp(self): | ||||
|         self.spec = ArgumentSpec() | ||||
| 
 | ||||
|     def test_create_virtual_server(self, *args): | ||||
|         set_module_args(dict( | ||||
|             all_profiles=[ | ||||
|                 dict( | ||||
|                     name='http' | ||||
|                 ), | ||||
|                 dict( | ||||
|                     name='clientssl' | ||||
|                 ) | ||||
|             ], | ||||
|             description="Test Virtual Server", | ||||
|             destination="10.10.10.10", | ||||
|             name="my-snat-pool", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="443", | ||||
|             server="localhost", | ||||
|             snat="Automap", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=False) | ||||
|         vsm.create_on_device = Mock(return_value=True) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is True | ||||
| 
 | ||||
|     def test_delete_virtual_server(self, *args): | ||||
|         set_module_args(dict( | ||||
|             all_profiles=[ | ||||
|                 'http', 'clientssl' | ||||
|             ], | ||||
|             description="Test Virtual Server", | ||||
|             destination="10.10.10.10", | ||||
|             name="my-snat-pool", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="443", | ||||
|             server="localhost", | ||||
|             snat="Automap", | ||||
|             state="absent", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=False) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
| 
 | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is False | ||||
| 
 | ||||
|     def test_enable_vs_that_is_already_enabled(self, *args): | ||||
|         set_module_args(dict( | ||||
|             all_profiles=[ | ||||
|                 'http', 'clientssl' | ||||
|             ], | ||||
|             description="Test Virtual Server", | ||||
|             destination="10.10.10.10", | ||||
|             name="my-snat-pool", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="443", | ||||
|             server="localhost", | ||||
|             snat="Automap", | ||||
|             state="absent", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters( | ||||
|             dict( | ||||
|                 agent_status_traps='disabled' | ||||
|             ) | ||||
|         ) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=False) | ||||
|         vsm.update_on_device = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is False | ||||
| 
 | ||||
|     def test_modify_port(self, *args): | ||||
|         set_module_args(dict( | ||||
|             name="my-virtual-server", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="10443", | ||||
|             server="localhost", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_1.json')) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
|         vsm.update_on_device = Mock(return_value=True) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is True | ||||
| 
 | ||||
|     def test_modify_port_idempotent(self, *args): | ||||
|         set_module_args(dict( | ||||
|             name="my-virtual-server", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="443", | ||||
|             server="localhost", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_1.json')) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is False | ||||
| 
 | ||||
|     def test_modify_vlans_idempotent(self, *args): | ||||
|         set_module_args(dict( | ||||
|             name="my-virtual-server", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             disabled_vlans=[ | ||||
|                 "net1" | ||||
|             ], | ||||
|             server="localhost", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_2.json')) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
| 
 | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is False | ||||
| 
 | ||||
|     def test_modify_profiles(self, *args): | ||||
|         set_module_args(dict( | ||||
|             name="my-virtual-server", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             profiles=[ | ||||
|                 'http', 'clientssl' | ||||
|             ], | ||||
|             server="localhost", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_2.json')) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
|         vsm.update_on_device = Mock(return_value=True) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
| 
 | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is True | ||||
|         assert len(results['profiles']) == 2 | ||||
|         assert 'name' in results['profiles'][0] | ||||
|         assert 'context' in results['profiles'][0] | ||||
|         assert results['profiles'][0]['name'] == 'http' | ||||
|         assert results['profiles'][0]['context'] == 'all' | ||||
|         assert 'name' in results['profiles'][1] | ||||
|         assert 'context' in results['profiles'][1] | ||||
|         assert results['profiles'][1]['name'] == 'clientssl' | ||||
|         assert results['profiles'][1]['context'] == 'clientside' | ||||
| 
 | ||||
|     def test_update_virtual_server(self, *args): | ||||
|         set_module_args(dict( | ||||
|             profiles=[ | ||||
|                 dict( | ||||
|                     name='http' | ||||
|                 ), | ||||
|                 dict( | ||||
|                     name='clientssl' | ||||
|                 ) | ||||
|             ], | ||||
|             description="foo virtual", | ||||
|             destination="1.1.1.1", | ||||
|             name="my-virtual-server", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="8443", | ||||
|             server="localhost", | ||||
|             snat="snat-pool1", | ||||
|             state="disabled", | ||||
|             source='1.2.3.4/32', | ||||
|             user="admin", | ||||
|             validate_certs="no", | ||||
|             irules=[ | ||||
|                 'irule1', | ||||
|                 'irule2' | ||||
|             ], | ||||
|             policies=[ | ||||
|                 'policy1', | ||||
|                 'policy2' | ||||
|             ], | ||||
|             enabled_vlans=[ | ||||
|                 'vlan1', | ||||
|                 'vlan2' | ||||
|             ], | ||||
|             pool='my-pool', | ||||
|             default_persistence_profile='source_addr', | ||||
|             fallback_persistence_profile='dest_addr' | ||||
|         )) | ||||
| 
 | ||||
|         # Configure the parameters that would be returned by querying the | ||||
|         # remote device | ||||
|         current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_3.json')) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         # Override methods to force specific logic in the module to happen | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=current) | ||||
|         vsm.update_on_device = Mock(return_value=True) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(return_value=vsm) | ||||
| 
 | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is True | ||||
|         assert results['source'] == '1.2.3.4/32' | ||||
|         assert results['description'] == 'foo virtual' | ||||
|         assert results['snat'] == '/Common/snat-pool1' | ||||
|         assert results['destination'] == '1.1.1.1' | ||||
|         assert results['port'] == 8443 | ||||
|         assert results['default_persistence_profile'] == '/Common/source_addr' | ||||
|         assert results['fallback_persistence_profile'] == '/Common/dest_addr' | ||||
| 
 | ||||
|         # policies | ||||
|         assert len(results['policies']) == 2 | ||||
|         assert '/Common/policy1' in results['policies'] | ||||
|         assert '/Common/policy2' in results['policies'] | ||||
| 
 | ||||
|         # irules | ||||
|         assert len(results['irules']) == 2 | ||||
|         assert '/Common/irule1' in results['irules'] | ||||
|         assert '/Common/irule2' in results['irules'] | ||||
| 
 | ||||
|         # vlans | ||||
|         assert len(results['enabled_vlans']) == 2 | ||||
|         assert '/Common/vlan1' in results['enabled_vlans'] | ||||
|         assert '/Common/vlan2' in results['enabled_vlans'] | ||||
| 
 | ||||
|         # profiles | ||||
|         assert len(results['profiles']) == 2 | ||||
|         assert 'name' in results['profiles'][0] | ||||
|         assert 'context' in results['profiles'][0] | ||||
|         assert results['profiles'][0]['name'] == 'http' | ||||
|         assert results['profiles'][0]['context'] == 'all' | ||||
|         assert 'name' in results['profiles'][1] | ||||
|         assert 'context' in results['profiles'][1] | ||||
|         assert results['profiles'][1]['name'] == 'clientssl' | ||||
|         assert results['profiles'][1]['context'] == 'clientside' | ||||
| 
 | ||||
| 
 | ||||
| @patch('ansible.module_utils.f5_utils.AnsibleF5Client._get_mgmt_root', | ||||
|        return_value=True) | ||||
| class TestDeprecatedAnsible24Manager(unittest.TestCase): | ||||
|     def setUp(self): | ||||
|         self.spec = ArgumentSpec() | ||||
| 
 | ||||
|     def test_modify_port_idempotent(self, *args): | ||||
|         set_module_args(dict( | ||||
|             destination="10.10.10.10", | ||||
|             name="my-virtual-server", | ||||
|             route_advertisement_state="enabled", | ||||
|             partition="Common", | ||||
|             password="secret", | ||||
|             port="443", | ||||
|             server="localhost", | ||||
|             state="present", | ||||
|             user="admin", | ||||
|             validate_certs="no" | ||||
|         )) | ||||
| 
 | ||||
|         client = AnsibleF5Client( | ||||
|             argument_spec=self.spec.argument_spec, | ||||
|             supports_check_mode=self.spec.supports_check_mode, | ||||
|             f5_product_name=self.spec.f5_product_name | ||||
|         ) | ||||
| 
 | ||||
|         vsm_current = VirtualServerApiParameters(load_fixture('load_ltm_virtual_1.json')) | ||||
|         vam_current = VirtualAddressParameters(load_fixture('load_ltm_virtual_1_address.json')) | ||||
| 
 | ||||
|         vsm = VirtualServerManager(client) | ||||
|         vsm.exists = Mock(return_value=True) | ||||
|         vsm.read_current_from_device = Mock(return_value=vsm_current) | ||||
|         vam = VirtualAddressManager(client) | ||||
|         vam.exists = Mock(return_value=True) | ||||
|         vam.read_current_from_device = Mock(return_value=vam_current) | ||||
| 
 | ||||
|         mm = ModuleManager(client) | ||||
|         mm.get_manager = Mock(side_effect=[vsm, vam]) | ||||
| 
 | ||||
|         results = mm.exec_module() | ||||
| 
 | ||||
|         assert results['changed'] is False | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue