diff options
Diffstat (limited to 'tests/indexObj.test')
-rw-r--r-- | tests/indexObj.test | 71 |
1 files changed, 35 insertions, 36 deletions
diff --git a/tests/indexObj.test b/tests/indexObj.test index 414901f..bff20a2 100644 --- a/tests/indexObj.test +++ b/tests/indexObj.test @@ -13,66 +13,61 @@ if {[lsearch [namespace children] ::tcltest] == -1} { namespace import -force ::tcltest::* } -if {[info commands testindexobj] == {}} { - puts "This application hasn't been compiled with the \"testindexobj\"" - puts "command, so I can't test Tcl_GetIndexFromObj etc." - ::tcltest::cleanupTests - return -} +testConstraint testindexobj [llength [info commands testindexobj]] -test indexObj-1.1 {exact match} { +test indexObj-1.1 {exact match} testindexobj { testindexobj 1 1 xyz abc def xyz alm } {2} -test indexObj-1.2 {exact match} { +test indexObj-1.2 {exact match} testindexobj { testindexobj 1 1 abc abc def xyz alm } {0} -test indexObj-1.3 {exact match} { +test indexObj-1.3 {exact match} testindexobj { testindexobj 1 1 alm abc def xyz alm } {3} -test indexObj-1.4 {unique abbreviation} { +test indexObj-1.4 {unique abbreviation} testindexobj { testindexobj 1 1 xy abc def xalb xyz alm } {3} -test indexObj-1.5 {multiple abbreviations and exact match} { +test indexObj-1.5 {multiple abbreviations and exact match} testindexobj { testindexobj 1 1 x abc def xalb xyz alm x } {5} -test indexObj-1.6 {forced exact match} { +test indexObj-1.6 {forced exact match} testindexobj { testindexobj 1 0 xy abc def xalb xy alm } {3} -test indexObj-1.7 {forced exact match} { +test indexObj-1.7 {forced exact match} testindexobj { testindexobj 1 0 x abc def xalb xyz alm x } {5} -test indexObj-1.8 {exact match of empty values} { +test indexObj-1.8 {exact match of empty values} testindexobj { testindexobj 1 1 {} a aa aaa {} b bb bbb } 3 -test indexObj-1.9 {exact match of empty values} { +test indexObj-1.9 {exact match of empty values} testindexobj { testindexobj 1 0 {} a aa aaa {} b bb bbb } 3 -test indexObj-2.1 {no match} { +test indexObj-2.1 {no match} testindexobj { list [catch {testindexobj 1 1 dddd abc def xalb xyz alm x} msg] $msg } {1 {bad token "dddd": must be abc, def, xalb, xyz, alm, or x}} -test indexObj-2.2 {no match} { +test indexObj-2.2 {no match} testindexobj { list [catch {testindexobj 1 1 dddd abc} msg] $msg } {1 {bad token "dddd": must be abc}} -test indexObj-2.3 {no match: no abbreviations} { +test indexObj-2.3 {no match: no abbreviations} testindexobj { list [catch {testindexobj 1 0 xy abc def xalb xyz alm} msg] $msg } {1 {bad token "xy": must be abc, def, xalb, xyz, or alm}} -test indexObj-2.4 {ambiguous value} { +test indexObj-2.4 {ambiguous value} testindexobj { list [catch {testindexobj 1 1 d dumb daughter a c} msg] $msg } {1 {ambiguous token "d": must be dumb, daughter, a, or c}} -test indexObj-2.5 {omit error message} { +test indexObj-2.5 {omit error message} testindexobj { list [catch {testindexobj 0 1 d x} msg] $msg } {1 {}} -test indexObj-2.6 {TCL_EXACT => no "ambiguous" error message} { +test indexObj-2.6 {TCL_EXACT => no "ambiguous" error message} testindexobj { list [catch {testindexobj 1 0 d dumb daughter a c} msg] $msg } {1 {bad token "d": must be dumb, daughter, a, or c}} -test indexObj-2.7 {exact match of empty values} { +test indexObj-2.7 {exact match of empty values} testindexobj { list [catch {testindexobj 1 1 {} a b c} msg] $msg } {1 {ambiguous token "": must be a, b, or c}} -test indexObj-2.8 {exact match of empty values: singleton case} { +test indexObj-2.8 {exact match of empty values: singleton case} testindexobj { list [catch {testindexobj 1 0 {} a} msg] $msg } {1 {bad token "": must be a}} -test indexObj-2.9 {non-exact match of empty values: singleton case} { +test indexObj-2.9 {non-exact match of empty values: singleton case} testindexobj { # NOTE this is a special case. Although the empty string is a # unique prefix, we have an established history of rejecting # empty lookup keys, requiring any unique prefix match to have @@ -80,32 +75,32 @@ test indexObj-2.9 {non-exact match of empty values: singleton case} { list [catch {testindexobj 1 1 {} a} msg] $msg } {1 {bad token "": must be a}} -test indexObj-3.1 {cache result to skip next lookup} { +test indexObj-3.1 {cache result to skip next lookup} testindexobj { testindexobj check 42 } {42} -test indexObj-4.1 {free old internal representation} { +test indexObj-4.1 {free old internal representation} testindexobj { set x {a b} lindex $x 1 testindexobj 1 1 $x abc def {a b} zzz } {2} -test indexObj-5.1 {Tcl_WrongNumArgs} { +test indexObj-5.1 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 1 "?option?" mycmd } "wrong # args: should be \"mycmd ?option?\"" -test indexObj-5.2 {Tcl_WrongNumArgs} { +test indexObj-5.2 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 2 "bar" mycmd foo } "wrong # args: should be \"mycmd foo bar\"" -test indexObj-5.3 {Tcl_WrongNumArgs} { +test indexObj-5.3 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 0 "bar" mycmd foo } "wrong # args: should be \"bar\"" -test indexObj-5.4 {Tcl_WrongNumArgs} { +test indexObj-5.4 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 0 "" mycmd foo } "wrong # args: should be \"\"" -test indexObj-5.5 {Tcl_WrongNumArgs} { +test indexObj-5.5 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 1 "" mycmd foo } "wrong # args: should be \"mycmd\"" -test indexObj-5.6 {Tcl_WrongNumArgs} { +test indexObj-5.6 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 2 "" mycmd foo } "wrong # args: should be \"mycmd foo\"" # Contrast this with test proc-3.6; they have to be like this because @@ -114,20 +109,20 @@ test indexObj-5.7 {Tcl_WrongNumArgs} testindexobj { testwrongnumargs 2 "fee fi" "fo fum" foo bar } "wrong # args: should be \"fo fum foo fee fi\"" -test indexObj-6.1 {Tcl_GetIndexFromObjStruct} { +test indexObj-6.1 {Tcl_GetIndexFromObjStruct} testindexobj { set x a testgetindexfromobjstruct $x 0 } "wrong # args: should be \"testgetindexfromobjstruct a 0\"" -test indexObj-6.2 {Tcl_GetIndexFromObjStruct} { +test indexObj-6.2 {Tcl_GetIndexFromObjStruct} testindexobj { set x a testgetindexfromobjstruct $x 0 testgetindexfromobjstruct $x 0 } "wrong # args: should be \"testgetindexfromobjstruct a 0\"" -test indexObj-6.3 {Tcl_GetIndexFromObjStruct} { +test indexObj-6.3 {Tcl_GetIndexFromObjStruct} testindexobj { set x c testgetindexfromobjstruct $x 1 } "wrong # args: should be \"testgetindexfromobjstruct c 1\"" -test indexObj-6.4 {Tcl_GetIndexFromObjStruct} { +test indexObj-6.4 {Tcl_GetIndexFromObjStruct} testindexobj { set x c testgetindexfromobjstruct $x 1 testgetindexfromobjstruct $x 1 @@ -136,3 +131,7 @@ test indexObj-6.4 {Tcl_GetIndexFromObjStruct} { # cleanup ::tcltest::cleanupTests return + +# Local Variables: +# mode: tcl +# End: |