From a42f409407b11deee2797fe666557882c6a68d10 Mon Sep 17 00:00:00 2001 From: pgajdos Date: Fri, 26 Jun 2020 11:16:12 +0200 Subject: [PATCH 1/3] switch to pytest --- README.md | 4 +- pytest.ini | 4 + setup.cfg | 4 - tox.ini | 12 +- voluptuous/tests/tests.py | 311 +++++++++++++++++--------------------- 5 files changed, 150 insertions(+), 185 deletions(-) create mode 100644 pytest.ini delete mode 100644 setup.cfg diff --git a/README.md b/README.md index e77856f..725c988 100644 --- a/README.md +++ b/README.md @@ -690,9 +690,9 @@ s({'password':'123', 'password_again': 1337}) ## Running tests. -Voluptuous is using nosetests: +Voluptuous is using pytest: - $ nosetests + $ pytest ## Why use Voluptuous over another validation library? diff --git a/pytest.ini b/pytest.ini new file mode 100644 index 0000000..0048dd0 --- /dev/null +++ b/pytest.ini @@ -0,0 +1,4 @@ +[pytest] +python_files = tests.py +testpaths = voluptuous/tests +addopts = --doctest-glob=*.md -v diff --git a/setup.cfg b/setup.cfg deleted file mode 100644 index adcebe2..0000000 --- a/setup.cfg +++ /dev/null @@ -1,4 +0,0 @@ -[nosetests] -doctest-extension = md -with-doctest = 1 -where = . diff --git a/tox.ini b/tox.ini index 7722ed8..552e268 100644 --- a/tox.ini +++ b/tox.ini @@ -10,15 +10,13 @@ exclude = .tox,.venv,build,*.egg distribute = True sitepackages = False deps = - nose - nose-cover3 + pytest + pytest-cov coverage>=3.0 commands = - nosetests \ - --with-coverage3 \ - --cover3-package=voluptuous \ - --cover3-branch \ - --verbose + pytest \ + --cov=voluptuous \ + voluptuous/tests/ [testenv:flake8] deps = flake8 diff --git a/voluptuous/tests/tests.py b/voluptuous/tests/tests.py index aaa260d..60efe1a 100644 --- a/voluptuous/tests/tests.py +++ b/voluptuous/tests/tests.py @@ -2,8 +2,7 @@ import collections import os import sys - -from nose.tools import assert_equal, assert_false, assert_raises, assert_true +import pytest from voluptuous import ( Schema, Required, Exclusive, Inclusive, Optional, Extra, Invalid, In, Remove, @@ -31,18 +30,16 @@ def test_exact_sequence(): assert True else: assert False, "Did not raise Invalid" - assert_equal(schema([1, 2]), [1, 2]) + assert schema([1, 2]) == [1, 2] def test_required(): """Verify that Required works.""" schema = Schema({Required('q'): 1}) - # Can't use nose's raises (because we need to access the raised - # exception, nor assert_raises which fails with Python 2.6.9. try: schema({}) except Invalid as e: - assert_equal(str(e), "required key not provided @ data['q']") + assert str(e) == "required key not provided @ data['q']" else: assert False, "Did not raise Invalid" @@ -51,8 +48,7 @@ def test_extra_with_required(): """Verify that Required does not break Extra.""" schema = Schema({Required('toaster'): str, Extra: object}) r = schema({'toaster': 'blue', 'another_valid_key': 'another_valid_value'}) - assert_equal( - r, {'toaster': 'blue', 'another_valid_key': 'another_valid_value'}) + assert r == {'toaster': 'blue', 'another_valid_key': 'another_valid_value'} def test_iterate_candidates(): @@ -63,7 +59,7 @@ def test_iterate_candidates(): } # toaster should be first. from voluptuous.schema_builder import _iterate_mapping_candidates - assert_equal(_iterate_mapping_candidates(schema)[0][0], 'toaster') + assert _iterate_mapping_candidates(schema)[0][0] == 'toaster' def test_in(): @@ -79,7 +75,7 @@ def test_not_in(): try: schema({"color": "blue"}) except Invalid as e: - assert_equal(str(e), "value is not allowed for dictionary value @ data['color']") + assert str(e) == "value is not allowed for dictionary value @ data['color']" else: assert False, "Did not raise NotInInvalid" @@ -91,8 +87,7 @@ def test_contains(): try: schema({'color': ['blue', 'yellow']}) except Invalid as e: - assert_equal(str(e), - "value is not allowed for dictionary value @ data['color']") + assert str(e) == "value is not allowed for dictionary value @ data['color']" def test_remove(): @@ -124,12 +119,12 @@ def test_remove(): # remove value from list schema = Schema([Remove(1), int]) out_ = schema([1, 2, 3, 4, 1, 5, 6, 1, 1, 1]) - assert_equal(out_, [2, 3, 4, 5, 6]) + assert out_ == [2, 3, 4, 5, 6] # remove values from list by type schema = Schema([1.0, Remove(float), int]) out_ = schema([1, 2, 1.0, 2.0, 3.0, 4]) - assert_equal(out_, [1, 2, 1.0, 4]) + assert out_ == [1, 2, 1.0, 4] def test_extra_empty_errors(): @@ -148,7 +143,7 @@ def test_literal(): try: schema([{"c": 1}]) except Invalid as e: - assert_equal(str(e), "{'c': 1} not match for {'b': 1} @ data[0]") + assert str(e) == "{'c': 1} not match for {'b': 1} @ data[0]" else: assert False, "Did not raise Invalid" @@ -156,9 +151,9 @@ def test_literal(): try: schema({"b": 1}) except MultipleInvalid as e: - assert_equal(str(e), "{'b': 1} not match for {'a': 1}") - assert_equal(len(e.errors), 1) - assert_equal(type(e.errors[0]), LiteralInvalid) + assert str(e) == "{'b': 1} not match for {'a': 1}" + assert len(e.errors) == 1 + assert type(e.errors[0]) == LiteralInvalid else: assert False, "Did not raise Invalid" @@ -173,9 +168,9 @@ class C1(object): try: schema(None) except MultipleInvalid as e: - assert_equal(str(e), "expected C1") - assert_equal(len(e.errors), 1) - assert_equal(type(e.errors[0]), TypeInvalid) + assert str(e) == "expected C1" + assert len(e.errors) == 1 + assert type(e.errors[0]) == TypeInvalid else: assert False, "Did not raise Invalid" @@ -189,9 +184,9 @@ class C2: try: schema(None) except MultipleInvalid as e: - assert_equal(str(e), "expected C2") - assert_equal(len(e.errors), 1) - assert_equal(type(e.errors[0]), TypeInvalid) + assert str(e) == "expected C2" + assert len(e.errors) == 1 + assert type(e.errors[0]) == TypeInvalid else: assert False, "Did not raise Invalid" @@ -210,8 +205,7 @@ def test_email_validation_with_none(): try: schema({"email": None}) except MultipleInvalid as e: - assert_equal(str(e), - "expected an Email for dictionary value @ data['email']") + assert str(e) == "expected an Email for dictionary value @ data['email']" else: assert False, "Did not raise Invalid for None url" @@ -222,8 +216,7 @@ def test_email_validation_with_empty_string(): try: schema({"email": ''}) except MultipleInvalid as e: - assert_equal(str(e), - "expected an Email for dictionary value @ data['email']") + assert str(e) == "expected an Email for dictionary value @ data['email']" else: assert False, "Did not raise Invalid for empty string url" @@ -234,8 +227,7 @@ def test_email_validation_without_host(): try: schema({"email": 'a@.com'}) except MultipleInvalid as e: - assert_equal(str(e), - "expected an Email for dictionary value @ data['email']") + assert str(e) == "expected an Email for dictionary value @ data['email']" else: assert False, "Did not raise Invalid for empty string url" @@ -254,8 +246,7 @@ def test_fqdn_url_without_domain_name(): try: schema({"url": "http://localhost/"}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a Fully qualified domain name URL for dictionary value @ data['url']") + assert str(e) == "expected a Fully qualified domain name URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for None url" @@ -266,8 +257,7 @@ def test_fqdnurl_validation_with_none(): try: schema({"url": None}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a Fully qualified domain name URL for dictionary value @ data['url']") + assert str(e) == "expected a Fully qualified domain name URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for None url" @@ -278,8 +268,7 @@ def test_fqdnurl_validation_with_empty_string(): try: schema({"url": ''}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a Fully qualified domain name URL for dictionary value @ data['url']") + assert str(e) == "expected a Fully qualified domain name URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for empty string url" @@ -290,8 +279,7 @@ def test_fqdnurl_validation_without_host(): try: schema({"url": 'http://'}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a Fully qualified domain name URL for dictionary value @ data['url']") + assert str(e) == "expected a Fully qualified domain name URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for empty string url" @@ -310,8 +298,7 @@ def test_url_validation_with_none(): try: schema({"url": None}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a URL for dictionary value @ data['url']") + assert str(e) == "expected a URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for None url" @@ -322,8 +309,7 @@ def test_url_validation_with_empty_string(): try: schema({"url": ''}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a URL for dictionary value @ data['url']") + assert str(e) == "expected a URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for empty string url" @@ -334,8 +320,7 @@ def test_url_validation_without_host(): try: schema({"url": 'http://'}) except MultipleInvalid as e: - assert_equal(str(e), - "expected a URL for dictionary value @ data['url']") + assert str(e) == "expected a URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for empty string url" @@ -401,10 +386,10 @@ def test_schema_extend_key_swap(): extension = {Required('a'): int} extended = base.extend(extension) - assert_equal(len(base.schema), 1) - assert_true(isinstance(list(base.schema)[0], Optional)) - assert_equal(len(extended.schema), 1) - assert_true((list(extended.schema)[0], Required)) + assert len(base.schema) == 1 + assert isinstance(list(base.schema)[0], Optional) + assert len(extended.schema) == 1 + assert (list(extended.schema)[0], Required) def test_subschema_extension(): @@ -414,9 +399,9 @@ def test_subschema_extension(): extension = {'d': str, 'a': {'b': str, 'e': int}} extended = base.extend(extension) - assert_equal(base.schema, {'a': {'b': int, 'c': float}}) - assert_equal(extension, {'d': str, 'a': {'b': str, 'e': int}}) - assert_equal(extended.schema, {'a': {'b': str, 'c': float, 'e': int}, 'd': str}) + assert base.schema == {'a': {'b': int, 'c': float}} + assert extension == {'d': str, 'a': {'b': str, 'e': int}} + assert extended.schema == {'a': {'b': str, 'c': float, 'e': int}, 'd': str} def test_schema_extend_handles_schema_subclass(): @@ -434,10 +419,9 @@ class S(Schema): def test_equality(): - assert_equal(Schema('foo'), Schema('foo')) + assert Schema('foo') == Schema('foo') - assert_equal(Schema(['foo', 'bar', 'baz']), - Schema(['foo', 'bar', 'baz'])) + assert Schema(['foo', 'bar', 'baz']) == Schema(['foo', 'bar', 'baz']) # Ensure two Schemas w/ two equivalent dicts initialized in a different # order are considered equal. @@ -451,35 +435,34 @@ def test_equality(): dict_b['bar'] = 2 dict_b['foo'] = 1 - assert_equal(Schema(dict_a), Schema(dict_b)) + assert Schema(dict_a) == Schema(dict_b) def test_equality_negative(): """Verify that Schema objects are not equal to string representations""" - assert_false(Schema('foo') == 'foo') + assert not Schema('foo') == 'foo' - assert_false(Schema(['foo', 'bar']) == "['foo', 'bar']") - assert_false(Schema(['foo', 'bar']) == Schema("['foo', 'bar']")) + assert not Schema(['foo', 'bar']) == "['foo', 'bar']" + assert not Schema(['foo', 'bar']) == Schema("['foo', 'bar']") - assert_false(Schema({'foo': 1, 'bar': 2}) == "{'foo': 1, 'bar': 2}") - assert_false(Schema({'foo': 1, 'bar': 2}) == Schema("{'foo': 1, 'bar': 2}")) + assert not Schema({'foo': 1, 'bar': 2}) == "{'foo': 1, 'bar': 2}" + assert not Schema({'foo': 1, 'bar': 2}) == Schema("{'foo': 1, 'bar': 2}") def test_inequality(): - assert_true(Schema('foo') != 'foo') + assert Schema('foo') != 'foo' - assert_true(Schema(['foo', 'bar']) != "['foo', 'bar']") - assert_true(Schema(['foo', 'bar']) != Schema("['foo', 'bar']")) + assert Schema(['foo', 'bar']) != "['foo', 'bar']" + assert Schema(['foo', 'bar']) != Schema("['foo', 'bar']") - assert_true(Schema({'foo': 1, 'bar': 2}) != "{'foo': 1, 'bar': 2}") - assert_true(Schema({'foo': 1, 'bar': 2}) != Schema("{'foo': 1, 'bar': 2}")) + assert Schema({'foo': 1, 'bar': 2}) != "{'foo': 1, 'bar': 2}" + assert Schema({'foo': 1, 'bar': 2}) != Schema("{'foo': 1, 'bar': 2}") def test_inequality_negative(): - assert_false(Schema('foo') != Schema('foo')) + assert not Schema('foo') != Schema('foo') - assert_false(Schema(['foo', 'bar', 'baz']) != - Schema(['foo', 'bar', 'baz'])) + assert not Schema(['foo', 'bar', 'baz']) != Schema(['foo', 'bar', 'baz']) # Ensure two Schemas w/ two equivalent dicts initialized in a different # order are considered equal. @@ -493,7 +476,7 @@ def test_inequality_negative(): dict_b['bar'] = 2 dict_b['foo'] = 1 - assert_false(Schema(dict_a) != Schema(dict_b)) + assert not Schema(dict_a) != Schema(dict_b) def test_repr(): @@ -506,15 +489,12 @@ def test_repr(): all_ = All('10', Coerce(int), msg='all msg') maybe_int = Maybe(int) - assert_equal(repr(match), "Match('a pattern', msg='message')") - assert_equal(repr(replace), "Replace('you', 'I', msg='you and I')") - assert_equal( - repr(range_), - "Range(min=0, max=42, min_included=False, max_included=False, msg='number not in range')" - ) - assert_equal(repr(coerce_), "Coerce(int, msg='moo')") - assert_equal(repr(all_), "All('10', Coerce(int, msg=None), msg='all msg')") - assert_equal(repr(maybe_int), "Any(None, %s, msg=None)" % str(int)) + assert repr(match) == "Match('a pattern', msg='message')" + assert repr(replace) == "Replace('you', 'I', msg='you and I')" + assert repr(range_) == "Range(min=0, max=42, min_included=False, max_included=False, msg='number not in range')" + assert repr(coerce_) == "Coerce(int, msg='moo')" + assert repr(all_) == "All('10', Coerce(int, msg=None), msg='all msg')" + assert repr(maybe_int) == "Any(None, %s, msg=None)" % str(int) def test_list_validation_messages(): @@ -530,9 +510,9 @@ def is_even(value): try: schema(dict(even_numbers=[3])) except Invalid as e: - assert_equal(len(e.errors), 1, e.errors) - assert_equal(str(e.errors[0]), "3 is not even @ data['even_numbers'][0]") - assert_equal(str(e), "3 is not even @ data['even_numbers'][0]") + assert len(e.errors) == 1 + assert str(e.errors[0]) == "3 is not even @ data['even_numbers'][0]" + assert str(e) == "3 is not even @ data['even_numbers'][0]" else: assert False, "Did not raise Invalid" @@ -551,9 +531,9 @@ def is_even(value): try: schema(dict(even_numbers=[3])) except Invalid as e: - assert_equal(len(e.errors), 1, e.errors) - assert_equal(str(e.errors[0]), "3 is not even @ data['even_numbers'][0]") - assert_equal(str(e), "3 is not even @ data['even_numbers'][0]") + assert len(e.errors) == 1 + assert str(e.errors[0]) == "3 is not even @ data['even_numbers'][0]" + assert str(e) == "3 is not even @ data['even_numbers'][0]" else: assert False, "Did not raise Invalid" @@ -570,24 +550,20 @@ def test_humanize_error(): try: schema(data) except MultipleInvalid as e: - assert_equal( - humanize_error(data, e), - "expected int for dictionary value @ data['a']. Got 'not an int'\n" - "expected str @ data['b'][0]. Got 123" - ) + assert humanize_error(data, e) == "expected int for dictionary value @ data['a']. Got 'not an int'\nexpected str @ data['b'][0]. Got 123" else: assert False, 'Did not raise MultipleInvalid' def test_fix_157(): s = Schema(All([Any('one', 'two', 'three')]), Length(min=1)) - assert_equal(['one'], s(['one'])) - assert_raises(MultipleInvalid, s, ['four']) + assert ['one'] == s(['one']) + pytest.raises(MultipleInvalid, s, ['four']) def test_range_exlcudes_nan(): s = Schema(Range(min=0, max=10)) - assert_raises(MultipleInvalid, s, float('nan')) + pytest.raises(MultipleInvalid, s, float('nan')) def test_range_excludes_none(): @@ -606,17 +582,17 @@ class MyObject(object): def test_equal(): s = Schema(Equal(1)) s(1) - assert_raises(Invalid, s, 2) + pytest.raises(Invalid, s, 2) s = Schema(Equal('foo')) s('foo') - assert_raises(Invalid, s, 'bar') + pytest.raises(Invalid, s, 'bar') s = Schema(Equal([1, 2])) s([1, 2]) - assert_raises(Invalid, s, []) - assert_raises(Invalid, s, [1, 2, 3]) + pytest.raises(Invalid, s, []) + pytest.raises(Invalid, s, [1, 2, 3]) # Evaluates exactly, not through validators s = Schema(Equal(str)) - assert_raises(Invalid, s, 'foo') + pytest.raises(Invalid, s, 'foo') def test_unordered(): @@ -625,15 +601,15 @@ def test_unordered(): s([2, 1]) s([1, 2]) # Amount of errors is OK - assert_raises(Invalid, s, [2, 0]) - assert_raises(MultipleInvalid, s, [0, 0]) + pytest.raises(Invalid, s, [2, 0]) + pytest.raises(MultipleInvalid, s, [0, 0]) # Different length is NOK - assert_raises(Invalid, s, [1]) - assert_raises(Invalid, s, [1, 2, 0]) - assert_raises(MultipleInvalid, s, [1, 2, 0, 0]) + pytest.raises(Invalid, s, [1]) + pytest.raises(Invalid, s, [1, 2, 0]) + pytest.raises(MultipleInvalid, s, [1, 2, 0, 0]) # Other type than list or tuple is NOK - assert_raises(Invalid, s, 'foo') - assert_raises(Invalid, s, 10) + pytest.raises(Invalid, s, 'foo') + pytest.raises(Invalid, s, 10) # Validators are evaluated through as schemas s = Schema(Unordered([int, str])) s([1, '2']) @@ -642,7 +618,7 @@ def test_unordered(): s([{'foo': 3}, []]) # Most accurate validators must be positioned on left s = Schema(Unordered([int, 3])) - assert_raises(Invalid, s, [3, 2]) + pytest.raises(Invalid, s, [3, 2]) s = Schema(Unordered([3, int])) s([3, 2]) @@ -651,12 +627,12 @@ def test_maybe(): s = Schema(Maybe(int)) assert s(1) == 1 assert s(None) is None - assert_raises(Invalid, s, 'foo') + pytest.raises(Invalid, s, 'foo') s = Schema(Maybe({str: Coerce(int)})) assert s({'foo': '100'}) == {'foo': 100} assert s(None) is None - assert_raises(Invalid, s, {'foo': 'bar'}) + pytest.raises(Invalid, s, {'foo': 'bar'}) def test_maybe_accepts_msg(): @@ -667,7 +643,7 @@ def test_maybe_accepts_msg(): def test_empty_list_as_exact(): s = Schema([]) - assert_raises(Invalid, s, [1]) + pytest.raises(Invalid, s, [1]) s([]) @@ -684,7 +660,7 @@ def test_schema_decorator_unmatch_with_args(): def fn(arg): return arg - assert_raises(Invalid, fn, 1.0) + pytest.raises(Invalid, fn, 1.0) def test_schema_decorator_match_with_kwargs(): @@ -700,7 +676,7 @@ def test_schema_decorator_unmatch_with_kwargs(): def fn(arg): return arg - assert_raises(Invalid, fn, 1.0) + pytest.raises(Invalid, fn, 1.0) def test_schema_decorator_match_return_with_args(): @@ -716,7 +692,7 @@ def test_schema_decorator_unmatch_return_with_args(): def fn(arg): return "hello" - assert_raises(Invalid, fn, 1) + pytest.raises(Invalid, fn, 1) def test_schema_decorator_match_return_with_kwargs(): @@ -732,7 +708,7 @@ def test_schema_decorator_unmatch_return_with_kwargs(): def fn(arg): return "hello" - assert_raises(Invalid, fn, 1) + pytest.raises(Invalid, fn, 1) def test_schema_decorator_return_only_match(): @@ -748,7 +724,7 @@ def test_schema_decorator_return_only_unmatch(): def fn(arg): return "hello" - assert_raises(Invalid, fn, 1) + pytest.raises(Invalid, fn, 1) def test_schema_decorator_partial_match_called_with_args(): @@ -764,7 +740,7 @@ def test_schema_decorator_partial_unmatch_called_with_args(): def fn(arg1, arg2): return arg1 - assert_raises(Invalid, fn, "bar", "foo") + pytest.raises(Invalid, fn, "bar", "foo") def test_schema_decorator_partial_match_called_with_kwargs(): @@ -780,7 +756,7 @@ def test_schema_decorator_partial_unmatch_called_with_kwargs(): def fn(arg1, arg2): return arg1 - assert_raises(Invalid, fn, arg1=1, arg2="foo") + pytest.raises(Invalid, fn, arg1=1, arg2="foo") def test_unicode_as_key(): @@ -798,8 +774,7 @@ def test_number_validation_with_string(): try: schema({"number": 'teststr'}) except MultipleInvalid as e: - assert_equal(str(e), - "Value must be a number enclosed with string for dictionary value @ data['number']") + assert str(e) == "Value must be a number enclosed with string for dictionary value @ data['number']" else: assert False, "Did not raise Invalid for String" @@ -810,8 +785,7 @@ def test_number_validation_with_invalid_precision_invalid_scale(): try: schema({"number": '123456.712'}) except MultipleInvalid as e: - assert_equal(str(e), - "Precision must be equal to 6, and Scale must be equal to 2 for dictionary value @ data['number']") + assert str(e) == "Precision must be equal to 6, and Scale must be equal to 2 for dictionary value @ data['number']" else: assert False, "Did not raise Invalid for String" @@ -820,28 +794,28 @@ def test_number_validation_with_valid_precision_scale_yield_decimal_true(): """ test with Number with valid precision and scale""" schema = Schema({"number": Number(precision=6, scale=2, yield_decimal=True)}) out_ = schema({"number": '1234.00'}) - assert_equal(float(out_.get("number")), 1234.00) + assert float(out_.get("number")) == 1234.00 def test_number_when_precision_scale_none_yield_decimal_true(): """ test with Number with no precision and scale""" schema = Schema({"number": Number(yield_decimal=True)}) out_ = schema({"number": '12345678901234'}) - assert_equal(out_.get("number"), 12345678901234) + assert out_.get("number") == 12345678901234 def test_number_when_precision_none_n_valid_scale_case1_yield_decimal_true(): """ test with Number with no precision and valid scale case 1""" schema = Schema({"number": Number(scale=2, yield_decimal=True)}) out_ = schema({"number": '123456789.34'}) - assert_equal(float(out_.get("number")), 123456789.34) + assert float(out_.get("number")) == 123456789.34 def test_number_when_precision_none_n_valid_scale_case2_yield_decimal_true(): """ test with Number with no precision and valid scale case 2 with zero in decimal part""" schema = Schema({"number": Number(scale=2, yield_decimal=True)}) out_ = schema({"number": '123456789012.00'}) - assert_equal(float(out_.get("number")), 123456789012.00) + assert float(out_.get("number")) == 123456789012.00 def test_number_when_precision_none_n_invalid_scale_yield_decimal_true(): @@ -850,8 +824,7 @@ def test_number_when_precision_none_n_invalid_scale_yield_decimal_true(): try: schema({"number": '12345678901.234'}) except MultipleInvalid as e: - assert_equal(str(e), - "Scale must be equal to 2 for dictionary value @ data['number']") + assert str(e) == "Scale must be equal to 2 for dictionary value @ data['number']" else: assert False, "Did not raise Invalid for String" @@ -860,7 +833,7 @@ def test_number_when_valid_precision_n_scale_none_yield_decimal_true(): """ test with Number with no precision and valid scale""" schema = Schema({"number": Number(precision=14, yield_decimal=True)}) out_ = schema({"number": '1234567.8901234'}) - assert_equal(float(out_.get("number")), 1234567.8901234) + assert float(out_.get("number")) == 1234567.8901234 def test_number_when_invalid_precision_n_scale_none_yield_decimal_true(): @@ -869,8 +842,7 @@ def test_number_when_invalid_precision_n_scale_none_yield_decimal_true(): try: schema({"number": '12345674.8901234'}) except MultipleInvalid as e: - assert_equal(str(e), - "Precision must be equal to 14 for dictionary value @ data['number']") + assert str(e) == "Precision must be equal to 14 for dictionary value @ data['number']" else: assert False, "Did not raise Invalid for String" @@ -879,7 +851,7 @@ def test_number_validation_with_valid_precision_scale_yield_decimal_false(): """ test with Number with valid precision, scale and no yield_decimal""" schema = Schema({"number": Number(precision=6, scale=2, yield_decimal=False)}) out_ = schema({"number": '1234.00'}) - assert_equal(out_.get("number"), '1234.00') + assert out_.get("number") == '1234.00' def test_named_tuples_validate_as_tuples(): @@ -896,19 +868,19 @@ def test_named_tuples_validate_as_tuples(): def test_datetime(): schema = Schema({"datetime": Datetime()}) schema({"datetime": "2016-10-24T14:01:57.102152Z"}) - assert_raises(MultipleInvalid, schema, {"datetime": "2016-10-24T14:01:57"}) + pytest.raises(MultipleInvalid, schema, {"datetime": "2016-10-24T14:01:57"}) def test_date(): schema = Schema({"date": Date()}) schema({"date": "2016-10-24"}) - assert_raises(MultipleInvalid, schema, {"date": "2016-10-24Z"}) + pytest.raises(MultipleInvalid, schema, {"date": "2016-10-24Z"}) def test_date_custom_format(): schema = Schema({"date": Date("%Y%m%d")}) schema({"date": "20161024"}) - assert_raises(MultipleInvalid, schema, {"date": "2016-10-24"}) + pytest.raises(MultipleInvalid, schema, {"date": "2016-10-24"}) def test_ordered_dict(): @@ -930,12 +902,12 @@ def test_marker_hashable(): Required('x'): int, Optional('y'): float, Remove('j'): int, Remove(int): str, int: int } - assert_equal(definition.get('x'), int) - assert_equal(definition.get('y'), float) - assert_true(Required('x') == Required('x')) - assert_true(Required('x') != Required('y')) + assert definition.get('x') == int + assert definition.get('y') == float + assert Required('x') == Required('x') + assert Required('x') != Required('y') # Remove markers are not hashable - assert_equal(definition.get('j'), None) + assert definition.get('j') == None def test_schema_infer(): @@ -945,12 +917,12 @@ def test_schema_infer(): 'int': 42, 'float': 3.14 }) - assert_equal(schema, Schema({ + assert schema == Schema({ Required('str'): str, Required('bool'): bool, Required('int'): int, Required('float'): float - })) + }) def test_schema_infer_dict(): @@ -962,13 +934,13 @@ def test_schema_infer_dict(): } }) - assert_equal(schema, Schema({ + assert schema == Schema({ Required('a'): { Required('b'): { Required('c'): str } } - })) + }) def test_schema_infer_list(): @@ -976,18 +948,18 @@ def test_schema_infer_list(): 'list': ['foo', True, 42, 3.14] }) - assert_equal(schema, Schema({ + assert schema == Schema({ Required('list'): [str, bool, int, float] - })) + }) def test_schema_infer_scalar(): - assert_equal(Schema.infer('foo'), Schema(str)) - assert_equal(Schema.infer(True), Schema(bool)) - assert_equal(Schema.infer(42), Schema(int)) - assert_equal(Schema.infer(3.14), Schema(float)) - assert_equal(Schema.infer({}), Schema(dict)) - assert_equal(Schema.infer([]), Schema(list)) + assert Schema.infer('foo') == Schema(str) + assert Schema.infer(True) == Schema(bool) + assert Schema.infer(42) == Schema(int) + assert Schema.infer(3.14) == Schema(float) + assert Schema.infer({}) == Schema(dict) + assert Schema.infer([]) == Schema(list) def test_schema_infer_accepts_kwargs(): @@ -1050,19 +1022,19 @@ def __call__(self, *args, **kwargs): def test_IsDir(): schema = Schema(IsDir()) - assert_raises(MultipleInvalid, schema, 3) + pytest.raises(MultipleInvalid, schema, 3) schema(os.path.dirname(os.path.abspath(__file__))) def test_IsFile(): schema = Schema(IsFile()) - assert_raises(MultipleInvalid, schema, 3) + pytest.raises(MultipleInvalid, schema, 3) schema(os.path.abspath(__file__)) def test_PathExists(): schema = Schema(PathExists()) - assert_raises(MultipleInvalid, schema, 3) + pytest.raises(MultipleInvalid, schema, 3) schema(os.path.abspath(__file__)) @@ -1236,7 +1208,7 @@ def test_SomeOf_on_bounds_assertion(): def test_comparing_voluptuous_object_to_str(): - assert_true(Optional('Classification') < 'Name') + assert Optional('Classification') < 'Name' def test_set_of_integers(): @@ -1252,7 +1224,7 @@ def test_set_of_integers(): try: schema(set(['abc'])) except MultipleInvalid as e: - assert_equal(str(e), "invalid value in set") + assert str(e) == "invalid value in set" else: assert False, "Did not raise Invalid" @@ -1270,7 +1242,7 @@ def test_frozenset_of_integers(): try: schema(frozenset(['abc'])) except MultipleInvalid as e: - assert_equal(str(e), "invalid value in frozenset") + assert str(e) == "invalid value in frozenset" else: assert False, "Did not raise Invalid" @@ -1287,7 +1259,7 @@ def test_set_of_integers_and_strings(): try: schema(set([None])) except MultipleInvalid as e: - assert_equal(str(e), "invalid value in set") + assert str(e) == "invalid value in set" else: assert False, "Did not raise Invalid" @@ -1304,7 +1276,7 @@ def test_frozenset_of_integers_and_strings(): try: schema(frozenset([None])) except MultipleInvalid as e: - assert_equal(str(e), "invalid value in frozenset") + assert str(e) == "invalid value in frozenset" else: assert False, "Did not raise Invalid" @@ -1350,8 +1322,7 @@ def test_any_required(): try: schema({}) except MultipleInvalid as e: - assert_equal(str(e), - "required key not provided @ data['a']") + assert str(e) == "required key not provided @ data['a']" else: assert False, "Did not raise Invalid for MultipleInvalid" @@ -1365,8 +1336,7 @@ def test_any_required_with_subschema(): try: schema({}) except MultipleInvalid as e: - assert_equal(str(e), - "required key not provided @ data['a']") + assert str(e) == "required key not provided @ data['a']" else: assert False, "Did not raise Invalid for MultipleInvalid" @@ -1377,16 +1347,15 @@ def test_inclusive(): }) r = schema({}) - assert_equal(r, {}) + assert r == {} r = schema({'x':1, 'y':2}) - assert_equal(r, {'x':1, 'y':2}) + assert r == {'x':1, 'y':2} try: r = schema({'x':1}) except MultipleInvalid as e: - assert_equal(str(e), - "some but not all values in the same group of inclusion 'stuff' @ data[]") + assert str(e) == "some but not all values in the same group of inclusion 'stuff' @ data[]" else: assert False, "Did not raise Invalid for incomplete Inclusive group" @@ -1397,13 +1366,12 @@ def test_inclusive_defaults(): }) r = schema({}) - assert_equal(r, {'x':3, 'y':4}) + assert r == {'x':3, 'y':4} try: r = schema({'x':1}) except MultipleInvalid as e: - assert_equal(str(e), - "some but not all values in the same group of inclusion 'stuff' @ data[]") + assert str(e) == "some but not all values in the same group of inclusion 'stuff' @ data[]" else: assert False, "Did not raise Invalid for incomplete Inclusive group with defaults" @@ -1414,16 +1382,15 @@ def test_exclusive(): }) r = schema({}) - assert_equal(r, {}) + assert r == {} r = schema({'x':1}) - assert_equal(r, {'x':1}) + assert r == {'x':1} try: r = schema({'x':1, 'y': 2}) except MultipleInvalid as e: - assert_equal(str(e), - "two or more values in the same group of exclusion 'stuff' @ data[]") + assert str(e) == "two or more values in the same group of exclusion 'stuff' @ data[]" else: assert False, "Did not raise Invalid for multiple values in Exclusive group" From 746e5308ced5e418a3b4580623758dd6d3946a6d Mon Sep 17 00:00:00 2001 From: pgajdos Date: Fri, 26 Jun 2020 11:33:04 +0200 Subject: [PATCH 2/3] more pytest transitions --- voluptuous/tests/tests.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/voluptuous/tests/tests.py b/voluptuous/tests/tests.py index 60efe1a..8c5e7eb 100644 --- a/voluptuous/tests/tests.py +++ b/voluptuous/tests/tests.py @@ -19,7 +19,7 @@ def test_new_required_test(): schema = Schema({ 'my_key': All(int, Range(1, 20)), }, required=True) - assert_true(schema.required) + assert schema.required def test_exact_sequence(): @@ -568,7 +568,7 @@ def test_range_exlcudes_nan(): def test_range_excludes_none(): s = Schema(Range(min=0, max=10)) - assert_raises(MultipleInvalid, s, None) + pytest.raises(MultipleInvalid, s, None) def test_range_excludes_unordered_object(): @@ -576,7 +576,7 @@ class MyObject(object): pass s = Schema(Range(min=0, max=10)) - assert_raises(MultipleInvalid, s, MyObject()) + pytest.raises(MultipleInvalid, s, MyObject()) def test_equal(): @@ -1414,6 +1414,6 @@ def test_any_with_discriminant(): 'c-value': None,} }) except MultipleInvalid as e: - assert_equal(str(e),'expected bool for dictionary value @ data[\'implementation\'][\'c-value\']') + assert str(e) == 'expected bool for dictionary value @ data[\'implementation\'][\'c-value\']' else: assert False, "Did not raise correct Invalid" From 91e7f9c97b4541af022ea255154ec9a703044338 Mon Sep 17 00:00:00 2001 From: Philip Allgaier Date: Sun, 3 Apr 2022 11:46:54 +0200 Subject: [PATCH 3/3] Convert remaining tests to pytest --- .github/workflows/tests.yml | 13 +++--- tox.ini | 2 +- voluptuous/tests/tests.py | 88 +++++++++++++++++++++---------------- 3 files changed, 57 insertions(+), 46 deletions(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 118b77a..9b9413f 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -14,12 +14,13 @@ jobs: fail-fast: false matrix: include: - - { python-version: "3.9", session: "flake8" } - - { python-version: "3.9", session: "py39" } - - { python-version: "3.8", session: "py38" } - - { python-version: "3.7", session: "py37" } - - { python-version: "3.6", session: "py36" } - - { python-version: "2.7", session: "py27" } + - { python-version: "3.10", session: "flake8" } + - { python-version: "3.10", session: "py310" } + - { python-version: "3.9", session: "py39" } + - { python-version: "3.8", session: "py38" } + - { python-version: "3.7", session: "py37" } + - { python-version: "3.6", session: "py36" } + - { python-version: "2.7", session: "py27" } steps: - name: Check out the repository diff --git a/tox.ini b/tox.ini index 4cbe2a1..683c5b7 100644 --- a/tox.ini +++ b/tox.ini @@ -1,5 +1,5 @@ [tox] -envlist = flake8,py27,py36,py37,py38,py39 +envlist = flake8,py27,py36,py37,py38,py39,py310 [flake8] ; E501: line too long (X > 79 characters) diff --git a/voluptuous/tests/tests.py b/voluptuous/tests/tests.py index d92b3e9..c792f07 100644 --- a/voluptuous/tests/tests.py +++ b/voluptuous/tests/tests.py @@ -250,8 +250,7 @@ def test_email_validation_with_bad_data(): try: schema({"email": 'john@voluptuous.com>'}) except MultipleInvalid as e: - assert_equal(str(e), - "expected an email address for dictionary value @ data['email']") + assert str(e) == "expected an email address for dictionary value @ data['email']" else: assert False, "Did not raise Invalid for bad email " + email @@ -344,7 +343,7 @@ def test_url_validation_without_host(): try: schema({"url": 'http://'}) except MultipleInvalid as e: - assert str(e) == "expected a URL for dictionary value @ data['url']" + assert str(e) == "expected a URL for dictionary value @ data['url']" else: assert False, "Did not raise Invalid for empty string URL" @@ -411,7 +410,7 @@ def test_schema_extend_key_swap(): assert len(base.schema) == 1 assert isinstance(list(base.schema)[0], Optional) assert len(extended.schema) == 1 - assert (list(extended.schema)[0], Required) + assert list(extended.schema)[0] def test_subschema_extension(): @@ -584,25 +583,29 @@ def test_fix_157(): def test_range_inside(): s = Schema(Range(min=0, max=10)) - assert_equal(5, s(5)) + assert 5 == s(5) def test_range_outside(): s = Schema(Range(min=0, max=10)) - assert_raises(MultipleInvalid, s, 12) - assert_raises(MultipleInvalid, s, -1) + with pytest.raises(MultipleInvalid): + s(12) + with pytest.raises(MultipleInvalid): + s(-1) def test_range_no_upper_limit(): s = Schema(Range(min=0)) - assert_equal(123, s(123)) - assert_raises(MultipleInvalid, s, -1) + assert 123 == s(123) + with pytest.raises(MultipleInvalid): + s(-1) def test_range_no_lower_limit(): s = Schema(Range(max=10)) - assert_equal(-1, s(-1)) - assert_raises(MultipleInvalid, s, 123) + assert -1 == s(-1) + with pytest.raises(MultipleInvalid): + s(123) def test_range_excludes_nan(): @@ -617,7 +620,8 @@ def test_range_excludes_none(): def test_range_excludes_string(): s = Schema(Range(min=0, max=10)) - assert_raises(MultipleInvalid, s, "abc") + with pytest.raises(MultipleInvalid): + s("abc") def test_range_excludes_unordered_object(): @@ -630,54 +634,60 @@ class MyObject(object): def test_clamp_inside(): s = Schema(Clamp(min=1, max=10)) - assert_equal(5, s(5)) + assert 5 == s(5) def test_clamp_above(): s = Schema(Clamp(min=1, max=10)) - assert_equal(10, s(12)) + assert 10 == s(12) def test_clamp_below(): s = Schema(Clamp(min=1, max=10)) - assert_equal(1, s(-3)) + assert 1 == s(-3) def test_clamp_invalid(): s = Schema(Clamp(min=1, max=10)) if sys.version_info.major >= 3: - assert_raises(MultipleInvalid, s, None) - assert_raises(MultipleInvalid, s, "abc") + with pytest.raises(MultipleInvalid): + s(None) + with pytest.raises(MultipleInvalid): + s("abc") else: - assert_equal(1, s(None)) + assert 1 == s(None) def test_length_ok(): v1 = ['a', 'b', 'c'] s = Schema(Length(min=1, max=10)) - assert_equal(v1, s(v1)) + assert v1 == s(v1) v2 = "abcde" - assert_equal(v2, s(v2)) + assert v2 == s(v2) def test_length_too_short(): v1 = [] s = Schema(Length(min=1, max=10)) - assert_raises(MultipleInvalid, s, v1) - v2 = '' - assert_raises(MultipleInvalid, s, v2) + with pytest.raises(MultipleInvalid): + s(v1) + with pytest.raises(MultipleInvalid): + v2 = '' + s(v2) def test_length_too_long(): v = ['a', 'b', 'c'] s = Schema(Length(min=0, max=2)) - assert_raises(MultipleInvalid, s, v) + with pytest.raises(MultipleInvalid): + s(v) def test_length_invalid(): v = None s = Schema(Length(min=0, max=2)) - assert_raises(MultipleInvalid, s, v) + with pytest.raises(MultipleInvalid): + s(v) def test_equal(): @@ -754,7 +764,7 @@ def test_maybe_returns_default_error(): # Should trigger a MultipleInvalid exception schema(3) except MultipleInvalid as e: - assert_equal(str(e), "not a valid value") + assert str(e) == "not a valid value" else: assert False, "Did not raise correct Invalid" @@ -766,14 +776,14 @@ def test_schema_empty_list(): try: s([123]) except MultipleInvalid as e: - assert_equal(str(e), "not a valid value @ data[123]") + assert str(e) == "not a valid value @ data[123]" else: assert False, "Did not raise correct Invalid" try: s({'var': 123}) except MultipleInvalid as e: - assert_equal(str(e), "expected a list") + assert str(e) == "expected a list" else: assert False, "Did not raise correct Invalid" @@ -785,14 +795,14 @@ def test_schema_empty_dict(): try: s({'var': 123}) except MultipleInvalid as e: - assert_equal(str(e), "extra keys not allowed @ data['var']") + assert str(e) == "extra keys not allowed @ data['var']" else: assert False, "Did not raise correct Invalid" try: s([123]) except MultipleInvalid as e: - assert_equal(str(e), "expected a dictionary") + assert str(e) == "expected a dictionary" else: assert False, "Did not raise correct Invalid" @@ -805,7 +815,7 @@ def test_schema_empty_dict_key(): try: s({'var': [123]}) except MultipleInvalid as e: - assert_equal(str(e), "not a valid value for dictionary value @ data['var']") + assert str(e) == "not a valid value for dictionary value @ data['var']" else: assert False, "Did not raise correct Invalid" @@ -1070,7 +1080,7 @@ def test_marker_hashable(): assert Required('x') == Required('x') assert Required('x') != Required('y') # Remove markers are not hashable - assert definition.get('j') == None + assert definition.get('j') is None def test_schema_infer(): @@ -1513,8 +1523,8 @@ def test_inclusive(): r = schema({}) assert r == {} - r = schema({'x':1, 'y':2}) - assert r == {'x':1, 'y':2} + r = schema({'x': 1, 'y': 2}) + assert r == {'x': 1, 'y': 2} try: r = schema({'x': 1}) @@ -1531,7 +1541,7 @@ def test_inclusive_defaults(): }) r = schema({}) - assert r == {'x':3, 'y':4} + assert r == {'x': 3, 'y': 4} try: r = schema({'x': 1}) @@ -1550,8 +1560,8 @@ def test_exclusive(): r = schema({}) assert r == {} - r = schema({'x':1}) - assert r == {'x':1} + r = schema({'x': 1}) + assert r == {'x': 1} try: r = schema({'x': 1, 'y': 2}) @@ -1611,13 +1621,13 @@ class StringChoice(str, Enum): try: schema(4) except Invalid as e: - assert str(e) == "expected Choice or one of 1, 2, 3") + assert str(e) == "expected Choice or one of 1, 2, 3" else: assert False, "Did not raise Invalid for String" try: string_schema("hello") except Invalid as e: - assert str(e) == "expected StringChoice or one of 'easy', 'medium', 'hard'") + assert str(e) == "expected StringChoice or one of 'easy', 'medium', 'hard'" else: assert False, "Did not raise Invalid for String"