Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Moved testing code to another file for easier using outside MCAD

  • Loading branch information...
commit ee4048f6b61463b381d516e4d74d4dcd2edfc655 1 parent 25343d6
@elmom authored
Showing with 50 additions and 0 deletions.
  1. +49 −0 openscad_testing.py
  2. +1 −0  test_mcad.py
View
49 openscad_testing.py
@@ -0,0 +1,49 @@
+import py
+
+from openscad_utils import *
+
+
+temppath = py.test.ensuretemp('MCAD')
+
+def pytest_generate_tests(metafunc):
+ if "modpath" in metafunc.funcargnames:
+ for fpath, modnames in collect_test_modules().items():
+ #os.system("cp %s %s/" % (fpath, temppath))
+ if "modname" in metafunc.funcargnames:
+ for modname in modnames:
+ metafunc.addcall(funcargs=dict(modname=modname, modpath=fpath))
+ else:
+ metafunc.addcall(funcargs=dict(modpath=fpath))
+
+
+def test_module_compile(modname, modpath):
+ tempname = modpath.basename + '-' + modname + '.scad'
+ fpath = temppath.join(tempname)
+ stlpath = temppath.join(tempname + ".stl")
+ f = fpath.open('w')
+ code = """
+//generated testfile
+use <%s>
+
+%s();
+""" % (modpath, modname)
+ print code
+ f.write(code)
+ f.flush()
+ output = call_openscad(path=fpath, stlpath=stlpath, timeout=15)
+ print output
+ assert output[0] is 0
+ for s in ("warning", "error"):
+ assert s not in output[2].strip().lower()
+ assert len(stlpath.readlines()) > 2
+
+def test_file_compile(modpath):
+ stlpath = temppath.join(modpath.basename + "-test.stl")
+ output = call_openscad(path=modpath, stlpath=stlpath)
+ print output
+ assert output[0] is 0
+ for s in ("warning", "error"):
+ assert s not in output[2].strip().lower()
+ assert len(stlpath.readlines()) == 2
+
+
View
1  test_mcad.py
@@ -0,0 +1 @@
+from openscad_testing import *

0 comments on commit ee4048f

Please sign in to comment.
Something went wrong with that request. Please try again.