Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 15 additions & 8 deletions src/runner.nim
Original file line number Diff line number Diff line change
Expand Up @@ -193,14 +193,21 @@ proc simplifyPathsInMessageValues(j: var JsonNode) =
simplifyPaths test["message"].str

proc writeOutput*(resultsFileName, runtimeOutput: string) =
var testResults = parseFile resultsFileName
let submissionOutput = runtimeOutput.extractSubmissionOutput

for index, test in submissionOutput.tests:
testResults["tests"][index]["output"] = test.output.newJString()

simplifyPathsInMessageValues testResults
resultsFileName.writeFile $testResults
let resultsContents = readFile resultsFileName
if resultsContents.len > 0:
try:
var testResults = parseJson resultsContents
let submissionOutput = runtimeOutput.extractSubmissionOutput

for index, test in submissionOutput.tests:
testResults["tests"][index]["output"] = test.output.newJString()

simplifyPathsInMessageValues testResults
resultsFileName.writeFile $testResults
except JsonParsingError:
writeTopLevelErrorJson(resultsFileName, runtimeOutput)
else:
writeTopLevelErrorJson(resultsFileName, runtimeOutput)

proc run*(paths: Paths): tuple[output: string, exitCode: int] =
## Compiles and runs the file in `paths.tmpTest`. Returns its exit code and
Expand Down
12 changes: 12 additions & 0 deletions tests/error/runtime_error_recursion_limit/expected_results.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
{
"version": 2,
"status": "fail",
"tests": [
{
"name": "identity function of 1",
"status": "error",
"message": "Traceback (most recent call last)\n/nim/lib/pure/unittest.nim(654) test_identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\n(1874 calls omitted) ...\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim(2) identity\nidentity.nim identity\nError: call depth limit reached in a debug build (2000 function calls). You can change it with -d:nimCallDepthLimit=<int> but really try to avoid deep recursions instead.\n",
"output": ""
}
]
}
2 changes: 2 additions & 0 deletions tests/error/runtime_error_recursion_limit/identity.nim
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
func identity*(n: int): int =
identity(n)
6 changes: 6 additions & 0 deletions tests/error/runtime_error_recursion_limit/test_identity.nim
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import std/unittest
import identity

suite "Identity Function":
test "identity function of 1":
check identity(1) == 1
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
{
"version": 2,
"status": "fail",
"tests": [
{
"name": "identity function of 1",
"status": "pass",
"output": ""
},
{
"name": "identity function of 2",
"status": "error",
"message": "Traceback (most recent call last)\n/nim/lib/pure/unittest.nim(654) test_identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\n(1874 calls omitted) ...\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim(3) identity\nidentity.nim identity\nError: call depth limit reached in a debug build (2000 function calls). You can change it with -d:nimCallDepthLimit=<int> but really try to avoid deep recursions instead.\n",
"output": ""
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
func identity*(n: int): int =
if n == 2:
identity(n)
else:
n
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import std/unittest
import identity

suite "Identity Function":
test "identity function of 1":
check identity(1) == 1

test "identity function of 2":
check identity(2) == 2

test "identity function of 3":
check identity(3) == 3