ccdf1a61c4
* More generic comparison code from docker_container to docker_common.
* More flexibility if a is None and method is allow_to_present.
Note that this odes not affect docker_container, as there a is never None.
* Update docker_secret and docker_config: simplify labels comparison.
* Added unit tests.
* Use proper subsequence test for allow_more_present for lists.
Note that this does not affect existing code in docker_container, since lists
don't use allow_more_present. Using allow_more_present will only be possible
in Ansible 2.8.
* pep8
(cherry picked from commit 73533d3fc2
)
464 lines
8.5 KiB
Python
464 lines
8.5 KiB
Python
import pytest
|
|
|
|
from ansible.module_utils.docker_common import (
|
|
compare_dict_allow_more_present,
|
|
compare_generic,
|
|
)
|
|
|
|
DICT_ALLOW_MORE_PRESENT = (
|
|
{
|
|
'av': {},
|
|
'bv': {'a': 1},
|
|
'result': True
|
|
},
|
|
{
|
|
'av': {'a': 1},
|
|
'bv': {'a': 1, 'b': 2},
|
|
'result': True
|
|
},
|
|
{
|
|
'av': {'a': 1},
|
|
'bv': {'b': 2},
|
|
'result': False
|
|
},
|
|
{
|
|
'av': {'a': 1},
|
|
'bv': {'a': None, 'b': 1},
|
|
'result': False
|
|
},
|
|
{
|
|
'av': {'a': None},
|
|
'bv': {'b': 1},
|
|
'result': False
|
|
},
|
|
)
|
|
|
|
COMPARE_GENERIC = [
|
|
########################################################################################
|
|
# value
|
|
{
|
|
'a': 1,
|
|
'b': 2,
|
|
'method': 'strict',
|
|
'type': 'value',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': 'hello',
|
|
'b': 'hello',
|
|
'method': 'strict',
|
|
'type': 'value',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': None,
|
|
'b': 'hello',
|
|
'method': 'strict',
|
|
'type': 'value',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': None,
|
|
'b': None,
|
|
'method': 'strict',
|
|
'type': 'value',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': 1,
|
|
'b': 2,
|
|
'method': 'ignore',
|
|
'type': 'value',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': None,
|
|
'b': 2,
|
|
'method': 'ignore',
|
|
'type': 'value',
|
|
'result': True
|
|
},
|
|
########################################################################################
|
|
# list
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'y',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'list',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'x',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'list',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'list',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'y',
|
|
'x',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'list',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'list',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'list',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'list',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'z',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
'x',
|
|
'z',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'list',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'y',
|
|
'x',
|
|
],
|
|
'method': 'ignore',
|
|
'type': 'list',
|
|
'result': True
|
|
},
|
|
########################################################################################
|
|
# set
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'y',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'x',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'y',
|
|
'x',
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'x',
|
|
'y',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'z',
|
|
],
|
|
'b': [
|
|
'x',
|
|
'y',
|
|
'x',
|
|
'z',
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
'x',
|
|
'a',
|
|
],
|
|
'b': [
|
|
'y',
|
|
'z',
|
|
],
|
|
'method': 'ignore',
|
|
'type': 'set',
|
|
'result': True
|
|
},
|
|
########################################################################################
|
|
# set(dict)
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
],
|
|
'b': [
|
|
{'y': 1},
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set(dict)',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
],
|
|
'b': [
|
|
{'x': 1},
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
],
|
|
'b': [
|
|
{'x': 1, 'y': 2},
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
{'x': 2, 'y': 3},
|
|
],
|
|
'b': [
|
|
{'x': 1},
|
|
{'x': 2, 'y': 3},
|
|
],
|
|
'method': 'strict',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
],
|
|
'b': [
|
|
{'x': 1, 'z': 2},
|
|
{'x': 2, 'y': 3},
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1, 'y': 2},
|
|
],
|
|
'b': [
|
|
{'x': 1},
|
|
{'x': 2, 'y': 3},
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set(dict)',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1, 'y': 3},
|
|
],
|
|
'b': [
|
|
{'x': 1},
|
|
{'x': 1, 'y': 3, 'z': 4},
|
|
],
|
|
'method': 'allow_more_present',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': [
|
|
{'x': 1},
|
|
{'x': 2, 'y': 3},
|
|
],
|
|
'b': [
|
|
{'x': 1},
|
|
],
|
|
'method': 'ignore',
|
|
'type': 'set(dict)',
|
|
'result': True
|
|
},
|
|
########################################################################################
|
|
# dict
|
|
{
|
|
'a': {'x': 1},
|
|
'b': {'y': 1},
|
|
'method': 'strict',
|
|
'type': 'dict',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': {'x': 1},
|
|
'b': {'x': 1, 'y': 2},
|
|
'method': 'strict',
|
|
'type': 'dict',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': {'x': 1},
|
|
'b': {'x': 1},
|
|
'method': 'strict',
|
|
'type': 'dict',
|
|
'result': True
|
|
},
|
|
{
|
|
'a': {'x': 1, 'z': 2},
|
|
'b': {'x': 1, 'y': 2},
|
|
'method': 'strict',
|
|
'type': 'dict',
|
|
'result': False
|
|
},
|
|
{
|
|
'a': {'x': 1, 'z': 2},
|
|
'b': {'x': 1, 'y': 2},
|
|
'method': 'ignore',
|
|
'type': 'dict',
|
|
'result': True
|
|
},
|
|
] + [{
|
|
'a': entry['av'],
|
|
'b': entry['bv'],
|
|
'method': 'allow_more_present',
|
|
'type': 'dict',
|
|
'result': entry['result']
|
|
} for entry in DICT_ALLOW_MORE_PRESENT]
|
|
|
|
|
|
@pytest.mark.parametrize("entry", DICT_ALLOW_MORE_PRESENT)
|
|
def test_dict_allow_more_present(entry):
|
|
assert compare_dict_allow_more_present(entry['av'], entry['bv']) == entry['result']
|
|
|
|
|
|
@pytest.mark.parametrize("entry", COMPARE_GENERIC)
|
|
def test_compare_generic(entry):
|
|
assert compare_generic(entry['a'], entry['b'], entry['method'], entry['type']) == entry['result']
|