#!/usr/bin/python # # Copyright 2018 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """Main entry point for all of acloud's unittest.""" from importlib import import_module import logging import os import sys import sysconfig import unittest # Needed to silence oauth2client. # This is a workaround to get rid of below warning message: # 'No handlers could be found for logger "oauth2client.contrib.multistore_file' # TODO(b/112803893): Remove this code once bug is fixed. OAUTH2_LOGGER = logging.getLogger('oauth2client.contrib.multistore_file') OAUTH2_LOGGER.setLevel(logging.CRITICAL) OAUTH2_LOGGER.addHandler(logging.FileHandler("/dev/null")) # Setup logging to be silent so unittests can pass through TF. ACLOUD_LOGGER = "acloud" logger = logging.getLogger(ACLOUD_LOGGER) logger.setLevel(logging.CRITICAL) logger.addHandler(logging.FileHandler("/dev/null")) if sys.version_info.major == 3: sys.path.insert(0, os.path.dirname(sysconfig.get_paths()['purelib'])) # (b/219847353) Move googleapiclient to the last position of sys.path when # existed. for lib in sys.path: if 'googleapiclient' in lib: sys.path.remove(lib) sys.path.append(lib) break def GetTestModules(): """Return list of testable modules. We need to find all the test files (*_test.py) and get their relative path (internal/lib/utils_test.py) and translate it to an import path and strip the py ext (internal.lib.utils_test). Returns: List of strings (the testable module import path). """ testable_modules = [] base_path = os.path.dirname(os.path.realpath(__file__)) # Get list of all python files that end in _test.py (except for __file__). for dirpath, _, files in os.walk(base_path): for f in files: if f.endswith("_test.py") and f != os.path.basename(__file__): # Now transform it into a relative import path. full_file_path = os.path.join(dirpath, f) rel_file_path = os.path.relpath(full_file_path, base_path) rel_file_path, _ = os.path.splitext(rel_file_path) rel_file_path = rel_file_path.replace(os.sep, ".") testable_modules.append(rel_file_path) return testable_modules def main(_): """Main unittest entry. Args: argv: A list of system arguments. (unused) Returns: 0 if success. None-zero if fails. """ test_modules = GetTestModules() for mod in test_modules: import_module(mod) loader = unittest.defaultTestLoader test_suite = loader.loadTestsFromNames(test_modules) runner = unittest.TextTestRunner(verbosity=2) result = runner.run(test_suite) sys.exit(not result.wasSuccessful()) if __name__ == '__main__': main(sys.argv[1:])