Skip to content
This repository has been archived by the owner on Jan 27, 2020. It is now read-only.

Commit

Permalink
Better error messages for bad parametrization
Browse files Browse the repository at this point in the history
Signed-off-by: Pete Baughman <pete.baughman@apex.ai>
  • Loading branch information
Pete Baughman committed Apr 16, 2019
1 parent 3ae41cf commit 35d0dc3
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 13 deletions.
27 changes: 27 additions & 0 deletions apex_launchtest/apex_launchtest/apex_runner.py
Original file line number Diff line number Diff line change
Expand Up @@ -241,4 +241,31 @@ def validate(self):
# Make sure the function signature of the launch configuration
# generator is correct
for run in self._test_runs:
# Drill down into any parametrized test descriptions and make sure the argument names
# are correct. A simpler check can use getcallargs, but then you won't get a very
# helpful message.
base_fn = inspect.unwrap(run.test_description_function)
base_args = inspect.getfullargspec(base_fn)
base_args = base_args.args + base_args.kwonlyargs

# Check that the parametrized arguments all have a place to go
for argname in run.param_args.keys():
if argname not in base_args:
raise Exception(
'Could not find an argument in generate_test_description matching '
"prametrized argument '{}'".format(argname)
)

# Check for extra args in generate_test_description
for argname in base_args:
if argname == 'ready_fn':
continue
if argname not in run.param_args.keys():
raise Exception(
"generate_test_description has unexpected extra argument '{}'".format(
argname
)
)

# This is a double-check
inspect.getcallargs(run.test_description_function, ready_fn=lambda: None)
51 changes: 38 additions & 13 deletions apex_launchtest/test/test_apex_runner_validation.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,35 +12,60 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import imp
import unittest

import apex_launchtest
from apex_launchtest.apex_runner import ApexRunner
from apex_launchtest.loader import TestRun as TR # Named TR so pytest doesn't think it's a test
from apex_launchtest.loader import LoadTestsFromPythonModule


def make_test_run_for_dut(generate_test_description_function):
module = imp.new_module('test_module')
module.generate_test_description = generate_test_description_function
return LoadTestsFromPythonModule(module)


class TestApexRunnerValidation(unittest.TestCase):

def test_catches_bad_signature(self):

dut = ApexRunner(
[TR(
test_description_function=lambda: None,
param_args={},
pre_shutdown_tests=None,
post_shutdown_tests=None,
)]
make_test_run_for_dut(
lambda: None
)
)

with self.assertRaises(TypeError):
dut.validate()

dut = ApexRunner(
[TR(
test_description_function=lambda ready_fn: None,
param_args={},
pre_shutdown_tests=None,
post_shutdown_tests=None,
)]
make_test_run_for_dut(
lambda ready_fn: None
)
)

dut.validate()

def test_too_many_arguments(self):

dut = ApexRunner(
make_test_run_for_dut(lambda ready_fn, extra_arg: None)
)

with self.assertRaisesRegex(Exception, "unexpected extra argument 'extra_arg'"):
dut.validate()

def test_bad_parametrization_argument(self):

@apex_launchtest.parametrize('bad_argument', [1, 2, 3])
def bad_launch_description(ready_fn):
pass # pragma: no cover

dut = ApexRunner(
make_test_run_for_dut(bad_launch_description)
)

with self.assertRaisesRegex(Exception, 'Could not find an argument') as cm:
dut.validate()
self.assertIn('bad_argument', str(cm.exception))

0 comments on commit 35d0dc3

Please sign in to comment.