Fixes some bugs and things (#35122)

Removes deprecations and fixes bugs.
This commit is contained in:
Tim Rupp 2018-01-20 10:40:20 -08:00 committed by GitHub
parent a0bb193598
commit ca8982f96c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
23 changed files with 136 additions and 230 deletions

View file

@ -427,14 +427,6 @@ class ArgumentSpec(object):
type='str', type='str',
default='rest', default='rest',
choices=['cli', 'rest'] choices=['cli', 'rest']
),
password=dict(
fallback=(env_fallback, ['F5_PASSWORD']),
no_log=True
),
partition=dict(
default='Common',
fallback=(env_fallback, ['F5_PARTITION'])
) )
) )
self.argument_spec = {} self.argument_spec = {}

View file

@ -492,13 +492,10 @@ class ModuleManager(object):
return False return False
def exec_module(self): def exec_module(self):
changed = False
result = dict() result = dict()
state = self.want.state
try: try:
if state == "present": changed = self.update()
changed = self.update()
except iControlUnexpectedHTTPError as e: except iControlUnexpectedHTTPError as e:
raise F5ModuleError(str(e)) raise F5ModuleError(str(e))
@ -556,11 +553,7 @@ class ArgumentSpec(object):
), ),
mirror_primary_address=dict(), mirror_primary_address=dict(),
mirror_secondary_address=dict(), mirror_secondary_address=dict(),
config_sync_ip=dict(), config_sync_ip=dict()
state=dict(
default='present',
choices=['present']
)
) )
self.argument_spec = {} self.argument_spec = {}
self.argument_spec.update(f5_argument_spec) self.argument_spec.update(f5_argument_spec)

View file

