mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-29 17:34:43 +00:00
* ttables: smaller table, 5x speedup * thavlak: less iterations, less loops; 30% speedup * tasyncclosestall: shorter timeout; 35% speedup * gcleak4: less iterations, 2x speedup * ttimes: remove deprecated stuff * tdangerisrelease: remove cpp backend, 3x speedup * tfrexp1: smaller range, 2x speedup * trtree: fix warnings, less iterations, 6x speedup * tasyncawait_cyclebreaker: smaller swarm size; 2x speedup * trealloc: smaller number of iterations; 10x speedup * towned_binary_tree: less iterations, 4x speedup * tclosure: remove unused code, less iterations; 2x speedup * twaitany: less durations; 1.4x speedup * tasync_misc: less iterations, 2x speedup * t8535: smaller sleep, 1.5x speedup * tmanyjoin: smaller sleep, 2x speedup * t12221: shorter sleeps, removed two slower tests; 1.6x speedup * tfuturestream: smaller sleep; 1.5x speedup * growobjcrash: less iterations; 2x speedup * ttryrecv: smaller sleep; 1.5x speedup * treusetvar: less threads; 2x speedup * delete tthreadanalysis2, basically a duplicate of tthreadanalysis * t7758: less iterations, 1.5x speedup * tasyncawait: smaller swarm, less messages; 1.5x speedup * tjsandnativeasync: smaller sleep, 1.5x speedup * tpendingcheck: smaller sleep, 1.5x speedup * remove rodfiles test category * move tseq from its own category to 'collections' category * remove unneeded tests and helpers from 'assert' category * stdlib: merge tbitops2 into tbitops * remove 'trepr2' from 'stdlib' cat * merge 'tstreams' into one file * remove 'tinefficient_const_table' from 'ccbugs' cat * merge 'tcollections_to_string' into 'tcollections' * tblocking_channel: smaller sleep, small speedup * tconvexhull: less iterartions; 1.2x speedup * merge 'tdeepcopy2' into 'tdeepcopy' * merge 'tdisjoint_slice2' into 'tdisjoint_slice1' * tmissing_deepcopy: smaller sequence * tsendtwice: smaller arrays; 5x speedup * remove 'tindexerrorformatbounds' * disable multimethod tests * remove 'gc:none' and 'refc' without 'd:useRealtimeGC' from gc tests * koch.nim: bootstrap just with '-d:release', no need for 'csource' * add github workflow for documentation * testament: no need for 8 sub-second decimals
112 lines
2.6 KiB
Nim
112 lines
2.6 KiB
Nim
discard """
|
|
output: '''
|
|
`false` first assertion from bar
|
|
`false` second assertion from bar
|
|
-1
|
|
'''
|
|
"""
|
|
from strutils import endsWith
|
|
|
|
type
|
|
TLineInfo = tuple[filename: string, line: int, column: int]
|
|
TMyError = object of Exception
|
|
lineinfo: TLineInfo
|
|
EMyError = ref TMyError
|
|
|
|
|
|
# NOTE: when entering newlines, adjust `expectedEnd` outputs
|
|
|
|
try:
|
|
doAssert(false, "msg1") # doAssert test
|
|
except AssertionError as e:
|
|
assert e.msg.endsWith "tassert2.nim(20, 11) `false` msg1"
|
|
|
|
try:
|
|
assert false # assert test with no msg
|
|
except AssertionError as e:
|
|
assert e.msg.endsWith "tassert2.nim(25, 10) `false` "
|
|
|
|
try:
|
|
let a = 1
|
|
doAssert(a+a==1) # assert test with Ast expression
|
|
# BUG: const folding would make "1+1==1" appear as `false` in
|
|
# assert message
|
|
except AssertionError as e:
|
|
assert e.msg.endsWith "`a + a == 1` "
|
|
|
|
try:
|
|
let a = 1
|
|
doAssert a+a==1 # ditto with `doAssert` and no parens
|
|
except AssertionError as e:
|
|
assert e.msg.endsWith "`a + a == 1` "
|
|
|
|
proc fooStatic() =
|
|
# protect against https://github.com/nim-lang/Nim/issues/8758
|
|
static: doAssert(true)
|
|
fooStatic()
|
|
|
|
|
|
|
|
|
|
|
|
block:
|
|
# scope-wide policy to change the failed assert
|
|
# exception type in order to include a lineinfo
|
|
onFailedAssert(msg):
|
|
var e = new(TMyError)
|
|
e.msg = msg
|
|
e.lineinfo = instantiationInfo(-2)
|
|
raise e
|
|
|
|
proc foo =
|
|
assert(false, "assertion from foo")
|
|
|
|
|
|
proc bar: int =
|
|
# local overrides that are active only in this proc
|
|
onFailedAssert(msg):
|
|
echo msg[^32..^1]
|
|
|
|
assert(false, "first assertion from bar")
|
|
|
|
onFailedAssert(msg):
|
|
echo msg[^33..^1]
|
|
return -1
|
|
|
|
assert(false, "second assertion from bar")
|
|
return 10
|
|
|
|
echo(bar())
|
|
|
|
try:
|
|
foo()
|
|
except:
|
|
let e = EMyError(getCurrentException())
|
|
assert e.msg.endsWith "tassert2.nim(62, 11) `false` assertion from foo"
|
|
|
|
block: ## checks for issue https://github.com/nim-lang/Nim/issues/8518
|
|
template fun(a: string): string =
|
|
const pattern = a & a
|
|
pattern
|
|
|
|
try:
|
|
doAssert fun("foo1") == fun("foo2"), "mymsg"
|
|
except AssertionError as e:
|
|
# used to expand out the template instantiaiton, sometimes filling hundreds of lines
|
|
assert e.msg.endsWith ""
|
|
|
|
block: ## checks for issue https://github.com/nim-lang/Nim/issues/9301
|
|
try:
|
|
doAssert 1 + 1 == 3
|
|
except AssertionError as e:
|
|
# used to const fold as false
|
|
assert e.msg.endsWith "tassert2.nim(100, 14) `1 + 1 == 3` "
|
|
|
|
block: ## checks AST isn't transformed as it used to
|
|
let a = 1
|
|
try:
|
|
doAssert a > 1
|
|
except AssertionError as e:
|
|
# used to rewrite as `1 < a`
|
|
assert e.msg.endsWith "tassert2.nim(108, 14) `a > 1` "
|