2021-05-17 18:35:16 +07:00
|
|
|
# Nimbus
|
|
|
|
# Copyright (c) 2021 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
|
|
|
import
|
2022-04-20 14:57:50 +07:00
|
|
|
std/[tables, strutils, times],
|
2023-09-28 13:20:12 +07:00
|
|
|
../../nimbus/utils/utils,
|
2022-04-20 14:57:50 +07:00
|
|
|
unittest2
|
2021-05-17 18:35:16 +07:00
|
|
|
|
|
|
|
export
|
2022-04-20 14:57:50 +07:00
|
|
|
tables, strutils, unittest2
|
2021-05-17 18:35:16 +07:00
|
|
|
|
2022-04-20 14:57:50 +07:00
|
|
|
type
|
|
|
|
SimStat* = object
|
|
|
|
ok*: int
|
|
|
|
skipped*: int
|
|
|
|
failed*: int
|
2022-06-17 07:53:33 +07:00
|
|
|
failingCases*: seq[string]
|
2021-06-18 08:37:59 +01:00
|
|
|
|
2022-04-20 14:57:50 +07:00
|
|
|
proc inc*(stat: var SimStat, name: string, status: TestStatus) =
|
|
|
|
echo name, ", ", status
|
|
|
|
if status == OK:
|
|
|
|
inc stat.ok
|
|
|
|
elif status == SKIPPED:
|
|
|
|
inc stat.skipped
|
|
|
|
else:
|
|
|
|
inc stat.failed
|
2022-06-17 07:53:33 +07:00
|
|
|
stat.failingCases.add name
|
2021-05-17 18:35:16 +07:00
|
|
|
|
2022-04-20 14:57:50 +07:00
|
|
|
proc `$`*(stat: SimStat): string =
|
2022-07-04 12:35:03 +07:00
|
|
|
if stat.failingCases.len > 0:
|
|
|
|
result.add " - Failing Cases:\n"
|
|
|
|
for c in stat.failingCases:
|
|
|
|
result.add " - $1 \n" % [c]
|
|
|
|
|
2023-09-30 21:31:57 +07:00
|
|
|
result.add " - ok: $1, skipped: $2, failed: $3" % [$stat.ok, $stat.skipped, $stat.failed]
|
2021-05-17 18:35:16 +07:00
|
|
|
|
2022-04-20 14:57:50 +07:00
|
|
|
proc print*(stat: SimStat, dur: Duration, name: string) =
|
|
|
|
var f = open(name & ".md", fmWrite)
|
|
|
|
f.write("* " & name)
|
|
|
|
f.write("\n")
|
2023-09-30 21:31:57 +07:00
|
|
|
f.write($stat)
|
2022-04-20 14:57:50 +07:00
|
|
|
f.write("\n")
|
2023-09-30 21:31:57 +07:00
|
|
|
f.write(" - Elapsed: " & dur.short)
|
2022-04-20 14:57:50 +07:00
|
|
|
f.write("\n")
|
|
|
|
f.close()
|