X-Git-Url: http://nitlanguage.org diff --git a/src/testing/testing_doc.nit b/src/testing/testing_doc.nit index 27e6fac..e975d85 100644 --- a/src/testing/testing_doc.nit +++ b/src/testing/testing_doc.nit @@ -79,7 +79,9 @@ class NitUnitExecutor var cpt = 0 # The entry point for a new `ndoc` node - # Fill the prepated `tc` (testcase) XTM node + # Fill `docunits` with new discovered unit of tests. + # + # `tc` (testcase) is the pre-filled XML node fun extract(ndoc: ADoc, tc: HTMLTag) do blocks.clear @@ -103,12 +105,123 @@ class NitUnitExecutor if blocks.is_empty then return - for block in blocks do test_block(ndoc, tc, block) + for block in blocks do + docunits.add new DocUnit(ndoc, tc, block.join("")) + end + end + + # All extracted docunits + var docunits = new Array[DocUnit] + + # Execute all the docunits + fun run_tests + do + var simple_du = new Array[DocUnit] + for du in docunits do + var ast = toolcontext.parse_something(du.block) + if ast isa AExpr then + simple_du.add du + else + test_single_docunit(du) + end + end + + test_simple_docunits(simple_du) end - # Execute a block - fun test_block(ndoc: ADoc, tc: HTMLTag, block: Array[String]) + # Executes multiples doc-units in a shared program. + # Used for docunits simple block of code (without modules, classes, functions etc.) + # + # In case of compilation error, the method fallbacks to `test_single_docunit` to + # * locate exactly the compilation problem in the problematic docunit. + # * permit the execution of the other docunits that may be correct. + fun test_simple_docunits(dus: Array[DocUnit]) do + if dus.is_empty then return + + var file = "{prefix}-0.nit" + + var dir = file.dirname + if dir != "" then dir.mkdir + var f + f = new OFStream.open(file) + f.write("# GENERATED FILE\n") + f.write("# Docunits extracted from comments\n") + f.write("import {mmodule.name}\n") + f.write("\n") + var i = 0 + for du in dus do + + i += 1 + f.write("fun run_{i} do\n") + f.write("# {du.testcase.attrs["name"]}\n") + f.write(du.block) + f.write("end\n") + end + f.write("var a = args.first.to_i\n") + for j in [1..i[ do + f.write("if a == {j} then run_{j}\n") + end + f.close + + if toolcontext.opt_noact.value then return + + var nit_dir = toolcontext.nit_dir + var nitg = nit_dir/"bin/nitg" + if not nitg.file_exists then + toolcontext.error(null, "Cannot find nitg. Set envvar NIT_DIR.") + toolcontext.check_errors + end + var cmd = "{nitg} --ignore-visibility --no-color '{file}' -I {mmodule.location.file.filename.dirname} >'{file}.out1' 2>&1 >'{file}.out1' 2>&1 ` XML element that contains the results of the executions. fun test_markdown(mmodule: MModule): HTMLTag do var ts = new HTMLTag("testsuite") toolcontext.info("nitunit: doc-unit {mmodule}", 2) - if not mmodule2nmodule.has_key(mmodule) then return ts - var nmodule = mmodule2nmodule[mmodule] + var nmodule = mmodule2node(mmodule) + if nmodule == null then return ts # usualy, only the original module must be imported in the unit test. var o = mmodule @@ -265,6 +381,8 @@ redef class ModelBuilder end end + d2m.run_tests + return ts end end