diff options
| author | Rodolfo Carvalho <rhcarvalho@gmail.com> | 2017-03-17 10:34:57 +0100 | 
|---|---|---|
| committer | Rodolfo Carvalho <rhcarvalho@gmail.com> | 2017-03-17 10:34:57 +0100 | 
| commit | 8cfdd96ffa1c5b35455751aa8be5a5704d2550da (patch) | |
| tree | c742852afa7c703550cb26e11b0251f90807f6ca /roles | |
| parent | c73bb3aa5b2b28ddbdf48f9735b5afa1b8228cd6 (diff) | |
| download | openshift-8cfdd96ffa1c5b35455751aa8be5a5704d2550da.tar.gz openshift-8cfdd96ffa1c5b35455751aa8be5a5704d2550da.tar.bz2 openshift-8cfdd96ffa1c5b35455751aa8be5a5704d2550da.tar.xz openshift-8cfdd96ffa1c5b35455751aa8be5a5704d2550da.zip | |
Add unit tests for existing health checks
Diffstat (limited to 'roles')
3 files changed, 47 insertions, 1 deletions
| diff --git a/roles/openshift_health_checker/openshift_checks/__init__.py b/roles/openshift_health_checker/openshift_checks/__init__.py index 8433923ed..f66d19fbf 100644 --- a/roles/openshift_health_checker/openshift_checks/__init__.py +++ b/roles/openshift_health_checker/openshift_checks/__init__.py @@ -66,7 +66,8 @@ def get_var(task_vars, *keys, **kwargs):      Ansible task_vars structures are Python dicts, often mapping strings to      other dicts. This helper makes it easier to get a nested value, raising -    OpenShiftCheckException when a key is not found. +    OpenShiftCheckException when a key is not found or returning a default value +    provided as a keyword argument.      """      try:          value = reduce(operator.getitem, keys, task_vars) diff --git a/roles/openshift_health_checker/test/conftest.py b/roles/openshift_health_checker/test/conftest.py new file mode 100644 index 000000000..bf717ae85 --- /dev/null +++ b/roles/openshift_health_checker/test/conftest.py @@ -0,0 +1,5 @@ +import os +import sys + +# extend sys.path so that tests can import openshift_checks +sys.path.insert(1, os.path.dirname(os.path.dirname(__file__))) diff --git a/roles/openshift_health_checker/test/openshift_check_test.py b/roles/openshift_health_checker/test/openshift_check_test.py new file mode 100644 index 000000000..c4c8cd1c2 --- /dev/null +++ b/roles/openshift_health_checker/test/openshift_check_test.py @@ -0,0 +1,40 @@ +import pytest + +from openshift_checks import get_var, OpenShiftCheckException + + +# Fixtures + + +@pytest.fixture() +def task_vars(): +    return dict(foo=42, bar=dict(baz="openshift")) + + +@pytest.fixture(params=[ +    ("notfound",), +    ("multiple", "keys", "not", "in", "task_vars"), +]) +def missing_keys(request): +    return request.param + + +# Tests + + +@pytest.mark.parametrize("keys,expected", [ +    (("foo",), 42), +    (("bar", "baz"), "openshift"), +]) +def test_get_var_ok(task_vars, keys, expected): +    assert get_var(task_vars, *keys) == expected + + +def test_get_var_error(task_vars, missing_keys): +    with pytest.raises(OpenShiftCheckException): +        get_var(task_vars, *missing_keys) + + +def test_get_var_default(task_vars, missing_keys): +    default = object() +    assert get_var(task_vars, *missing_keys, default=default) == default | 
