2020-01-28 12:12:14 -05:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# (c) 2019 Ansible Project
|
|
|
|
# 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 pytest
|
|
|
|
|
|
|
|
import ansible.module_utils.common.warnings as warnings
|
|
|
|
|
|
|
|
from ansible.module_utils.common.warnings import deprecate, get_deprecation_messages
|
|
|
|
from ansible.module_utils.six import PY3
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def deprecation_messages():
|
|
|
|
return [
|
2020-06-10 00:21:19 +02:00
|
|
|
{'msg': 'First deprecation', 'version': None, 'collection_name': None},
|
|
|
|
{'msg': 'Second deprecation', 'version': None, 'collection_name': 'ansible.builtin'},
|
|
|
|
{'msg': 'Third deprecation', 'version': '2.14', 'collection_name': None},
|
|
|
|
{'msg': 'Fourth deprecation', 'version': '2.9', 'collection_name': None},
|
|
|
|
{'msg': 'Fifth deprecation', 'version': '2.9', 'collection_name': 'ansible.builtin'},
|
|
|
|
{'msg': 'Sixth deprecation', 'date': '2199-12-31', 'collection_name': None},
|
|
|
|
{'msg': 'Seventh deprecation', 'date': '2199-12-31', 'collection_name': 'ansible.builtin'},
|
2020-01-28 12:12:14 -05:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
@pytest.fixture
|
|
|
|
def reset(monkeypatch):
|
|
|
|
monkeypatch.setattr(warnings, '_global_deprecations', [])
|
|
|
|
|
|
|
|
|
|
|
|
def test_deprecate_message_only(reset):
|
2020-01-28 12:12:14 -05:00
|
|
|
deprecate('Deprecation message')
|
2020-06-10 00:21:19 +02:00
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'version': None, 'collection_name': None}]
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_deprecate_with_collection(reset):
|
2020-06-10 00:21:19 +02:00
|
|
|
deprecate(msg='Deprecation message', collection_name='ansible.builtin')
|
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'version': None, 'collection_name': 'ansible.builtin'}]
|
2020-01-28 12:12:14 -05:00
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_deprecate_with_version(reset):
|
2020-01-28 12:12:14 -05:00
|
|
|
deprecate(msg='Deprecation message', version='2.14')
|
2020-06-10 00:21:19 +02:00
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'version': '2.14', 'collection_name': None}]
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_deprecate_with_version_and_collection(reset):
|
2020-06-10 00:21:19 +02:00
|
|
|
deprecate(msg='Deprecation message', version='2.14', collection_name='ansible.builtin')
|
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'version': '2.14', 'collection_name': 'ansible.builtin'}]
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_deprecate_with_date(reset):
|
2020-06-10 00:21:19 +02:00
|
|
|
deprecate(msg='Deprecation message', date='2199-12-31')
|
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'date': '2199-12-31', 'collection_name': None}]
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_deprecate_with_date_and_collection(reset):
|
2020-06-10 00:21:19 +02:00
|
|
|
deprecate(msg='Deprecation message', date='2199-12-31', collection_name='ansible.builtin')
|
|
|
|
assert warnings._global_deprecations == [
|
|
|
|
{'msg': 'Deprecation message', 'date': '2199-12-31', 'collection_name': 'ansible.builtin'}]
|
2020-01-28 12:12:14 -05:00
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_multiple_deprecations(deprecation_messages, reset):
|
2020-01-28 12:12:14 -05:00
|
|
|
for d in deprecation_messages:
|
|
|
|
deprecate(**d)
|
|
|
|
|
|
|
|
assert deprecation_messages == warnings._global_deprecations
|
|
|
|
|
|
|
|
|
2021-04-16 11:42:29 -05:00
|
|
|
def test_get_deprecation_messages(deprecation_messages, reset):
|
2020-01-28 12:12:14 -05:00
|
|
|
for d in deprecation_messages:
|
|
|
|
deprecate(**d)
|
|
|
|
|
|
|
|
accessor_deprecations = get_deprecation_messages()
|
|
|
|
assert isinstance(accessor_deprecations, tuple)
|
2020-06-10 00:21:19 +02:00
|
|
|
assert len(accessor_deprecations) == 7
|
2020-01-28 12:12:14 -05:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
'test_case',
|
|
|
|
(
|
|
|
|
1,
|
|
|
|
True,
|
|
|
|
[1],
|
|
|
|
{'k1': 'v1'},
|
|
|
|
(1, 2),
|
|
|
|
6.62607004,
|
|
|
|
b'bytestr' if PY3 else None,
|
|
|
|
None,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
def test_deprecate_failure(test_case):
|
|
|
|
with pytest.raises(TypeError, match='deprecate requires a string not a %s' % type(test_case)):
|
|
|
|
deprecate(test_case)
|