|  | #!/usr/bin/python | 
|  |  | 
|  | """ | 
|  | Copyright 2014 Google Inc. | 
|  |  | 
|  | Use of this source code is governed by a BSD-style license that can be | 
|  | found in the LICENSE file. | 
|  |  | 
|  | A wrapper around the standard Python unittest library, adding features we need | 
|  | for various unittests within this directory. | 
|  | """ | 
|  |  | 
|  | import errno | 
|  | import os | 
|  | import shutil | 
|  | import sys | 
|  | import unittest | 
|  |  | 
|  | # Set the PYTHONPATH to include the tools directory. | 
|  | sys.path.append( | 
|  | os.path.join(os.path.dirname(os.path.realpath(__file__)), os.pardir)) | 
|  | import find_run_binary | 
|  |  | 
|  |  | 
|  | class TestCase(unittest.TestCase): | 
|  |  | 
|  | def shortDescription(self): | 
|  | """Tell unittest framework to not print docstrings for test cases.""" | 
|  | return None | 
|  |  | 
|  | def create_empty_dir(self, path): | 
|  | """Creates an empty directory at path and returns path. | 
|  |  | 
|  | Args: | 
|  | path: path on local disk | 
|  | """ | 
|  | shutil.rmtree(path=path, ignore_errors=True) | 
|  | try: | 
|  | os.makedirs(path) | 
|  | except OSError as exc: | 
|  | if exc.errno != errno.EEXIST: | 
|  | raise | 
|  | return path | 
|  |  | 
|  | def run_command(self, args): | 
|  | """Runs a program from the command line and returns stdout. | 
|  |  | 
|  | Args: | 
|  | args: Command line to run, as a list of string parameters. args[0] is the | 
|  | binary to run. | 
|  |  | 
|  | Returns: | 
|  | stdout from the program, as a single string. | 
|  |  | 
|  | Raises: | 
|  | Exception: the program exited with a nonzero return code. | 
|  | """ | 
|  | return find_run_binary.run_command(args) | 
|  |  | 
|  | def find_path_to_program(self, program): | 
|  | """Returns path to an existing program binary. | 
|  |  | 
|  | Args: | 
|  | program: Basename of the program to find (e.g., 'render_pictures'). | 
|  |  | 
|  | Returns: | 
|  | Absolute path to the program binary, as a string. | 
|  |  | 
|  | Raises: | 
|  | Exception: unable to find the program binary. | 
|  | """ | 
|  | return find_run_binary.find_path_to_program(program) | 
|  |  | 
|  |  | 
|  | def main(test_case_class): | 
|  | """Run the unit tests within the given class. | 
|  |  | 
|  | Raises an Exception if any of those tests fail (in case we are running in the | 
|  | context of run_all.py, which depends on that Exception to signal failures). | 
|  |  | 
|  | TODO(epoger): Make all of our unit tests use the Python unittest framework, | 
|  | so we can leverage its ability to run *all* the tests and report failures at | 
|  | the end. | 
|  | """ | 
|  | suite = unittest.TestLoader().loadTestsFromTestCase(test_case_class) | 
|  | results = unittest.TextTestRunner(verbosity=2).run(suite) | 
|  | if not results.wasSuccessful(): | 
|  | raise Exception('failed unittest %s' % test_case_class) |