X-Git-Url: https://gerrit.akraino.org/r/gitweb?p=validation.git;a=blobdiff_plain;f=bluval%2Fbluval.py;h=f8762bd8d0d89137ba96622d0ff4fb3e44d95b52;hp=01b402af6b613fd5c5620d24d6f3bcccf5fd9183;hb=HEAD;hpb=980caf9de32c2a8a04415d584b968f7582abcd75 diff --git a/bluval/bluval.py b/bluval/bluval.py index 01b402a..f8762bd 100644 --- a/bluval/bluval.py +++ b/bluval/bluval.py @@ -20,30 +20,67 @@ testcase """ import subprocess +import sys +import traceback +from pathlib import Path + import click import yaml +from bluutil import BluvalError +from bluutil import ShowStopperError + +_OPTIONAL_ALSO = False + def run_testcase(testcase): """Runs a single testcase """ - show_stopper = testcase.get('show_stopper', False) + name = testcase.get('name') + skip = testcase.get('skip', "False") + optional = testcase.get('optional', "False") + if skip.lower() == "true": + # skip is mentioned and true. + print('Skipping {}'.format(name)) + return + print("_OPTIONAL_ALSO {}".format(_OPTIONAL_ALSO)) + if not _OPTIONAL_ALSO and optional.lower() == "true": + # Optional Test case. + print('Ignoring Optional {} testcase'.format(name)) + return + show_stopper = testcase.get('show_stopper', "False") what = testcase.get('what') - results = "results/"+testcase.get('layer')+"/"+what - test_path = "tests/"+testcase.get('layer')+"/"+what - command = '{} {} {} {}'.format("robot", "-d", results, test_path) + mypath = Path(__file__).absolute() + results_path = mypath.parents[2].joinpath( + "results/"+testcase.get('layer')+"/"+what) + test_path = mypath.parents[1].joinpath( + "tests/"+testcase.get('layer')+"/"+what) - print('Executing testcase {}'.format(testcase['name'])) - print(' show_stopper {}'.format(show_stopper)) - print('Invoking {}'.format(command)) + # add to the variables file the path to where to sotre the logs + variables_file = mypath.parents[1].joinpath("tests/variables.yaml") + variables_dict = yaml.safe_load(variables_file.open()) + variables_dict['log_path'] = str(results_path) + variables_updated_file = mypath.parents[1].joinpath("tests/variables_updated.yaml") + variables_updated_file.write_text(str(variables_dict)) + variables_loglevel = variables_dict['loglevel'] + + # run the test + args = ["robot", "-V", str(variables_updated_file), + "-d", str(results_path), + "-n", "non-critical", + "-b", "debug.log", + "-L", str(variables_loglevel), + str(test_path)] + + print('Executing testcase {}'.format(name)) + print('show_stopper {}'.format(show_stopper)) + print('Invoking {}'.format(args), flush=True) try: - status = subprocess.call(command, shell=True) - if status != 0 and show_stopper: - print('Show stopper testcase failed') - return status + status = subprocess.call(args, shell=False) + if status != 0 and show_stopper.lower() == "true": + raise ShowStopperError(name) except OSError: - print('Error while executing {}'.format(command)) - return -1 - return status + #print('Error while executing {}'.format(args)) + raise BluvalError(OSError) def validate_layer(blueprint, layer): @@ -59,26 +96,57 @@ def validate_blueprint(yaml_loc, layer): """Parse yaml file and validates given layer. If no layer given all layers validated """ - with open(yaml_loc) as yaml_file: + with open(str(yaml_loc)) as yaml_file: yamldoc = yaml.safe_load(yaml_file) blueprint = yamldoc['blueprint'] - if layer is None: - for each_layer in blueprint['layers']: - validate_layer(blueprint, each_layer) - else: - validate_layer(blueprint, layer) + validate_layer(blueprint, layer) + + +def write_test_info(layer): + """writes testing info to test_info.yaml + """ + data = dict( + test_info=dict( + layer=layer, + optional=_OPTIONAL_ALSO, + ) + ) + + with open('/opt/akraino/results/test_info.yaml', 'w') as outfile: + yaml.dump(data, outfile, default_flow_style=False) @click.command() @click.argument('blueprint') @click.option('--layer', '-l') -def main(blueprint, layer): +@click.option('--optional_also', '-o', is_flag=True) +def main(blueprint, layer, optional_also): """Takes blueprint name and optional layer. Validates inputs and derives yaml location from blueprint name. Invokes validate on blue print. """ - yaml_loc = 'bluval/bluval-{}.yaml'.format(blueprint) - layer = layer.lower() - validate_blueprint(yaml_loc, layer) + global _OPTIONAL_ALSO # pylint: disable=global-statement + mypath = Path(__file__).absolute() + yaml_loc = mypath.parents[0].joinpath('bluval-{}.yaml'.format(blueprint)) + if layer is not None: + layer = layer.lower() + if optional_also: + _OPTIONAL_ALSO = True + print("_OPTIONAL_ALSO {}".format(_OPTIONAL_ALSO)) + + try: + write_test_info(layer) + validate_blueprint(yaml_loc, layer) + except ShowStopperError as err: + print('ShowStopperError:', err) + except BluvalError as err: + print('Unexpected BluvalError', err) + raise + except: + print("Exception in user code:") + print("-"*60) + traceback.print_exc(file=sys.stdout) + print("-"*60) + raise if __name__ == "__main__":