diff options
author | Dmitry Trofimov <trofimov.dmitry@gmail.com> | 2015-04-14 18:19:20 -0400 |
---|---|---|
committer | Dmitry Trofimov <trofimov.dmitry@gmail.com> | 2015-04-14 18:19:20 -0400 |
commit | 78a0ad5a6b4668dc9f1807d7bfb431d263b7b071 (patch) | |
tree | e786fd9de54a22208a44612f76f4653f647f3a21 /coverage/execfile.py | |
parent | e7e8d3c1db25973021a1ef212ca5d6b53230f715 (diff) | |
download | python-coveragepy-78a0ad5a6b4668dc9f1807d7bfb431d263b7b071.tar.gz |
Look for __main__ module if coverage is being run for directory #252
Diffstat (limited to 'coverage/execfile.py')
-rw-r--r-- | coverage/execfile.py | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/coverage/execfile.py b/coverage/execfile.py index 2d85689..71bdb8d 100644 --- a/coverage/execfile.py +++ b/coverage/execfile.py @@ -137,6 +137,16 @@ def run_python_file(filename, args, package=None, modulename=None): old_argv = sys.argv sys.argv = args + if os.path.isdir(filename): + # in directory we should look for __main__ module + for ext in [".py", ".pyc", ".pyo"]: + try_filename = os.path.join(filename, "__main__" + ext) + if os.path.exists(try_filename): + filename = try_filename + break + else: + raise NoSource("Can't find '__main__' module in '%s'" % filename) + try: # Make a code object somehow. if filename.endswith((".pyc", ".pyo")): |