Commit 8b42d921 authored by Kevin Modzelewski's avatar Kevin Modzelewski

Fix a bug in the try-importer

The repl swallows all exceptions, so we weren't counting what we thought.
parent 3c8c90fa
...@@ -2,11 +2,14 @@ import glob ...@@ -2,11 +2,14 @@ import glob
import os import os
import subprocess import subprocess
LIB_DIR = "from_cpython/Lib"
EXE_PATH = "./pyston_dbg"
modules = [] modules = []
for fn in glob.glob("from_cpython/Lib/*.py"): for fn in glob.glob("%s/*.py" % LIB_DIR):
modules.append(os.path.basename(fn)[:-3]) modules.append(os.path.basename(fn)[:-3])
for fn in glob.glob("from_cpython/Lib/*"): for fn in glob.glob("%s/*" % LIB_DIR):
if not os.path.isdir(fn): if not os.path.isdir(fn):
continue continue
modules.append(os.path.basename(fn)) modules.append(os.path.basename(fn))
...@@ -15,10 +18,17 @@ print modules ...@@ -15,10 +18,17 @@ print modules
nworked = 0 nworked = 0
total = 0 total = 0
print len(modules) print len(modules)
f = open("failures.txt", 'w')
for m in modules: for m in modules:
p = subprocess.Popen(["./pyston_dbg"], stdin=subprocess.PIPE) p = subprocess.Popen([EXE_PATH, "-q"], stdin=subprocess.PIPE, stderr=subprocess.PIPE)
p.stdin.write("import %s\n" % m) # We need to make pyston exit with a non-zero return code if an exception was thrown,
# so use this little dance. If the import succeeds, then we call sys.exit(0), otherwise
# we skip to the next line and call sys.exit(1)
p.stdin.write("import sys\n")
p.stdin.write("import %s; sys.exit(0)\n" % m)
p.stdin.write("sys.exit(1)\n")
p.stdin.close() p.stdin.close()
err = p.stderr.read()
code = p.wait() code = p.wait()
if code == 0: if code == 0:
print m, "worked", print m, "worked",
...@@ -26,5 +36,8 @@ for m in modules: ...@@ -26,5 +36,8 @@ for m in modules:
else: else:
print code print code
print m, "failed", print m, "failed",
print >>f, m
print >>f, '\n'.join(err.split('\n')[-4:])
f.flush()
total += 1 total += 1
print "%d/%d" % (nworked, total) print "%d/%d" % (nworked, total)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment