From 9231ec21af7a6b715e20dd83e28a8325aecc5f59 Mon Sep 17 00:00:00 2001 From: Matt Snider Date: Sat, 30 Mar 2019 18:34:29 +0100 Subject: [PATCH] Add tests for --map-project values --- tests/test_validation.py | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 tests/test_validation.py diff --git a/tests/test_validation.py b/tests/test_validation.py new file mode 100644 index 0000000..0af00b2 --- /dev/null +++ b/tests/test_validation.py @@ -0,0 +1,33 @@ +""" Validation Tests + +Test argument/option validations +""" +import click +import pytest +from todoist_taskwarrior import utils + + +def validate(fn, value): + """Calls the validation with None for `ctx` and `param`. + + Note: This could definitely be an issue for validations that + use either param, but at the moment it's a simplification + which works. + """ + return fn(None, None, value) + + +def test_validate_map_project(): + # Simple + assert validate(utils.validate_map_project, ('HELLO=WORLD',)) == {'HELLO': 'WORLD'} + + # Missing DST + assert validate(utils.validate_map_project, ('HELLO=',)) == {'HELLO': None} + + # Multiple + assert validate(utils.validate_map_project, ('FOO=BAR', 'BAR=BAZZ')) == {'FOO': 'BAR', 'BAR': 'BAZZ'} + + # Invalid, no '=' + with pytest.raises(click.BadParameter): + assert validate(utils.validate_map_project, ('FOO',)) == None +