forked from ansible/ansible
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add tests for module_utils.common.collections
- Loading branch information
Showing
2 changed files
with
67 additions
and
0 deletions.
There are no files selected for viewing
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# -*- coding: utf-8 -*- | ||
# Copyright (c), Sviatoslav Sydorenko <[email protected]> 2018 | ||
# Simplified BSD License (see licenses/simplified_bsd.txt or https://opensource.org/licenses/BSD-2-Clause) | ||
"""Test low-level utility functions from ``module_utils.common.collections``.""" | ||
|
||
from __future__ import absolute_import, division, print_function | ||
__metaclass__ = type | ||
|
||
import pytest | ||
|
||
from ansible.module_utils.common._collections_compat import Sequence | ||
from ansible.module_utils.common.collections import is_sequence | ||
|
||
|
||
class SeqStub: | ||
"""Stub emulating a sequence type. | ||
>>> from collections.abc import Sequence | ||
>>> assert issubclass(SeqStub, Sequence) | ||
>>> assert isinstance(SeqStub(), Sequence) | ||
""" | ||
|
||
|
||
Sequence.register(SeqStub) | ||
|
||
|
||
TEST_STRINGS = u'he', u'Україна', u'Česká republika' | ||
TEST_STRINGS = TEST_STRINGS + tuple(s.encode('utf-8') for s in TEST_STRINGS) | ||
|
||
TEST_ITEMS_NON_SEQUENCES = ( | ||
{}, object(), frozenset(), | ||
4, 0., | ||
) + TEST_STRINGS | ||
|
||
TEST_ITEMS_SEQUENCES = ( | ||
[], (), | ||
SeqStub(), | ||
) | ||
TEST_ITEMS_SEQUENCES = TEST_ITEMS_SEQUENCES + ( | ||
# Iterable effectively containing nested random data: | ||
TEST_ITEMS_NON_SEQUENCES, | ||
) | ||
|
||
|
||
@pytest.mark.parametrize('sequence_input', TEST_ITEMS_SEQUENCES) | ||
def test_sequence_positive(sequence_input): | ||
"""Test that non-string item sequences are identified correctly.""" | ||
assert is_sequence(sequence_input) | ||
assert is_sequence(sequence_input, include_strings=False) | ||
|
||
|
||
@pytest.mark.parametrize('non_sequence_input', TEST_ITEMS_NON_SEQUENCES) | ||
def test_sequence_negative(non_sequence_input): | ||
"""Test that non-sequences are identified correctly.""" | ||
assert not is_sequence(non_sequence_input) | ||
|
||
|
||
@pytest.mark.parametrize('string_input', TEST_STRINGS) | ||
def test_sequence_string_types_with_strings(string_input): | ||
"""Test that ``is_sequence`` can separate string and non-string.""" | ||
assert is_sequence(string_input, include_strings=True) | ||
|
||
|
||
@pytest.mark.parametrize('string_input', TEST_STRINGS) | ||
def test_sequence_string_types_without_strings(string_input): | ||
"""Test that ``is_sequence`` can separate string and non-string.""" | ||
assert not is_sequence(string_input, include_strings=False) |