summary refs log tree commit diff stats
path: root/tests/stdlib/tstackframes.nim
blob: 618ff7b9213b11971e209dbd377b3930ad526ca1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
import std/[strformat,os,osproc]
import stdtest/unittest_light

proc main(opt: string, expected: string) =
  const nim = getCurrentCompilerExe()
  const file = currentSourcePath().parentDir / "mstackframes.nim"
  let cmd = fmt"{nim} c -r --excessiveStackTrace:off --stacktraceMsgs:{opt} --hints:off {file}"
  let (output, exitCode) = execCmdEx(cmd)
  assertEquals output, expected
  doAssert exitCode == 0

main("on"): """
mstackframes.nim(38)     mstackframes
mstackframes.nim(29)     main
  z: 0
  z: 1
mstackframes.nim(20)     main2 ("main2", 5, 1)
mstackframes.nim(20)     main2 ("main2", 4, 2)
mstackframes.nim(20)     main2 ("main2", 3, 3)
mstackframes.nim(19)     main2 ("main2", 2, 4)
mstackframes.nim(18)     bar ("bar ",)

"""

main("off"): """
mstackframes.nim(38)     mstackframes
mstackframes.nim(29)     main
mstackframes.nim(20)     main2
mstackframes.nim(20)     main2
mstackframes.nim(20)     main2
mstackframes.nim(19)     main2
mstackframes.nim(18)     bar

"""