mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 00:28:26 -05:00
test infra: improve prints on failed assertions
sometimes we have several assertions with the same condition in the same test at different stages, and when these fail (the ones that print the condition text) you don't know which one it was. other assertions didn't print the condition text (variable names), just the expected and unexpected values. So now, all assertions print context line, and conditin text. besides, one of the major differences between 'assert' and 'assert_equal', is that the later is able to print the value that doesn't match the expected. if there is a rare non-reproducible failure, it is helpful to know what was the value the test encountered and how far it was from the threshold. So now, adding assert_lessthan and assert_range that can be used in some places. were we used just 'assert { a > b }' so far.
This commit is contained in:
parent
764b420f5f
commit
a0cfd519e3
@ -11,31 +11,58 @@ proc fail {msg} {
|
|||||||
|
|
||||||
proc assert {condition} {
|
proc assert {condition} {
|
||||||
if {![uplevel 1 [list expr $condition]]} {
|
if {![uplevel 1 [list expr $condition]]} {
|
||||||
error "assertion:Expected condition '$condition' to be true ([uplevel 1 [list subst -nocommands $condition]])"
|
set context "(context: [info frame -1])"
|
||||||
|
error "assertion:Expected [uplevel 1 [list subst -nocommands $condition]] $context"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc assert_no_match {pattern value} {
|
proc assert_no_match {pattern value} {
|
||||||
if {[string match $pattern $value]} {
|
if {[string match $pattern $value]} {
|
||||||
error "assertion:Expected '$value' to not match '$pattern'"
|
set context "(context: [info frame -1])"
|
||||||
|
error "assertion:Expected '$value' to not match '$pattern' $context"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc assert_match {pattern value} {
|
proc assert_match {pattern value} {
|
||||||
if {![string match $pattern $value]} {
|
if {![string match $pattern $value]} {
|
||||||
error "assertion:Expected '$value' to match '$pattern'"
|
set context "(context: [info frame -1])"
|
||||||
|
error "assertion:Expected '$value' to match '$pattern' $context"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
proc assert_equal {expected value {detail ""}} {
|
proc assert_equal {value expected {detail ""}} {
|
||||||
if {$expected ne $value} {
|
if {$expected ne $value} {
|
||||||
if {$detail ne ""} {
|
if {$detail ne ""} {
|
||||||
set detail "(detail: $detail)"
|
set detail "(detail: $detail)"
|
||||||
|
} else {
|
||||||
|
set detail "(context: [info frame -1])"
|
||||||
}
|
}
|
||||||
error "assertion:Expected '$value' to be equal to '$expected' $detail"
|
error "assertion:Expected '$value' to be equal to '$expected' $detail"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proc assert_lessthan {value expected {detail ""}} {
|
||||||
|
if {!($value < $expected)} {
|
||||||
|
if {$detail ne ""} {
|
||||||
|
set detail "(detail: $detail)"
|
||||||
|
} else {
|
||||||
|
set detail "(context: [info frame -1])"
|
||||||
|
}
|
||||||
|
error "assertion:Expected '$value' to be lessthan to '$expected' $detail"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
proc assert_range {value min max {detail ""}} {
|
||||||
|
if {!($value <= $max && $value >= $min)} {
|
||||||
|
if {$detail ne ""} {
|
||||||
|
set detail "(detail: $detail)"
|
||||||
|
} else {
|
||||||
|
set detail "(context: [info frame -1])"
|
||||||
|
}
|
||||||
|
error "assertion:Expected '$value' to be between to '$min' and '$max' $detail"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
proc assert_error {pattern code} {
|
proc assert_error {pattern code} {
|
||||||
if {[catch {uplevel 1 $code} error]} {
|
if {[catch {uplevel 1 $code} error]} {
|
||||||
assert_match $pattern $error
|
assert_match $pattern $error
|
||||||
|
Loading…
Reference in New Issue
Block a user