Merge pull request #712 from revarbat/revarbat_dev

Added test-file mismatch warnings to func_coverage.py
This commit is contained in:
Revar Desmera 2021-10-26 22:31:18 -07:00 committed by GitHub
commit 0d06429d3d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -14,24 +14,27 @@ for filename in os.listdir("."):
if funcname.startswith("_"): if funcname.startswith("_"):
continue continue
if funcname in funcs: if funcname in funcs:
print("WARNING!!! Function {} re-defined at {}:{}".format(funcname, filename, linenum)); print("WARNING!!! Function {} re-defined at {}:{}".format(funcname, filename, linenum+1));
print(" Previously defined at {}:{}".format(*funcs[funcname])); print(" Previously defined at {}:{}".format(*funcs[funcname]));
else: else:
funcs[funcname] = (filename, linenum) funcs[funcname] = (filename, linenum+1)
covered = [] covered = {}
uncovered = funcs.copy() uncovered = funcs.copy()
for filename in os.listdir("tests"): for filename in os.listdir("tests"):
if filename.startswith("test_") and filename.endswith(".scad"): if filename.startswith("test_") and filename.endswith(".scad"):
filepath = os.path.join("tests",filename) filepath = os.path.join("tests",filename)
with open(filepath, "r") as f: with open(filepath, "r") as f:
for line in f.readlines(): for linenum,line in enumerate(f.readlines()):
if line.startswith("module "): if line.startswith("module "):
testmodule = line[7:].strip().split("(")[0].strip() testmodule = line[7:].strip().split("(")[0].strip()
if testmodule.startswith("test_"): if testmodule.startswith("test_"):
funcname = testmodule.split("_",1)[1] funcname = testmodule.split("_",1)[1]
if funcname in uncovered: if funcname in uncovered:
covered.append(funcname) if filename != "test_" + uncovered[funcname][0]:
print("WARNING!!! Function {} defined at {}:{}".format(funcname, *uncovered[funcname]));
print(" but tested at {}:{}".format(filename, linenum+1));
covered[funcname] = (filename,linenum+1)
del uncovered[funcname] del uncovered[funcname]
uncovered_by_file = {} uncovered_by_file = {}