X-Git-Url: https://git.saurik.com/redis.git/blobdiff_plain/08b59207509ffe2c6938f7051ea786c66e7fa09d..f858c11d7d9ca79010dd46a9c8c625e63a9a3ec0:/tests/support/test.tcl diff --git a/tests/support/test.tcl b/tests/support/test.tcl index 988189bf..153ba1e3 100644 --- a/tests/support/test.tcl +++ b/tests/support/test.tcl @@ -1,41 +1,50 @@ -set ::passed 0 -set ::failed 0 -set ::testnum 0 +set ::num_tests 0 +set ::num_passed 0 +set ::num_failed 0 +set ::tests_failed {} + +proc assert {condition} { + if {![uplevel 1 expr $condition]} { + error "assertion:Expected '$value' to be true" + } +} proc assert_match {pattern value} { if {![string match $pattern $value]} { - puts "!! ERROR\nExpected '$value' to match '$pattern'" - error "assertion" + error "assertion:Expected '$value' to match '$pattern'" } } proc assert_equal {expected value} { if {$expected ne $value} { - puts "!! ERROR\nExpected '$value' to be equal to '$expected'" - error "assertion" + error "assertion:Expected '$value' to be equal to '$expected'" } } proc assert_error {pattern code} { - if {[catch $code error]} { + if {[catch {uplevel 1 $code} error]} { assert_match $pattern $error } else { - puts "!! ERROR\nExpected an error but nothing was catched" - error "assertion" + error "assertion:Expected an error but nothing was catched" } } proc assert_encoding {enc key} { - # swapped out value doesn't have encoding, so swap in first - r debug swapin $key - assert_match "* encoding:$enc *" [r debug object $key] + # Swapped out values don't have an encoding, so make sure that + # the value is swapped in before checking the encoding. + set dbg [r debug object $key] + while {[string match "* swapped at:*" $dbg]} { + r debug swapin $key + set dbg [r debug object $key] + } + assert_match "* encoding:$enc *" $dbg } proc assert_type {type key} { assert_equal $type [r type $key] } -proc test {name code {okpattern notspecified}} { +proc test {name code {okpattern undefined}} { # abort if tagged with a tag to deny foreach tag $::denytags { if {[lsearch $::tags $tag] >= 0} { @@ -57,29 +66,63 @@ proc test {name code {okpattern notspecified}} { } } - incr ::testnum - puts -nonewline [format "#%03d %-68s " $::testnum $name] - flush stdout + incr ::num_tests + set details {} + lappend details $::curfile + lappend details $::tags + lappend details $name + + if {$::verbose} { + puts -nonewline [format "#%03d %-68s " $::num_tests $name] + flush stdout + } + if {[catch {set retval [uplevel 1 $code]} error]} { - if {$error eq "assertion"} { - incr ::failed + if {[string match "assertion:*" $error]} { + set msg [string range $error 10 end] + lappend details $msg + lappend ::tests_failed $details + + incr ::num_failed + if {$::verbose} { + puts "FAILED" + puts "$msg\n" + } else { + puts -nonewline "F" + } } else { - puts "EXCEPTION" - puts "\nCaught error: $error" - error "exception" + # Re-raise, let handler up the stack take care of this. + error $error $::errorInfo } } else { - if {$okpattern eq "notspecified" || $okpattern eq $retval || [string match $okpattern $retval]} { - puts "PASSED" - incr ::passed + if {$okpattern eq "undefined" || $okpattern eq $retval || [string match $okpattern $retval]} { + incr ::num_passed + if {$::verbose} { + puts "PASSED" + } else { + puts -nonewline "." + } } else { - puts "!! ERROR expected\n'$okpattern'\nbut got\n'$retval'" - incr ::failed + set msg "Expected '$okpattern' to equal or match '$retval'" + lappend details $msg + lappend ::tests_failed $details + + incr ::num_failed + if {$::verbose} { + puts "FAILED" + puts "$msg\n" + } else { + puts -nonewline "F" + } } } + flush stdout + if {$::traceleaks} { - if {![string match {*0 leaks*} [exec leaks redis-server]]} { - puts "--------- Test $::testnum LEAKED! --------" + set output [exec leaks redis-server] + if {![string match {*0 leaks*} $output]} { + puts "--- Test \"$name\" leaked! ---" + puts $output exit 1 } }