@ -27,7 +27,7 @@ options:
choices: choices:
- pool - pool
- wide_ip - wide_ip
- virtual_server - server
filter: filter:
description: description:
- Perform regex filter of response. Filtering is done on the name of - Perform regex filter of response. Filtering is done on the name of
@ -117,13 +117,13 @@ pool:
ttl: 30 ttl: 30
type: naptr type: naptr
verify_member_availability: disabled verify_member_availability: disabled
virtual_server: server:
description: description:
Contains the virtual server enabled and availability status, and address. Contains the virtual server enabled and availability status, and address.
returned: changed returned: changed
type: list type: list
sample: sample:
virtual_server: server:
- addresses: - addresses:
- device_name: /Common/qweqwe - device_name: /Common/qweqwe
name: 10.10.10.10 name: 10.10.10.10
@ -231,10 +231,6 @@ class BaseManager(object):
srvs='srv' srvs='srv'
) )
def exec_module(self):
result = self.read_current_from_device()
return result
def filter_matches_name(self, name): def filter_matches_name(self, name):
if self.want.filter is None: if self.want.filter is None:
return True return True
@ -270,7 +266,8 @@ class UntypedManager(BaseManager):
results = [] results = []
facts = self.read_facts() facts = self.read_facts()
for item in facts: for item in facts:
filtered = [(k, v) for k, v in iteritems(item) if self.filter_matches_name(k)] attrs = item.to_return()
filtered = [(k, v) for k, v in iteritems(attrs) if self.filter_matches_name(k)]
if filtered: if filtered:
results.append(dict(filtered)) results.append(dict(filtered))
return results return results
@ -297,19 +294,12 @@ class Parameters(AnsibleF5Parameters):
@property @property
def include(self): def include(self):
requested = self._values['include'] requested = self._values['include']
valid = ['pool', 'wide_ip', 'virtual_server', 'server', 'all'] valid = ['pool', 'wide_ip', 'server', 'all']
if any(x for x in requested if x not in valid): if any(x for x in requested if x not in valid):
raise F5ModuleError( raise F5ModuleError(
"The valid 'include' choices are {0}".format(', '.join(valid)) "The valid 'include' choices are {0}".format(', '.join(valid))
) )
if any(x for x in requested if x == 'virtual_server'):
self._values['__warnings'].append(
dict(
msg="The 'virtual_server' param is deprecated. Use 'server' instead",
version='2.5'
)
)
if 'all' in requested: if 'all' in requested:
return ['all'] return ['all']
@ -337,9 +327,11 @@ class BaseParameters(Parameters):
return False return False
def _remove_internal_keywords(self, resource): def _remove_internal_keywords(self, resource):
del resource['kind'] resource.pop('kind', None)
del resource['generation'] resource.pop('generation', None)
del resource['selfLink'] resource.pop('selfLink', None)
resource.pop('isSubcollection', None)
resource.pop('fullPath', None)
def to_return(self): def to_return(self):
result = {} result = {}
@ -653,7 +645,7 @@ class ServerParameters(BaseParameters):
if 'translationAddress' in item: if 'translationAddress' in item:
item['translation_address'] = item.pop('translationAddress') item['translation_address'] = item.pop('translationAddress')
if 'translationPort' in item: if 'translationPort' in item:
item['translation_port'] = int(item.pop('translation_port')) item['translation_port'] = int(item.pop('translationPort'))
result.append(item) result.append(item)
return result return result
@ -724,7 +716,7 @@ class TypedPoolFactManager(TypedManager):
for resource in collection: for resource in collection:
attrs = resource.attrs attrs = resource.attrs
attrs['stats'] = self.read_stats_from_device(resource) attrs['stats'] = self.read_stats_from_device(resource)
params = PoolParameters(attrs) params = PoolParameters(params=attrs)
results.append(params) results.append(params)
return results return results
@ -752,7 +744,7 @@ class UntypedPoolFactManager(UntypedManager):
for resource in collection: for resource in collection:
attrs = resource.attrs attrs = resource.attrs
attrs['stats'] = self.read_stats_from_device(resource) attrs['stats'] = self.read_stats_from_device(resource)
params = PoolParameters(attrs) params = PoolParameters(params=attrs)
results.append(params) results.append(params)
return results return results
@ -794,7 +786,7 @@ class TypedWideIpFactManager(TypedManager):
collection = self.read_collection_from_device(collection) collection = self.read_collection_from_device(collection)
for resource in collection: for resource in collection:
attrs = resource.attrs attrs = resource.attrs
params = WideIpParameters(attrs) params = WideIpParameters(params=attrs)
results.append(params) results.append(params)
return results return results
@ -821,7 +813,7 @@ class UntypedWideIpFactManager(UntypedManager):
collection = self.read_collection_from_device() collection = self.read_collection_from_device()
for resource in collection: for resource in collection:
attrs = resource.attrs attrs = resource.attrs
params = WideIpParameters(attrs) params = WideIpParameters(params=attrs)
results.append(params) results.append(params)
return results return results
@ -843,7 +835,7 @@ class ServerFactManager(UntypedManager):
def exec_module(self): def exec_module(self):
facts = super(ServerFactManager, self).exec_module() facts = super(ServerFactManager, self).exec_module()
result = dict(server=facts, virtual_server=facts) result = dict(server=facts)
return result return result
def read_facts(self): def read_facts(self):
@ -851,7 +843,7 @@ class ServerFactManager(UntypedManager):
collection = self.read_collection_from_device() collection = self.read_collection_from_device()
for resource in collection: for resource in collection:
attrs = resource.attrs attrs = resource.attrs
params = WideIpParameters(attrs) params = ServerParameters(params=attrs)
results.append(params) results.append(params)
return results return results
@ -881,10 +873,6 @@ class ModuleManager(object):
names = ['pool', 'wide_ip', 'server'] names = ['pool', 'wide_ip', 'server']
else: else:
names = self.want.include names = self.want.include
# The virtual_server parameter is deprecated
if 'virtual_server' in names:
names.append('server')
names.remove('virtual_server')
managers = [self.get_manager(name) for name in names] managers = [self.get_manager(name) for name in names]
result = self.execute_managers(managers) result = self.execute_managers(managers)
if result: if result:

