mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Bump version to 2.0.0 (#1369)
* Bump version to 2.0.0. * Remove deprecated 2.0.0 features. * Test for failure. * Fix cache plugin unit tests. * Accept direct import only for Ansible 2.9.
This commit is contained in:
parent
25c52d56bd
commit
1db167b12a
9 changed files with 21 additions and 50 deletions
5
changelogs/fragments/deprecation-removals.yml
Normal file
5
changelogs/fragments/deprecation-removals.yml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
removed_features:
|
||||||
|
- "iptables_state - the ``ANSIBLE_ASYNC_DIR`` environment is no longer supported, use the ``async_dir`` shell option instead (https://github.com/ansible-collections/community.general/pull/1371)."
|
||||||
|
- "memcached cache plugin - do not import ``CacheModule``s directly. Use ``ansible.plugins.loader.cache_loader`` instead (https://github.com/ansible-collections/community.general/pull/1371)."
|
||||||
|
- "redis cache plugin - do not import ``CacheModule``s directly. Use ``ansible.plugins.loader.cache_loader`` instead (https://github.com/ansible-collections/community.general/pull/1371)."
|
||||||
|
- "xml - when ``content=attribute``, the ``attribute`` option is ignored (https://github.com/ansible-collections/community.general/pull/1371)."
|
|
@ -1,6 +1,6 @@
|
||||||
namespace: community
|
namespace: community
|
||||||
name: general
|
name: general
|
||||||
version: 1.3.0
|
version: 2.0.0
|
||||||
readme: README.md
|
readme: README.md
|
||||||
authors:
|
authors:
|
||||||
- Ansible (https://github.com/ansible)
|
- Ansible (https://github.com/ansible)
|
||||||
|
|
|
@ -98,25 +98,9 @@ class ActionModule(ActionBase):
|
||||||
task_async,
|
task_async,
|
||||||
max_timeout))
|
max_timeout))
|
||||||
|
|
||||||
# BEGIN snippet from async_status action plugin
|
# inject the async directory based on the shell option into the
|
||||||
env_async_dir = [e for e in self._task.environment if
|
# module args
|
||||||
"ANSIBLE_ASYNC_DIR" in e]
|
async_dir = self.get_shell_option('async_dir', default="~/.ansible_async")
|
||||||
if len(env_async_dir) > 0:
|
|
||||||
# for backwards compatibility we need to get the dir from
|
|
||||||
# ANSIBLE_ASYNC_DIR that is defined in the environment. This is
|
|
||||||
# deprecated and will be removed in favour of shell options
|
|
||||||
async_dir = env_async_dir[0]['ANSIBLE_ASYNC_DIR']
|
|
||||||
|
|
||||||
msg = "Setting the async dir from the environment keyword " \
|
|
||||||
"ANSIBLE_ASYNC_DIR is deprecated. Set the async_dir " \
|
|
||||||
"shell option instead"
|
|
||||||
display.deprecated(msg, version='2.0.0',
|
|
||||||
collection_name='community.general') # was Ansible 2.12
|
|
||||||
else:
|
|
||||||
# inject the async directory based on the shell option into the
|
|
||||||
# module args
|
|
||||||
async_dir = self.get_shell_option('async_dir', default="~/.ansible_async")
|
|
||||||
# END snippet from async_status action plugin
|
|
||||||
|
|
||||||
# Bind the loop max duration to consistent values on both
|
# Bind the loop max duration to consistent values on both
|
||||||
# remote and local sides (if not the same, make the loop
|
# remote and local sides (if not the same, make the loop
|
||||||
|
|
7
plugins/cache/memcached.py
vendored
7
plugins/cache/memcached.py
vendored
|
@ -53,6 +53,7 @@ from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.module_utils.common._collections_compat import MutableSet
|
from ansible.module_utils.common._collections_compat import MutableSet
|
||||||
from ansible.plugins.cache import BaseCacheModule
|
from ansible.plugins.cache import BaseCacheModule
|
||||||
|
from ansible.release import __version__ as ansible_base_version
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -180,9 +181,9 @@ class CacheModule(BaseCacheModule):
|
||||||
self._timeout = self.get_option('_timeout')
|
self._timeout = self.get_option('_timeout')
|
||||||
self._prefix = self.get_option('_prefix')
|
self._prefix = self.get_option('_prefix')
|
||||||
except KeyError:
|
except KeyError:
|
||||||
display.deprecated('Rather than importing CacheModules directly, '
|
# TODO: remove once we no longer support Ansible 2.9
|
||||||
'use ansible.plugins.loader.cache_loader',
|
if not ansible_base_version.startswith('2.9.'):
|
||||||
version='2.0.0', collection_name='community.general') # was Ansible 2.12
|
raise AnsibleError("Do not import CacheModules directly. Use ansible.plugins.loader.cache_loader instead.")
|
||||||
if C.CACHE_PLUGIN_CONNECTION:
|
if C.CACHE_PLUGIN_CONNECTION:
|
||||||
connection = C.CACHE_PLUGIN_CONNECTION.split(',')
|
connection = C.CACHE_PLUGIN_CONNECTION.split(',')
|
||||||
self._timeout = C.CACHE_PLUGIN_TIMEOUT
|
self._timeout = C.CACHE_PLUGIN_TIMEOUT
|
||||||
|
|
7
plugins/cache/redis.py
vendored
7
plugins/cache/redis.py
vendored
|
@ -69,6 +69,7 @@ from ansible.errors import AnsibleError
|
||||||
from ansible.module_utils._text import to_native
|
from ansible.module_utils._text import to_native
|
||||||
from ansible.parsing.ajson import AnsibleJSONEncoder, AnsibleJSONDecoder
|
from ansible.parsing.ajson import AnsibleJSONEncoder, AnsibleJSONDecoder
|
||||||
from ansible.plugins.cache import BaseCacheModule
|
from ansible.plugins.cache import BaseCacheModule
|
||||||
|
from ansible.release import __version__ as ansible_base_version
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -103,9 +104,9 @@ class CacheModule(BaseCacheModule):
|
||||||
self._keys_set = self.get_option('_keyset_name')
|
self._keys_set = self.get_option('_keyset_name')
|
||||||
self._sentinel_service_name = self.get_option('_sentinel_service_name')
|
self._sentinel_service_name = self.get_option('_sentinel_service_name')
|
||||||
except KeyError:
|
except KeyError:
|
||||||
display.deprecated('Rather than importing CacheModules directly, '
|
# TODO: remove once we no longer support Ansible 2.9
|
||||||
'use ansible.plugins.loader.cache_loader',
|
if not ansible_base_version.startswith('2.9.'):
|
||||||
version='2.0.0', collection_name='community.general') # was Ansible 2.12
|
raise AnsibleError("Do not import CacheModules directly. Use ansible.plugins.loader.cache_loader instead.")
|
||||||
if C.CACHE_PLUGIN_CONNECTION:
|
if C.CACHE_PLUGIN_CONNECTION:
|
||||||
uri = C.CACHE_PLUGIN_CONNECTION
|
uri = C.CACHE_PLUGIN_CONNECTION
|
||||||
self._timeout = float(C.CACHE_PLUGIN_TIMEOUT)
|
self._timeout = float(C.CACHE_PLUGIN_TIMEOUT)
|
||||||
|
|
|
@ -826,8 +826,7 @@ def main():
|
||||||
supports_check_mode=True,
|
supports_check_mode=True,
|
||||||
required_by=dict(
|
required_by=dict(
|
||||||
add_children=['xpath'],
|
add_children=['xpath'],
|
||||||
# TODO: Reinstate this in community.general 2.0.0 when we have deprecated the incorrect use below
|
attribute=['value'],
|
||||||
# attribute=['value'],
|
|
||||||
content=['xpath'],
|
content=['xpath'],
|
||||||
set_children=['xpath'],
|
set_children=['xpath'],
|
||||||
value=['xpath'],
|
value=['xpath'],
|
||||||
|
@ -876,12 +875,6 @@ def main():
|
||||||
elif LooseVersion('.'.join(to_native(f) for f in etree.LXML_VERSION)) < LooseVersion('3.0.0'):
|
elif LooseVersion('.'.join(to_native(f) for f in etree.LXML_VERSION)) < LooseVersion('3.0.0'):
|
||||||
module.warn('Using lxml version lower than 3.0.0 does not guarantee predictable element attribute order.')
|
module.warn('Using lxml version lower than 3.0.0 does not guarantee predictable element attribute order.')
|
||||||
|
|
||||||
# Report wrongly used attribute parameter when using content=attribute
|
|
||||||
# TODO: Remove this in community.general 2.0.0 (and reinstate strict parameter test above) and remove the integration test example
|
|
||||||
if content == 'attribute' and attribute is not None:
|
|
||||||
module.deprecate("Parameter 'attribute=%s' is ignored when using 'content=attribute' only 'xpath' is used. Please remove entry." % attribute,
|
|
||||||
version='2.0.0', collection_name='community.general') # was Ansible 2.12
|
|
||||||
|
|
||||||
# Check if the file exists
|
# Check if the file exists
|
||||||
if xml_string:
|
if xml_string:
|
||||||
infile = BytesIO(to_bytes(xml_string, errors='surrogate_or_strict'))
|
infile = BytesIO(to_bytes(xml_string, errors='surrogate_or_strict'))
|
||||||
|
|
|
@ -19,24 +19,19 @@
|
||||||
- get_element_attribute.matches[0]['rating'] is defined
|
- get_element_attribute.matches[0]['rating'] is defined
|
||||||
- get_element_attribute.matches[0]['rating']['subjective'] == 'true'
|
- get_element_attribute.matches[0]['rating']['subjective'] == 'true'
|
||||||
|
|
||||||
# TODO: Remove this in 2.0.0 when this incorrect use of attribute is deprecated
|
- name: Get element attributes (should fail)
|
||||||
- name: Get element attributes
|
|
||||||
xml:
|
xml:
|
||||||
path: /tmp/ansible-xml-beers.xml
|
path: /tmp/ansible-xml-beers.xml
|
||||||
xpath: /business/rating
|
xpath: /business/rating
|
||||||
content: attribute
|
content: attribute
|
||||||
attribute: subjective
|
attribute: subjective
|
||||||
register: get_element_attribute_wrong
|
register: get_element_attribute_wrong
|
||||||
|
ignore_errors: true
|
||||||
|
|
||||||
- name: Test expected result
|
- name: Test expected result
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- get_element_attribute_wrong.changed == false
|
- get_element_attribute_wrong is failed
|
||||||
- get_element_attribute_wrong.matches[0]['rating'] is defined
|
|
||||||
- get_element_attribute_wrong.matches[0]['rating']['subjective'] == 'true'
|
|
||||||
- get_element_attribute_wrong.deprecations is defined
|
|
||||||
- get_element_attribute_wrong.deprecations[0].msg == "Parameter 'attribute=subjective' is ignored when using 'content=attribute' only 'xpath' is used. Please remove entry."
|
|
||||||
- get_element_attribute_wrong.deprecations[0].version == '2.0.0'
|
|
||||||
|
|
||||||
- name: Get element text
|
- name: Get element text
|
||||||
xml:
|
xml:
|
||||||
|
|
4
tests/unit/plugins/cache/test_memcached.py
vendored
4
tests/unit/plugins/cache/test_memcached.py
vendored
|
@ -28,8 +28,4 @@ from ansible_collections.community.general.plugins.cache.memcached import CacheM
|
||||||
|
|
||||||
|
|
||||||
def test_memcached_cachemodule():
|
def test_memcached_cachemodule():
|
||||||
assert isinstance(MemcachedCache(), MemcachedCache)
|
|
||||||
|
|
||||||
|
|
||||||
def test_memcached_cachemodule_with_loader():
|
|
||||||
assert isinstance(cache_loader.get('community.general.memcached'), MemcachedCache)
|
assert isinstance(cache_loader.get('community.general.memcached'), MemcachedCache)
|
||||||
|
|
4
tests/unit/plugins/cache/test_redis.py
vendored
4
tests/unit/plugins/cache/test_redis.py
vendored
|
@ -28,9 +28,5 @@ from ansible_collections.community.general.plugins.cache.redis import CacheModul
|
||||||
|
|
||||||
|
|
||||||
def test_redis_cachemodule():
|
def test_redis_cachemodule():
|
||||||
assert isinstance(RedisCache(), RedisCache)
|
|
||||||
|
|
||||||
|
|
||||||
def test_redis_cachemodule_with_loader():
|
|
||||||
# The _uri option is required for the redis plugin
|
# The _uri option is required for the redis plugin
|
||||||
assert isinstance(cache_loader.get('community.general.redis', **{'_uri': '127.0.0.1:6379:1'}), RedisCache)
|
assert isinstance(cache_loader.get('community.general.redis', **{'_uri': '127.0.0.1:6379:1'}), RedisCache)
|
||||||
|
|
Loading…
Reference in a new issue