mirror of
https://github.com/nim-lang/Nim.git
synced 2026-06-04 02:44:44 +00:00
1
.gitignore
vendored
1
.gitignore
vendored
@@ -82,6 +82,7 @@ tweeter_test.db
|
||||
|
||||
/tests/megatest.nim
|
||||
/tests/ic/*_temp.nim
|
||||
/tests/navigator/*_temp.nim
|
||||
|
||||
|
||||
/outputExpected.txt
|
||||
|
||||
@@ -494,7 +494,8 @@ proc loadError(err: RodFileError; filename: AbsoluteFile; config: ConfigRef;) =
|
||||
of includeFileChanged:
|
||||
rawMessage(config, warnFileChanged, filename.string)
|
||||
else:
|
||||
echo "Error: ", $err, " loading file: ", filename.string
|
||||
rawMessage(config, warnCannotOpenFile, filename.string & " reason: " & $err)
|
||||
#echo "Error: ", $err, " loading file: ", filename.string
|
||||
|
||||
proc loadRodFile*(filename: AbsoluteFile; m: var PackedModule; config: ConfigRef;
|
||||
ignoreConfig = false): RodFileError =
|
||||
|
||||
@@ -79,7 +79,7 @@ proc usage(c: var NavContext; info: PackedLineInfo; isDecl: bool) =
|
||||
file = os.extractFilename file
|
||||
toLocation(m, file, info.line.int, info.col.int + ColOffset)
|
||||
if not c.alreadyEmitted.containsOrIncl(m):
|
||||
echo (if isDecl: "def" else: "usage"), c.outputSep, m
|
||||
msgWriteln c.g.config, (if isDecl: "def" else: "usage") & c.outputSep & m
|
||||
|
||||
proc list(c: var NavContext; tree: PackedTree; sym: ItemId) =
|
||||
for i in 0..high(tree.nodes):
|
||||
|
||||
@@ -483,24 +483,27 @@ proc testNimblePackages(r: var TResults; cat: Category; packageFilter: string) =
|
||||
|
||||
# ---------------- IC tests ---------------------------------------------
|
||||
|
||||
proc icTests(r: var TResults; testsDir: string, cat: Category, options: string) =
|
||||
proc icTests(r: var TResults; testsDir: string, cat: Category, options: string;
|
||||
isNavigatorTest: bool) =
|
||||
const
|
||||
tooltests = ["compiler/nim.nim", "tools/nimgrep.nim"]
|
||||
writeOnly = " --incremental:writeonly "
|
||||
readOnly = " --incremental:readonly "
|
||||
incrementalOn = " --incremental:on -d:nimIcIntegrityChecks "
|
||||
navTestConfig = " --ic:on --defusages -d:nimIcNavigatorTests --hint[Conf]:off --warnings:off "
|
||||
|
||||
template test(x: untyped) =
|
||||
testSpecWithNimcache(r, makeRawTest(file, x & options, cat), nimcache)
|
||||
|
||||
template editedTest(x: untyped) =
|
||||
var test = makeTest(file, x & options, cat)
|
||||
if isNavigatorTest:
|
||||
test.spec.action = actionCompile
|
||||
test.spec.targets = {getTestSpecTarget()}
|
||||
testSpecWithNimcache(r, test, nimcache)
|
||||
|
||||
const tempExt = "_temp.nim"
|
||||
for it in walkDirRec(testsDir / "ic"):
|
||||
# for it in ["tests/ic/timports.nim"]: # debugging: to try a specific test
|
||||
for it in walkDirRec(testsDir):
|
||||
if isTestFile(it) and not it.endsWith(tempExt):
|
||||
let nimcache = nimcacheDir(it, options, getTestSpecTarget())
|
||||
removeDir(nimcache)
|
||||
@@ -510,10 +513,10 @@ proc icTests(r: var TResults; testsDir: string, cat: Category, options: string)
|
||||
let file = it.replace(".nim", tempExt)
|
||||
writeFile(file, fragment)
|
||||
let oldPassed = r.passed
|
||||
editedTest incrementalOn
|
||||
editedTest(if isNavigatorTest: navTestConfig else: incrementalOn)
|
||||
if r.passed != oldPassed+1: break
|
||||
|
||||
when false:
|
||||
if not isNavigatorTest and false:
|
||||
for file in tooltests:
|
||||
let nimcache = nimcacheDir(file, options, getTestSpecTarget())
|
||||
removeDir(nimcache)
|
||||
@@ -528,7 +531,7 @@ proc icTests(r: var TResults; testsDir: string, cat: Category, options: string)
|
||||
|
||||
# ----------------------------------------------------------------------------
|
||||
|
||||
const AdditionalCategories = ["debugger", "examples", "lib", "ic"]
|
||||
const AdditionalCategories = ["debugger", "examples", "lib", "ic", "navigator"]
|
||||
const MegaTestCat = "megatest"
|
||||
|
||||
proc `&.?`(a, b: string): string =
|
||||
@@ -695,7 +698,9 @@ proc processCategory(r: var TResults, cat: Category,
|
||||
of "niminaction":
|
||||
testNimInAction(r, cat, options)
|
||||
of "ic":
|
||||
icTests(r, testsDir, cat, options)
|
||||
icTests(r, testsDir / cat2, cat, options, isNavigatorTest=false)
|
||||
of "navigator":
|
||||
icTests(r, testsDir / cat2, cat, options, isNavigatorTest=true)
|
||||
of "untestable":
|
||||
# These require special treatment e.g. because they depend on a third party
|
||||
# dependency; see `trunner_special` which runs some of those.
|
||||
|
||||
@@ -157,8 +157,8 @@ proc prepareTestArgs(cmdTemplate, filename, options, nimcache: string,
|
||||
"options", options, "file", filename.quoteShell,
|
||||
"filedir", filename.getFileDir(), "nim", compilerPrefix])
|
||||
|
||||
proc callCompiler(cmdTemplate, filename, options, nimcache: string,
|
||||
target: TTarget, extraOptions = ""): TSpec =
|
||||
proc callNimCompiler(cmdTemplate, filename, options, nimcache: string,
|
||||
target: TTarget, extraOptions = ""): TSpec =
|
||||
let c = prepareTestArgs(cmdTemplate, filename, options, nimcache, target,
|
||||
extraOptions)
|
||||
result.cmd = quoteShellCommand(c)
|
||||
@@ -465,11 +465,11 @@ proc testSpecHelper(r: var TResults, test: var TTest, expected: TSpec,
|
||||
test.startTime = epochTime()
|
||||
case expected.action
|
||||
of actionCompile:
|
||||
var given = callCompiler(expected.getCmd, test.name, test.options, nimcache, target,
|
||||
var given = callNimCompiler(expected.getCmd, test.name, test.options, nimcache, target,
|
||||
extraOptions = " --stdout --hint[Path]:off --hint[Processing]:off")
|
||||
compilerOutputTests(test, target, given, expected, r)
|
||||
of actionRun:
|
||||
var given = callCompiler(expected.getCmd, test.name, test.options,
|
||||
var given = callNimCompiler(expected.getCmd, test.name, test.options,
|
||||
nimcache, target, extraOptions)
|
||||
if given.err != reSuccess:
|
||||
r.addResult(test, target, "", "$ " & given.cmd & '\n' & given.nimout, given.err)
|
||||
@@ -523,7 +523,7 @@ proc testSpecHelper(r: var TResults, test: var TTest, expected: TSpec,
|
||||
else:
|
||||
compilerOutputTests(test, target, given, expected, r)
|
||||
of actionReject:
|
||||
var given = callCompiler(expected.getCmd, test.name, test.options,
|
||||
var given = callNimCompiler(expected.getCmd, test.name, test.options,
|
||||
nimcache, target)
|
||||
cmpMsgs(r, expected, given, test, target)
|
||||
|
||||
|
||||
33
tests/navigator/tnav1.nim
Normal file
33
tests/navigator/tnav1.nim
Normal file
@@ -0,0 +1,33 @@
|
||||
discard """
|
||||
cmd: "nim check $options --track:$file,12,7 $file"
|
||||
nimout: '''def tnav1_temp.nim(11, 10)
|
||||
usage tnav1_temp.nim(12, 8)
|
||||
'''
|
||||
"""
|
||||
|
||||
|
||||
import std / [times]
|
||||
|
||||
proc foo(x: int) =
|
||||
echo x
|
||||
|
||||
foo(3)
|
||||
echo "yes", 1 != 3
|
||||
|
||||
#!EDIT!#
|
||||
discard """
|
||||
cmd: "nim check $options --track:$file,15,2 $file"
|
||||
nimout: '''def tnav1_temp.nim(12, 6)
|
||||
usage tnav1_temp.nim(15, 1)
|
||||
'''
|
||||
"""
|
||||
|
||||
|
||||
import std / [times]
|
||||
|
||||
proc foo(x: int) =
|
||||
echo x
|
||||
|
||||
foo(3)
|
||||
echo "yes", 1 != 3
|
||||
|
||||
Reference in New Issue
Block a user