Merge "Add warning for invalid parameters"

This commit is contained in:
Jenkins 2016-06-22 13:07:25 +00:00 committed by Gerrit Code Review
commit 9a7fcb9258
3 changed files with 17 additions and 0 deletions

View File

@ -280,6 +280,15 @@ class RestParametersDirective(Table):
# self.app.info("Lookup table looks like %s" % lookup)
new_content = list()
for paramlist in parsed:
if not isinstance(paramlist, dict):
self.env.warn(
"%s:%s" % (
self.state_machine.node.source,
self.state_machine.node.line),
("Invalid parameter definition ``%s``. Expected "
"format: ``name: reference``. "
" Skipping." % paramlist))
continue
for name, ref in paramlist.items():
if ref in lookup:
new_content.append((name, lookup[ref]))

View File

@ -13,3 +13,4 @@ I am text, hear me roar!
- name: name
- name: lookup_key_name
- name: name_1
- invalid_name

View File

@ -66,3 +66,10 @@ class TestWarnings(base.TestCase):
+ " ('required', True)]). "
+ "'NoneType' object has no attribute 'split'\n"),
self.warning)
def test_invalid_parameter_definition(self):
"""Warning when parameter definition is invalid."""
self.assertIn(
("WARNING: Invalid parameter definition ``invalid_name``. "
+ "Expected format: ``name: reference``. "),
self.warning)