View file

@ -78,6 +78,8 @@ options:
- foundry-server-iron - foundry-server-iron
- netapp - netapp
- windows-2000-server - windows-2000-server
aliases:
- product
link_discovery: link_discovery:
description: description:
- Specifies whether the system auto-discovers the links for this server. When - Specifies whether the system auto-discovers the links for this server. When

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has

View file

@ -26,8 +26,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
description: description:
description: description:
- Specifies descriptive text that identifies the monitor. - Specifies descriptive text that identifies the monitor.
@ -400,13 +398,6 @@ class Difference(object):
"The parent monitor cannot be changed" "The parent monitor cannot be changed"
) )
@property
def destination(self):
if self.want.ip is None:
return None
if self.want.destination != self.have.destination:
return self.want.destination
@property @property
def interval(self): def interval(self):
if self.want.timeout is not None and self.want.interval is not None: if self.want.timeout is not None and self.want.interval is not None:
@ -613,7 +604,6 @@ class ArgumentSpec(object):
name=dict(required=True), name=dict(required=True),
description=dict(), description=dict(),
parent=dict(default='/Common/snmp_dca'), parent=dict(default='/Common/snmp_dca'),
ip=dict(),
interval=dict(type='int'), interval=dict(type='int'),
timeout=dict(type='int'), timeout=dict(type='int'),
time_until_up=dict(type='int'), time_until_up=dict(type='int'),

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has
@ -44,19 +42,6 @@ options:
'*'. '*'.
- If this value is an IP address, and the C(type) is C(tcp) (the default), - If this value is an IP address, and the C(type) is C(tcp) (the default),
then a C(port) number must be specified. then a C(port) number must be specified.
type:
description:
- The template type of this monitor template.
- Deprecated in 2.4. Use one of the C(bigip_monitor_tcp_echo) or
C(bigip_monitor_tcp_half_open) modules instead.
default: tcp
choices:
- tcp
- tcp_echo
- tcp_half_open
- TTYPE_TCP
- TTYPE_TCP_ECHO
- TTYPE_TCP_HALF_OPEN
port: port:
description: description:
- Port address part of the IP/port definition. If this parameter is not - Port address part of the IP/port definition. If this parameter is not

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has

View file

@ -23,8 +23,6 @@ options:
description: description:
- Monitor name. - Monitor name.
required: True required: True
aliases:
- monitor
parent: parent:
description: description:
- The parent template of this monitor template. Once this value has - The parent template of this monitor template. Once this value has

View file

@ -20,6 +20,10 @@ description:
- Manage BIG-IP partitions. - Manage BIG-IP partitions.
version_added: "2.5" version_added: "2.5"
options: options:
name:
description:
- Name of the partition
required: True
description: description:
description: description:
- The description to attach to the Partition. - The description to attach to the Partition.

View file

@ -20,6 +20,9 @@ description:
- This module will manage LTM policy rules on a BIG-IP. - This module will manage LTM policy rules on a BIG-IP.
version_added: 2.5 version_added: 2.5
options: options:
description:
description:
- Description of the policy rule.
actions: actions:
description: description:
- The actions that you want the policy rule to perform. - The actions that you want the policy rule to perform.

View file

