diff options
Diffstat (limited to 'tests/init.test')
-rw-r--r-- | tests/init.test | 143 |
1 files changed, 76 insertions, 67 deletions
diff --git a/tests/init.test b/tests/init.test index 2a81b52..07270e1 100644 --- a/tests/init.test +++ b/tests/init.test @@ -1,114 +1,136 @@ -# Functionality covered: this file contains a collection of tests for the auto -# loading and namespaces. +# Functionality covered: this file contains a collection of tests for the +# auto loading and namespaces. # -# Sourcing this file into Tcl runs the tests and generates output for errors. -# No output means no errors were found. +# Sourcing this file into Tcl runs the tests and generates output for +# errors. No output means no errors were found. # # Copyright (c) 1997 Sun Microsystems, Inc. # Copyright (c) 1998-1999 by Scriptics Corporation. # -# See the file "license.terms" for information on usage and redistribution of -# this file, and for a DISCLAIMER OF ALL WARRANTIES. +# See the file "license.terms" for information on usage and redistribution +# of this file, and for a DISCLAIMER OF ALL WARRANTIES. -if {"::tcltest" ni [namespace children]} { +if {[lsearch [namespace children] ::tcltest] == -1} { package require tcltest 2.3.4 namespace import -force ::tcltest::* } # Clear out any namespaces called test_ns_* catch {namespace delete {*}[namespace children :: test_ns_*]} - + # Six cases - white box testing test init-1.1 {auto_qualify - absolute cmd - namespace} { auto_qualify ::foo::bar ::blue } ::foo::bar + test init-1.2 {auto_qualify - absolute cmd - global} { auto_qualify ::global ::sub } global + test init-1.3 {auto_qualify - no colons cmd - global} { auto_qualify nocolons :: -} nocolons +} nocolons + test init-1.4 {auto_qualify - no colons cmd - namespace} { auto_qualify nocolons ::sub } {::sub::nocolons nocolons} + test init-1.5 {auto_qualify - colons in cmd - global} { auto_qualify foo::bar :: } ::foo::bar + test init-1.6 {auto_qualify - colons in cmd - namespace} { auto_qualify foo::bar ::sub } {::sub::foo::bar ::foo::bar} + # Some additional tests + test init-1.7 {auto_qualify - multiples colons 1} { auto_qualify :::foo::::bar ::blue } ::foo::bar + test init-1.8 {auto_qualify - multiple colons 2} { auto_qualify :::foo ::bar } foo -# We use a sub-interp and auto_reset and double the tests because there is 2 + +# we use a sub interp and auto_reset and double the tests because there is 2 # places where auto_loading occur (before loading the indexes files and after) set testInterp [interp create] tcltest::loadIntoSlaveInterpreter $testInterp {*}$argv interp eval $testInterp { namespace import -force ::tcltest::* - customMatch pairwise {apply {{mode pair} { - if {[llength $pair] != 2} {error "need a pair of values to check"} - string $mode [lindex $pair 0] [lindex $pair 1] - }}} - auto_reset catch {rename parray {}} -test init-2.0 {load parray - stage 1} -body { - parray -} -returnCodes error -cleanup { - rename parray {} ;# remove it, for the next test - that should not fail. -} -result {wrong # args: should be "parray a ?pattern?"} -test init-2.1 {load parray - stage 2} -body { - parray -} -returnCodes error -result {wrong # args: should be "parray a ?pattern?"} +test init-2.0 {load parray - stage 1} { + set ret [catch {parray} error] + rename parray {} ; # remove it, for the next test - that should not fail. + list $ret $error +} {1 {wrong # args: should be "parray a ?pattern?"}} + + +test init-2.1 {load parray - stage 2} { + set ret [catch {parray} error] + list $ret $error +} {1 {wrong # args: should be "parray a ?pattern?"}} + + auto_reset catch {rename ::safe::setLogCmd {}} -#unset -nocomplain auto_index(::safe::setLogCmd) auto_oldpath +#unset auto_index(::safe::setLogCmd) +#unset auto_oldpath + test init-2.2 {load ::safe::setLogCmd - stage 1} { ::safe::setLogCmd - rename ::safe::setLogCmd {} ;# should not fail + rename ::safe::setLogCmd {} ; # should not fail } {} + test init-2.3 {load ::safe::setLogCmd - stage 2} { ::safe::setLogCmd - rename ::safe::setLogCmd {} ;# should not fail + rename ::safe::setLogCmd {} ; # should not fail } {} + auto_reset catch {rename ::safe::setLogCmd {}} + test init-2.4 {load safe:::setLogCmd - stage 1} { - safe:::setLogCmd ;# intentionally 3 : - rename ::safe::setLogCmd {} ;# should not fail + safe:::setLogCmd ; # intentionally 3 : + rename ::safe::setLogCmd {} ; # should not fail } {} + test init-2.5 {load safe:::setLogCmd - stage 2} { - safe:::setLogCmd ;# intentionally 3 : - rename ::safe::setLogCmd {} ;# should not fail + safe:::setLogCmd ; # intentionally 3 : + rename ::safe::setLogCmd {} ; # should not fail } {} + auto_reset catch {rename ::safe::setLogCmd {}} + test init-2.6 {load setLogCmd from safe:: - stage 1} { - namespace eval safe setLogCmd - rename ::safe::setLogCmd {} ;# should not fail + namespace eval safe setLogCmd + rename ::safe::setLogCmd {} ; # should not fail } {} + test init-2.7 {oad setLogCmd from safe:: - stage 2} { - namespace eval safe setLogCmd - rename ::safe::setLogCmd {} ;# should not fail + namespace eval safe setLogCmd + rename ::safe::setLogCmd {} ; # should not fail } {} + + + test init-2.8 {load tcl::HistAdd} -setup { auto_reset catch {rename ::tcl::HistAdd {}} } -body { # 3 ':' on purpose - tcl:::HistAdd -} -returnCodes error -cleanup { - rename ::tcl::HistAdd {} -} -result {wrong # args: should be "tcl:::HistAdd event ?exec?"} + list [catch {tcl:::HistAdd} error] $error +} -cleanup { + rename ::tcl::HistAdd {} ; +} -result {1 {wrong # args: should be "tcl:::HistAdd command ?exec?"}} + test init-3.0 {random stuff in the auto_index, should still work} { set auto_index(foo:::bar::blah) { @@ -117,9 +139,9 @@ test init-3.0 {random stuff in the auto_index, should still work} { foo:::bar::blah } 1 -# Tests that compare the error stack trace generated when autoloading with -# that generated when no autoloading is necessary. Ideally they should be the -# same. +# Tests that compare the error stack trace generated when autoloading +# with that generated when no autoloading is necessary. Ideally they +# should be the same. set count 0 foreach arg [subst -nocommands -novariables { @@ -132,12 +154,12 @@ foreach arg [subst -nocommands -novariables { and is long enough to be truncated and " <- includes a false lead in the prune point search and must be longer still to force truncation} - {contrived example: rare circumstance + {contrived example: rare circumstance where the point at which to prune the error stack cannot be uniquely determined. foo bar foo "} - {contrived example: rare circumstance + {contrived example: rare circumstance where the point at which to prune the error stack cannot be uniquely determined. foo bar @@ -145,39 +167,30 @@ foreach arg [subst -nocommands -novariables { {argument that contains non-ASCII character, \u20ac, and which is of such great length that it will be longer than 150 bytes so it will be truncated by the Tcl C library} }] { ;# emacs needs -> " - test init-4.$count.0 {::errorInfo produced by [unknown]} -setup { + test init-4.$count.0 {::errorInfo produced by [unknown]} { auto_reset - } -body { catch {parray a b $arg} set first $::errorInfo catch {parray a b $arg} - list $first $::errorInfo - } -match pairwise -result equal - test init-4.$count.1 {::errorInfo produced by [unknown]} -setup { + set second $::errorInfo + string equal $first $second + } 1 + + test init-4.$count.1 {::errorInfo produced by [unknown]} { auto_reset - } -body { namespace eval junk [list array set $arg [list 1 2 3 4]] trace variable ::junk::$arg r \ "[list error [subst {Variable \"$arg\" is write-only}]] ;# " catch {parray ::junk::$arg} set first $::errorInfo catch {parray ::junk::$arg} - list $first $::errorInfo - } -match pairwise -result equal + set second $::errorInfo + string equal $first $second + } 1 incr count } -test init-4.$count {[Bug 46f801ed5a]} -setup { - auto_reset - array set auto_index {demo {proc demo {} {tailcall error foo}}} -} -body { - demo -} -cleanup { - array unset auto_index demo - rename demo {} -} -returnCodes error -result foo - test init-5.0 {return options passed through ::unknown} -setup { catch {rename xxx {}} set ::auto_index(::xxx) {proc ::xxx {} { @@ -189,8 +202,8 @@ test init-5.0 {return options passed through ::unknown} -setup { list $code $foo $bar $code2 $foo2 $bar2 } -cleanup { unset ::auto_index(::xxx) -} -match glob -result {2 xxx {-errorcode NONE -code 1 -level 1} 2 xxx {-code 1 -level 1 -errorcode NONE}} - +} -result {2 xxx {-errorcode NONE -code 1 -level 1} 2 xxx {-code 1 -level 1 -errorcode NONE}} + cleanupTests } ;# End of [interp eval $testInterp] @@ -199,7 +212,3 @@ interp delete $testInterp ::tcltest::cleanupTests return -# Local Variables: -# mode: tcl -# fill-column: 78 -# End: |