1 #!/usr/bin/python 2 """Create new scenario test instance from an existing results directory. 3 4 This automates creation of regression tests for the results parsers. 5 There are 2 primary use cases for this. 6 7 1) Bug fixing: Parser broke on some input in the field and we want 8 to start with a test that operates on that input and fails. We 9 then apply fixes to the parser implementation until it passes. 10 11 2) Regression alarms: We take input from various real scenarios that 12 work as expected with the parser. These will be used to ensure 13 we do not break the expected functionality of the parser while 14 refactoring it. 15 16 While much is done automatically, a scenario harness is meant to 17 be easily extended and configured once generated. 18 """ 19 20 import optparse, os, shutil, sys 21 from os import path 22 23 import common 24 from autotest_lib.tko.parsers.test import scenario_base 25 from autotest_lib.client.common_lib import autotemp 26 27 usage = 'usage: %prog [options] results_dirpath scenerios_dirpath' 28 parser = optparse.OptionParser(usage=usage) 29 parser.add_option( 30 '-n', '--name', 31 help='Name for new scenario instance. Will use dirname if not specified') 32 parser.add_option( 33 '-p', '--parser_result_tag', 34 default='v1', 35 help='Storage tag to use for initial parser result.') 36 parser.add_option( 37 '-t', '--template_type', 38 default='base', 39 help='Type of unittest module to copy into new scenario.') 40 41 42 def main(): 43 (options, args) = parser.parse_args() 44 if len(args) < 2: 45 parser.print_help() 46 sys.exit(1) 47 48 results_dirpath = path.normpath(args[0]) 49 if not path.exists(results_dirpath) or not path.isdir(results_dirpath): 50 print 'Invalid results_dirpath:', results_dirpath 51 parser.print_help() 52 sys.exit(1) 53 54 scenarios_dirpath = path.normpath(args[1]) 55 if not path.exists(scenarios_dirpath) or not path.isdir(scenarios_dirpath): 56 print 'Invalid scenarios_dirpath:', scenarios_dirpath 57 parser.print_help() 58 sys.exit(1) 59 60 results_dirname = path.basename(results_dirpath) 61 # Not everything is a valid python package name, fix if necessary 62 package_dirname = scenario_base.fix_package_dirname( 63 options.name or results_dirname) 64 65 scenario_package_dirpath = path.join( 66 scenarios_dirpath, package_dirname) 67 if path.exists(scenario_package_dirpath): 68 print ( 69 'Scenario package already exists at path: %s' % 70 scenario_package_dirpath) 71 parser.print_help() 72 sys.exit(1) 73 74 # Create new scenario package 75 os.mkdir(scenario_package_dirpath) 76 77 # Create tmp_dir 78 tmp_dirpath = autotemp.tempdir(unique_id='new_scenario') 79 copied_dirpath = path.join(tmp_dirpath.name, results_dirname) 80 # Copy results_dir 81 shutil.copytree(results_dirpath, copied_dirpath) 82 83 # scenario_base.sanitize_results_data(copied_dirpath) 84 85 # Launch parser on copied_dirpath, collect emitted test objects. 86 harness = scenario_base.new_parser_harness(copied_dirpath) 87 try: 88 parser_result = harness.execute() 89 except Exception, e: 90 parser_result = e 91 92 scenario_base.store_parser_result( 93 scenario_package_dirpath, parser_result, 94 options.parser_result_tag) 95 96 scenario_base.store_results_dir( 97 scenario_package_dirpath, copied_dirpath) 98 99 scenario_base.write_config( 100 scenario_package_dirpath, 101 status_version=harness.status_version, 102 parser_result_tag=options.parser_result_tag, 103 ) 104 105 scenario_base.install_unittest_module( 106 scenario_package_dirpath, options.template_type) 107 tmp_dirpath.clean() 108 109 110 if __name__ == '__main__': 111 main() 112