2017-07-12 20:04:22 -07:00
|
|
|
#!/usr/bin/env python
|
|
|
|
"""Import the given python module(s) and report error(s) encountered."""
|
|
|
|
|
|
|
|
from __future__ import absolute_import, print_function
|
|
|
|
|
|
|
|
import imp
|
|
|
|
import os
|
2017-09-14 09:01:11 -07:00
|
|
|
import re
|
2017-07-12 20:04:22 -07:00
|
|
|
import sys
|
|
|
|
import traceback
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
"""Main program function."""
|
|
|
|
base_dir = os.getcwd()
|
|
|
|
messages = set()
|
|
|
|
|
|
|
|
for path in sys.argv[1:]:
|
|
|
|
try:
|
|
|
|
with open(path, 'r') as module_fd:
|
|
|
|
imp.load_module('module_import_test', module_fd, os.path.abspath(path), ('.py', 'r', imp.PY_SOURCE))
|
|
|
|
except Exception as ex: # pylint: disable=locally-disabled, broad-except
|
|
|
|
exc_type, _, exc_tb = sys.exc_info()
|
|
|
|
message = str(ex)
|
|
|
|
results = list(reversed(traceback.extract_tb(exc_tb)))
|
|
|
|
source = None
|
2017-07-14 08:04:43 -07:00
|
|
|
line = 0
|
|
|
|
offset = 0
|
2017-07-12 20:04:22 -07:00
|
|
|
|
|
|
|
for result in results:
|
|
|
|
if result[0].startswith(base_dir):
|
|
|
|
source = result[0][len(base_dir) + 1:].replace('test/runner/import/', '')
|
2017-08-05 22:16:10 -07:00
|
|
|
line = result[1] or 0
|
2017-07-12 20:04:22 -07:00
|
|
|
break
|
|
|
|
|
|
|
|
if not source:
|
2017-07-14 08:04:43 -07:00
|
|
|
# If none of our source files are found in the traceback, report the file we were testing.
|
|
|
|
# I haven't been able to come up with a test case that encounters this issue yet.
|
2017-07-12 20:04:22 -07:00
|
|
|
source = path
|
2017-08-05 22:16:10 -07:00
|
|
|
message += ' (in %s:%d)' % (results[-1][0], results[-1][1] or 0)
|
2017-07-14 08:04:43 -07:00
|
|
|
elif isinstance(ex, SyntaxError):
|
|
|
|
if ex.filename.endswith(path): # pylint: disable=locally-disabled, no-member
|
|
|
|
# A SyntaxError in the source we're importing will have the correct path, line and offset.
|
|
|
|
# However, the traceback will report the path to this importer.py script instead.
|
|
|
|
# We'll use the details from the SyntaxError in this case, as it's more accurate.
|
|
|
|
source = path
|
2017-08-05 22:16:10 -07:00
|
|
|
line = ex.lineno or 0 # pylint: disable=locally-disabled, no-member
|
|
|
|
offset = ex.offset or 0 # pylint: disable=locally-disabled, no-member
|
2017-07-14 08:04:43 -07:00
|
|
|
message = str(ex)
|
|
|
|
|
|
|
|
# Hack to remove the filename and line number from the message, if present.
|
|
|
|
message = message.replace(' (%s, line %d)' % (os.path.basename(path), line), '')
|
|
|
|
|
2017-09-14 09:01:11 -07:00
|
|
|
message = re.sub(r'\n *', ': ', message)
|
2017-07-14 08:04:43 -07:00
|
|
|
error = '%s:%d:%d: %s: %s' % (source, line, offset, exc_type.__name__, message)
|
2017-07-12 20:04:22 -07:00
|
|
|
|
|
|
|
if error not in messages:
|
|
|
|
messages.add(error)
|
|
|
|
print(error)
|
|
|
|
|
|
|
|
if messages:
|
|
|
|
exit(10)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|