unittests: Add additional tests for KwargInfo::since values

The first test is checking the added support for keys as either `dict`
or `list`.

The second checks that a default value which would otherwise trigger a
value_since check doesn't, and that passing the default value explicitly
does.
pull/10718/head
Dylan Baker 3 years ago committed by Eli Schwartz
parent 25a3eff797
commit f10967e3f4
  1. 16
      unittests/internaltests.py

@ -1387,6 +1387,10 @@ class InternalTests(unittest.TestCase):
validator=in_set_validator({'clean', 'build', 'rebuild', 'deprecated', 'since'}), validator=in_set_validator({'clean', 'build', 'rebuild', 'deprecated', 'since'}),
deprecated_values={'deprecated': '1.0'}, deprecated_values={'deprecated': '1.0'},
since_values={'since': '1.1'}), since_values={'since': '1.1'}),
KwargInfo('dict', (ContainerTypeInfo(list, str), ContainerTypeInfo(dict, str)), default={},
since_values={list: '1.9'}),
KwargInfo('new_dict', (ContainerTypeInfo(list, str), ContainerTypeInfo(dict, str)), default={},
since_values={dict: '1.1'}),
) )
def _(obj, node, args: T.Tuple, kwargs: T.Dict[str, str]) -> None: def _(obj, node, args: T.Tuple, kwargs: T.Dict[str, str]) -> None:
pass pass
@ -1427,6 +1431,18 @@ class InternalTests(unittest.TestCase):
_(None, mock.Mock(subproject=''), [], {'mode': 'since'}) _(None, mock.Mock(subproject=''), [], {'mode': 'since'})
self.assertRegex(out.getvalue(), r"""WARNING:.Project targets '1.0'.*introduced in '1.1': "testfunc" keyword argument "mode" value "since".*""") self.assertRegex(out.getvalue(), r"""WARNING:.Project targets '1.0'.*introduced in '1.1': "testfunc" keyword argument "mode" value "since".*""")
with self.subTest('new container'), mock.patch('sys.stdout', io.StringIO()) as out:
_(None, mock.Mock(subproject=''), [], {'dict': ['a=b']})
self.assertRegex(out.getvalue(), r"""WARNING:.Project targets '1.0'.*introduced in '1.9': "testfunc" keyword argument "dict" of type list.*""")
with self.subTest('new container set to default'), mock.patch('sys.stdout', io.StringIO()) as out:
_(None, mock.Mock(subproject=''), [], {'new_dict': {}})
self.assertRegex(out.getvalue(), r"""WARNING:.Project targets '1.0'.*introduced in '1.1': "testfunc" keyword argument "new_dict" of type dict.*""")
with self.subTest('new container default'), mock.patch('sys.stdout', io.StringIO()) as out:
_(None, mock.Mock(subproject=''), [], {})
self.assertNotRegex(out.getvalue(), r"""WARNING:.Project targets '1.0'.*introduced in '1.1': "testfunc" keyword argument "new_dict" of type dict.*""")
def test_typed_kwarg_evolve(self) -> None: def test_typed_kwarg_evolve(self) -> None:
k = KwargInfo('foo', str, required=True, default='foo') k = KwargInfo('foo', str, required=True, default='foo')
v = k.evolve(default='bar') v = k.evolve(default='bar')

Loading…
Cancel
Save