# # Metrix++, Copyright 2009-2013, Metrix++ Project # Link: http://metrixplusplus.sourceforge.net # # This file is a part of Metrix++ Tool. # # Metrix++ is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, version 3 of the License. # # Metrix++ is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Metrix++. If not, see . # import logging import time import subprocess import os.path import itertools import core.log import core.cmdparser def main(): exit_code = 0 log_plugin = core.log.Plugin() parser = core.cmdparser.MultiOptionParser(usage="Usage: %prog [options] -- [testgroup-dir-path-1[/testsuite-file-path-1]] ... [...path-N]") log_plugin.declare_configuration(parser, default_value='ERROR') parser.add_option("-g", "--general.generate-golds", action="store_true", default=False, help="If the option is set (True), new gold files are generated (replacing existing) [default: %default]") (options, args) = parser.parse_args() log_plugin.configure(options) os.environ['METRIXPLUSPLUS_TEST_GENERATE_GOLDS'] = str(options.__dict__['general.generate_golds']) install_dir = os.path.dirname(os.path.abspath(__file__)) tests_dir = os.path.join(install_dir, 'tests') os.environ['METRIXPLUSPLUS_INSTALL_DIR'] = install_dir process_data= ["python", "-m", "unittest", "discover", "-v", "-s"] if len(args) == 0 or tests_dir == os.path.abspath(args[0]): for fname in os.listdir(tests_dir): full_path = os.path.join(tests_dir, fname) if os.path.isdir(full_path) and fname != "sources": exit_code += subprocess.call(itertools.chain(process_data, [full_path]), cwd=os.environ['METRIXPLUSPLUS_INSTALL_DIR']) else: for arg in args: if os.path.isdir(arg): exit_code += subprocess.call(itertools.chain(process_data, [arg]), cwd=os.environ['METRIXPLUSPLUS_INSTALL_DIR']) else: dir_name = os.path.dirname(arg) file_name = os.path.basename(arg) exit_code += subprocess.call(itertools.chain(process_data, [dir_name, "-p", file_name]), cwd=os.environ['METRIXPLUSPLUS_INSTALL_DIR']) return exit_code if __name__ == '__main__': ts = time.time() core.log.set_default_format() exit_code = main() logging.warning("Exit code: " + str(exit_code) + ". Time spent: " + str(round((time.time() - ts), 2)) + " seconds. Done") exit(exit_code) # number of reported messages, errors are reported as non-handled exceptions