| #!/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.""" |
| |
| import logging |
| import pkgutil |
| import sys |
| 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")) |
| |
| |
| def main(): |
| """Main unittest entry. |
| |
| Args: |
| argv: A list of system arguments. (unused) |
| |
| Returns: |
| 0 if success. None-zero if fails. |
| """ |
| test_modules = [ |
| mod.name |
| for mod in pkgutil.walk_packages() |
| if mod.name.startswith('acloud') and mod.name.endswith('_test') |
| ] |
| |
| 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() |