@ -57,18 +57,24 @@ options:
- weighted-least-connections-nod - weighted-least-connections-nod
monitor_type: monitor_type:
description: description:
- Monitor rule type when C(monitors) is specified. When creating a new - Monitor rule type when C(monitors) is specified.
pool, if this value is not specified, the default of 'and_list' will - When creating a new pool, if this value is not specified, the default
be used. of 'and_list' will be used.
- When C(single) ensures that all specified monitors are checked, but
additionally includes checks to make sure you only specified a single
monitor.
- When C(and_list) ensures that B(all) monitors are checked.
- When C(m_of_n) ensures that C(quorum) of C(monitors) are checked. C(m_of_n)
B(requires) that a C(quorum) of 1 or greater be set either in the playbook,
or already existing on the device.
- Both C(single) and C(and_list) are functionally identical since BIG-IP - Both C(single) and C(and_list) are functionally identical since BIG-IP
considers all monitors as "a list". BIG=IP either has a list of many, considers all monitors as "a list".
or it has a list of one. Where they differ is in the extra guards that
C(single) provides; namely that it only allows a single monitor.
version_added: "1.3" version_added: "1.3"
choices: ['and_list', 'm_of_n', 'single'] choices: ['and_list', 'm_of_n', 'single']
quorum: quorum:
description: description:
- Monitor quorum value when C(monitor_type) is C(m_of_n). - Monitor quorum value when C(monitor_type) is C(m_of_n).
- Quorum must be a value of 1 or greater when C(monitor_type) is C(m_of_n).
version_added: "1.3" version_added: "1.3"
monitors: monitors:
description: description:
@ -99,7 +105,17 @@ options:
- Device partition to manage resources on. - Device partition to manage resources on.
default: Common default: Common
version_added: 2.5 version_added: 2.5
metdata: state:
description:
- When C(present), guarantees that the pool exists with the provided
attributes.
- When C(absent), removes the pool from the system.
default: present
choices:
- absent
- present
version_added: 2.5
metadata:
description: description:
- Arbitrary key/value pairs that you can attach to a pool. This is useful in - Arbitrary key/value pairs that you can attach to a pool. This is useful in
situations where you might want to annotate a pool to me managed by Ansible. situations where you might want to annotate a pool to me managed by Ansible.
@ -521,6 +537,15 @@ class ReportableChanges(Changes):
result = sorted(re.findall(r'/\w+/[^\s}]+', self._values['monitors'])) result = sorted(re.findall(r'/\w+/[^\s}]+', self._values['monitors']))
return result return result
@property
def monitor_type(self):
pattern = r'min\s+\d+\s+of'
matches = re.search(pattern, self._values['monitors'])
if matches:
return 'm_of_n'
else:
return 'and_list'
@property @property
def metadata(self): def metadata(self):
result = dict() result = dict()
@ -569,16 +594,29 @@ class Difference(object):
else: else:
return want return want
@property def _monitors_and_quorum(self):
def monitor_type(self):
if self.want.monitor_type is None: if self.want.monitor_type is None:
self.want.update(dict(monitor_type=self.have.monitor_type)) self.want.update(dict(monitor_type=self.have.monitor_type))
if self.want.quorum is None: if self.want.monitor_type == 'm_of_n':
self.want.update(dict(quorum=self.have.quorum)) if self.want.quorum is None:
if self.want.monitor_type == 'm_of_n' and self.want.quorum is None: self.want.update(dict(quorum=self.have.quorum))
raise F5ModuleError( if self.want.quorum is None or self.want.quorum < 1:
"Quorum value must be specified with monitor_type 'm_of_n'." raise F5ModuleError(
) "Quorum value must be specified with monitor_type 'm_of_n'."
)
if self.want.monitors != self.have.monitors:
return dict(
monitors=self.want.monitors
)
elif self.want.monitor_type == 'and_list':
if self.want.quorum is not None and self.want.quorum > 0:
raise F5ModuleError(
"Quorum values have no effect when used with 'and_list'."
)
if self.want.monitors != self.have.monitors:
return dict(
monitors=self.want.monitors
)
elif self.want.monitor_type == 'single': elif self.want.monitor_type == 'single':
if len(self.want.monitors_list) > 1: if len(self.want.monitors_list) > 1:
raise F5ModuleError( raise F5ModuleError(
@ -598,8 +636,18 @@ class Difference(object):
# Remember that 'single' is nothing more than a fancy way of saying # Remember that 'single' is nothing more than a fancy way of saying
# "and_list plus some extra checks" # "and_list plus some extra checks"
self.want.update(dict(monitor_type='and_list')) self.want.update(dict(monitor_type='and_list'))
if self.want.monitor_type != self.have.monitor_type: if self.want.monitors != self.have.monitors:
return self.want.monitor_type return dict(
monitors=self.want.monitors
)
@property
def monitor_type(self):
return self._monitors_and_quorum()
@property
def quorum(self):
return self._monitors_and_quorum()
@property @property
def monitors(self): def monitors(self):
@ -734,10 +782,14 @@ class ModuleManager(object):
if self.want.monitor_type is None: if self.want.monitor_type is None:
self.want.update(dict(monitor_type='and_list')) self.want.update(dict(monitor_type='and_list'))
if self.want.monitor_type == 'm_of_n' and self.want.quorum is None: if self.want.monitor_type == 'm_of_n' and (self.want.quorum is None or self.want.quorum < 1):
raise F5ModuleError( raise F5ModuleError(
"Quorum value must be specified with monitor_type 'm_of_n'." "Quorum value must be specified with monitor_type 'm_of_n'."
) )
elif self.want.monitor_type == 'and_list' and self.want.quorum is not None and self.want.quorum > 0:
raise F5ModuleError(
"Quorum values have no effect when used with 'and_list'."
)
elif self.want.monitor_type == 'single' and len(self.want.monitors_list) > 1: elif self.want.monitor_type == 'single' and len(self.want.monitors_list) > 1:
raise F5ModuleError( raise F5ModuleError(
"When using a 'monitor_type' of 'single', only one monitor may be provided" "When using a 'monitor_type' of 'single', only one monitor may be provided"

View file

@ -97,6 +97,17 @@ options:
- yes - yes
- no - no
version_added: 2.1 version_added: 2.1
priority_group:
description:
- Specifies a number representing the priority group for the pool member.
- When adding a new member, the default is 0, meaning that the member has no priority.
- To specify a priority, you must activate priority group usage when you
create a new pool or when adding or removing pool members. When activated,
the system load balances traffic according to the priority group number
assigned to the pool member.
- The higher the number, the higher the priority, so a member with a priority
of 3 has higher priority than a member with a priority of 1.
version_added: 2.5
extends_documentation_fragment: f5 extends_documentation_fragment: f5
''' '''

View file

@ -35,6 +35,15 @@ options:
provide no local IP, specify the value C(none). When creating a provide no local IP, specify the value C(none). When creating a
remote syslog, if this parameter is not specified, the default value remote syslog, if this parameter is not specified, the default value
C(none) is used. C(none) is used.
state:
description:
- When C(present), guarantees that the remote syslog exists with the provided
attributes.
- When C(absent), removes the remote syslog from the system.
default: present
choices:
- absent
- present
notes: notes:
- Requires the netaddr Python package on the host. This is as easy as pip - Requires the netaddr Python package on the host. This is as easy as pip
install netaddr. install netaddr.

View file

@ -49,6 +49,11 @@ options:
region: region:
description: description:
- Region name of the country to use. - Region name of the country to use.
addresses:
description:
- Individual addresses that you want to add to the list. These addresses differ
from ranges, and lists of lists such as what can be used in C(address_ranges)
and C(address_lists) respectively.
address_ranges: address_ranges:
description: description:
- A list of address ranges where the range starts with a port number, is followed - A list of address ranges where the range starts with a port number, is followed

View file

@ -41,9 +41,9 @@ options:
is required. is required.
state: state:
description: description:
- The state of the variable on the system. When C(present), guarantees - When C(present), guarantees that the Self-IP exists with the provided
that the Self-IP exists with the provided attributes. When C(absent), attributes.
removes the Self-IP from the system. - When C(absent), removes the Self-IP from the system.
default: present default: present
choices: choices:
- absent - absent

View file

@ -39,7 +39,7 @@ options:
partition: partition:
description: description:
- Device partition to manage resources on. - Device partition to manage resources on.
default: 'Common' default: Common
version_added: 2.5 version_added: 2.5
notes: notes:
- Requires the netaddr Python package on the host. This is as easy as - Requires the netaddr Python package on the host. This is as easy as

View file

@ -152,7 +152,7 @@ options:
- Device partition to manage resources on. - Device partition to manage resources on.
default: Common default: Common
version_added: 2.5 version_added: 2.5
metdata: metadata:
description: description:
- Arbitrary key/value pairs that you can attach to a pool. This is useful in - Arbitrary key/value pairs that you can attach to a pool. This is useful in
situations where you might want to annotate a virtual to me managed by Ansible. situations where you might want to annotate a virtual to me managed by Ansible.

View file

@ -91,7 +91,12 @@ options:
- When creating a new VLAN, if this parameter is not specified, the default - When creating a new VLAN, if this parameter is not specified, the default
of (no) is used. of (no) is used.
version_added: 2.5 version_added: 2.5
choices: [yes, no] type: bool
partition:
description:
- Device partition to manage resources on.
default: Common
version_added: 2.5
notes: notes:
- Requires BIG-IP versions >= 12.0.0 - Requires BIG-IP versions >= 12.0.0
extends_documentation_fragment: f5 extends_documentation_fragment: f5

View file

@ -377,129 +377,6 @@ lib/ansible/modules/network/enos/enos_command.py E323
lib/ansible/modules/network/enos/enos_config.py E323 lib/ansible/modules/network/enos/enos_config.py E323
lib/ansible/modules/network/enos/enos_facts.py E323 lib/ansible/modules/network/enos/enos_facts.py E323
lib/ansible/modules/network/eos/eos_linkagg.py E322 lib/ansible/modules/network/eos/eos_linkagg.py E322
lib/ansible/modules/network/f5/bigip_asm_policy.py E322
lib/ansible/modules/network/f5/bigip_asm_policy.py E323
lib/ansible/modules/network/f5/bigip_command.py E322
lib/ansible/modules/network/f5/bigip_command.py E323
lib/ansible/modules/network/f5/bigip_config.py E322
lib/ansible/modules/network/f5/bigip_config.py E323
lib/ansible/modules/network/f5/bigip_configsync_action.py E322
lib/ansible/modules/network/f5/bigip_configsync_action.py E323
lib/ansible/modules/network/f5/bigip_device_connectivity.py E322
lib/ansible/modules/network/f5/bigip_device_connectivity.py E323
lib/ansible/modules/network/f5/bigip_device_dns.py E322
lib/ansible/modules/network/f5/bigip_device_dns.py E323
lib/ansible/modules/network/f5/bigip_device_group.py E322
lib/ansible/modules/network/f5/bigip_device_group.py E323
lib/ansible/modules/network/f5/bigip_device_httpd.py E322
lib/ansible/modules/network/f5/bigip_device_httpd.py E323
lib/ansible/modules/network/f5/bigip_device_ntp.py E322
lib/ansible/modules/network/f5/bigip_device_ntp.py E323
lib/ansible/modules/network/f5/bigip_device_sshd.py E322
lib/ansible/modules/network/f5/bigip_device_sshd.py E323
lib/ansible/modules/network/f5/bigip_device_trust.py E322
lib/ansible/modules/network/f5/bigip_device_trust.py E323
lib/ansible/modules/network/f5/bigip_facts.py E322
lib/ansible/modules/network/f5/bigip_facts.py E323
lib/ansible/modules/network/f5/bigip_gtm_datacenter.py E322
lib/ansible/modules/network/f5/bigip_gtm_datacenter.py E323
lib/ansible/modules/network/f5/bigip_gtm_facts.py E322
lib/ansible/modules/network/f5/bigip_gtm_facts.py E323
lib/ansible/modules/network/f5/bigip_gtm_pool.py E322
lib/ansible/modules/network/f5/bigip_gtm_pool.py E323
lib/ansible/modules/network/f5/bigip_gtm_server.py E322
lib/ansible/modules/network/f5/bigip_gtm_server.py E323
lib/ansible/modules/network/f5/bigip_gtm_virtual_server.py E322
lib/ansible/modules/network/f5/bigip_gtm_wide_ip.py E322
lib/ansible/modules/network/f5/bigip_gtm_wide_ip.py E323
lib/ansible/modules/network/f5/bigip_hostname.py E322
lib/ansible/modules/network/f5/bigip_hostname.py E323
lib/ansible/modules/network/f5/bigip_iapp_service.py E322
lib/ansible/modules/network/f5/bigip_iapp_service.py E323
lib/ansible/modules/network/f5/bigip_iapp_template.py E322
lib/ansible/modules/network/f5/bigip_iapp_template.py E323
lib/ansible/modules/network/f5/bigip_iapplx_package.py E322
lib/ansible/modules/network/f5/bigip_iapplx_package.py E323
lib/ansible/modules/network/f5/bigip_irule.py E322
lib/ansible/modules/network/f5/bigip_irule.py E323
lib/ansible/modules/network/f5/bigip_monitor_http.py E322
lib/ansible/modules/network/f5/bigip_monitor_http.py E323
lib/ansible/modules/network/f5/bigip_monitor_https.py E322
lib/ansible/modules/network/f5/bigip_monitor_https.py E323
lib/ansible/modules/network/f5/bigip_monitor_snmp_dca.py E322
lib/ansible/modules/network/f5/bigip_monitor_snmp_dca.py E323
lib/ansible/modules/network/f5/bigip_monitor_tcp.py E322
lib/ansible/modules/network/f5/bigip_monitor_tcp.py E323
lib/ansible/modules/network/f5/bigip_monitor_tcp_echo.py E322
lib/ansible/modules/network/f5/bigip_monitor_tcp_echo.py E323
lib/ansible/modules/network/f5/bigip_monitor_tcp_half_open.py E322
lib/ansible/modules/network/f5/bigip_monitor_tcp_half_open.py E323
lib/ansible/modules/network/f5/bigip_monitor_udp.py E322
lib/ansible/modules/network/f5/bigip_monitor_udp.py E323
lib/ansible/modules/network/f5/bigip_node.py E322
lib/ansible/modules/network/f5/bigip_node.py E323
lib/ansible/modules/network/f5/bigip_partition.py E322
lib/ansible/modules/network/f5/bigip_partition.py E323
lib/ansible/modules/network/f5/bigip_policy.py E322
lib/ansible/modules/network/f5/bigip_policy.py E323
lib/ansible/modules/network/f5/bigip_policy_rule.py E322
lib/ansible/modules/network/f5/bigip_policy_rule.py E323
lib/ansible/modules/network/f5/bigip_pool.py E322
lib/ansible/modules/network/f5/bigip_pool.py E323
lib/ansible/modules/network/f5/bigip_pool_member.py E322
lib/ansible/modules/network/f5/bigip_pool_member.py E323
lib/ansible/modules/network/f5/bigip_profile_client_ssl.py E322
lib/ansible/modules/network/f5/bigip_profile_client_ssl.py E323
lib/ansible/modules/network/f5/bigip_provision.py E322
lib/ansible/modules/network/f5/bigip_provision.py E323
lib/ansible/modules/network/f5/bigip_qkview.py E322
lib/ansible/modules/network/f5/bigip_qkview.py E323
lib/ansible/modules/network/f5/bigip_remote_syslog.py E322
lib/ansible/modules/network/f5/bigip_remote_syslog.py E323
lib/ansible/modules/network/f5/bigip_security_address_list.py E322
lib/ansible/modules/network/f5/bigip_security_address_list.py E323
lib/ansible/modules/network/f5/bigip_security_port_list.py E322
lib/ansible/modules/network/f5/bigip_security_port_list.py E323
lib/ansible/modules/network/f5/bigip_selfip.py E322
lib/ansible/modules/network/f5/bigip_selfip.py E323
lib/ansible/modules/network/f5/bigip_snat_pool.py E322
lib/ansible/modules/network/f5/bigip_snat_pool.py E323
lib/ansible/modules/network/f5/bigip_snmp.py E322
lib/ansible/modules/network/f5/bigip_snmp.py E323
lib/ansible/modules/network/f5/bigip_snmp_trap.py E322
lib/ansible/modules/network/f5/bigip_snmp_trap.py E323
lib/ansible/modules/network/f5/bigip_software_update.py E322
lib/ansible/modules/network/f5/bigip_software_update.py E323
lib/ansible/modules/network/f5/bigip_ssl_certificate.py E322
lib/ansible/modules/network/f5/bigip_ssl_certificate.py E323
lib/ansible/modules/network/f5/bigip_ssl_key.py E322
lib/ansible/modules/network/f5/bigip_ssl_key.py E323
lib/ansible/modules/network/f5/bigip_static_route.py E322
lib/ansible/modules/network/f5/bigip_static_route.py E323
lib/ansible/modules/network/f5/bigip_sys_db.py E322
lib/ansible/modules/network/f5/bigip_sys_db.py E323
lib/ansible/modules/network/f5/bigip_sys_global.py E322
lib/ansible/modules/network/f5/bigip_sys_global.py E323
lib/ansible/modules/network/f5/bigip_traffic_group.py E322
lib/ansible/modules/network/f5/bigip_traffic_group.py E323
lib/ansible/modules/network/f5/bigip_ucs.py E322
lib/ansible/modules/network/f5/bigip_ucs.py E323
lib/ansible/modules/network/f5/bigip_user.py E322
lib/ansible/modules/network/f5/bigip_user.py E323
lib/ansible/modules/network/f5/bigip_vcmp_guest.py E322
lib/ansible/modules/network/f5/bigip_vcmp_guest.py E323
lib/ansible/modules/network/f5/bigip_virtual_address.py E322
lib/ansible/modules/network/f5/bigip_virtual_address.py E323
lib/ansible/modules/network/f5/bigip_virtual_server.py E322
lib/ansible/modules/network/f5/bigip_virtual_server.py E323
lib/ansible/modules/network/f5/bigip_vlan.py E322
lib/ansible/modules/network/f5/bigip_vlan.py E323
lib/ansible/modules/network/f5/bigip_wait.py E322
lib/ansible/modules/network/f5/bigip_wait.py E323
lib/ansible/modules/network/f5/bigiq_regkey_license.py E322
lib/ansible/modules/network/f5/bigiq_regkey_license.py E323
lib/ansible/modules/network/f5/bigiq_regkey_pool.py E322
lib/ansible/modules/network/f5/bigiq_regkey_pool.py E323
lib/ansible/modules/network/illumos/dladm_linkprop.py E317 lib/ansible/modules/network/illumos/dladm_linkprop.py E317
lib/ansible/modules/network/illumos/ipadm_addrprop.py E317 lib/ansible/modules/network/illumos/ipadm_addrprop.py E317
lib/ansible/modules/network/illumos/ipadm_ifprop.py E317 lib/ansible/modules/network/illumos/ipadm_ifprop.py E317

View file

@ -135,7 +135,7 @@ class TestManager(unittest.TestCase):
# Configure the parameters that would be returned by querying the # Configure the parameters that would be returned by querying the
# remote device # remote device
current = Parameters( current = Parameters(
dict( params=dict(
agent_status_traps='disabled' agent_status_traps='disabled'
) )
) )