os/persistentdata/persistentstorage/sqlite3api/TEST/TCL/tcldistribution/tests/timer.test
First public contribution.
1 # This file contains a collection of tests for the procedures in the
2 # file tclTimer.c, which includes the "after" Tcl command. Sourcing
3 # this file into Tcl runs the tests and generates output for errors.
4 # No output means no errors were found.
6 # This file contains a collection of tests for one or more of the Tcl
7 # built-in commands. Sourcing this file into Tcl runs the tests and
8 # generates output for errors. No output means no errors were found.
10 # Copyright (c) 1997 by Sun Microsystems, Inc.
11 # Copyright (c) 1998-1999 by Scriptics Corporation.
13 # See the file "license.terms" for information on usage and redistribution
14 # of this file, and for a DISCLAIMER OF ALL WARRANTIES.
16 # RCS: @(#) $Id: timer.test,v 1.7.22.2 2005/11/09 21:46:20 kennykb Exp $
18 if {[lsearch [namespace children] ::tcltest] == -1} {
19 package require tcltest 2
20 namespace import -force ::tcltest::*
23 test timer-1.1 {Tcl_CreateTimerHandler procedure} {
24 foreach i [after info] {
28 foreach i {100 200 1000 50 150} {
36 test timer-2.1 {Tcl_DeleteTimerHandler procedure} {
37 foreach i [after info] {
41 foreach i {100 200 300 50 150} {
44 after cancel lappend x 150
45 after cancel lappend x 50
51 # No tests for Tcl_ServiceTimer or ResetTimer, since it is already tested
54 test timer-3.1 {TimerHandlerEventProc procedure: event masks} {
56 after 100 { set x fired }
63 test timer-3.2 {TimerHandlerEventProc procedure: multiple timers} {
64 foreach i [after info] {
67 foreach i {200 600 1000} {
81 } {200 {200 600} {200 600 1000}}
82 test timer-3.3 {TimerHandlerEventProc procedure: reentrant timer deletion} {
83 foreach i [after info] {
87 after 100 lappend x 100
88 set i [after 300 lappend x 300]
89 after 200 after cancel $i
94 test timer-3.4 {TimerHandlerEventProc procedure: all expired timers fire} {
95 foreach i [after info] {
100 after 200 lappend x b
101 after 300 lappend x c
106 test timer-3.5 {TimerHandlerEventProc procedure: reentrantly added timers don't fire} {
107 foreach i [after info] {
111 after 100 {lappend x a; after 0 lappend x b}
116 test timer-3.6 {TimerHandlerEventProc procedure: reentrantly added timers don't fire} {
117 foreach i [after info] {
121 after 100 {lappend x a; after 100 lappend x b; after 100}
129 # No tests for Tcl_DoWhenIdle: it's already tested by other tests
132 test timer-4.1 {Tcl_CancelIdleCall procedure} {
133 foreach i [after info] {
139 after idle set x after1
140 after idle set y after2
141 after idle set z after3
142 after cancel set y after2
145 } {after1 before after3}
146 test timer-4.2 {Tcl_CancelIdleCall procedure} {
147 foreach i [after info] {
153 after idle set x after1
154 after idle set y after2
155 after idle set z after3
156 after cancel set x after1
159 } {before after2 after3}
161 test timer-5.1 {Tcl_ServiceIdle, self-rescheduling handlers} {
162 foreach i [after info] {
167 after idle {incr x; after idle {incr x; after idle {incr x}}}
175 test timer-6.1 {Tcl_AfterCmd procedure, basics} {
176 list [catch {after} msg] $msg
177 } {1 {wrong # args: should be "after option ?arg arg ...?"}}
178 test timer-6.2 {Tcl_AfterCmd procedure, basics} {
179 list [catch {after 2x} msg] $msg
180 } {1 {expected integer but got "2x"}}
181 test timer-6.3 {Tcl_AfterCmd procedure, basics} {
182 list [catch {after gorp} msg] $msg
183 } {1 {bad argument "gorp": must be cancel, idle, info, or a number}}
184 test timer-6.4 {Tcl_AfterCmd procedure, ms argument} {
186 after 400 {set x after}
194 test timer-6.5 {Tcl_AfterCmd procedure, ms argument} {
196 after 300 set x after
204 test timer-6.6 {Tcl_AfterCmd procedure, cancel option} {
205 list [catch {after cancel} msg] $msg
206 } {1 {wrong # args: should be "after cancel id|command"}}
207 test timer-6.7 {Tcl_AfterCmd procedure, cancel option} {
210 test timer-6.8 {Tcl_AfterCmd procedure, cancel option} {
211 after cancel {foo bar}
213 test timer-6.9 {Tcl_AfterCmd procedure, cancel option} {
214 foreach i [after info] {
218 set y [after 100 set x after]
224 test timer-6.10 {Tcl_AfterCmd procedure, cancel option} {
225 foreach i [after info] {
229 after 100 set x after
230 after cancel {set x after}
235 test timer-6.11 {Tcl_AfterCmd procedure, cancel option} {
236 foreach i [after info] {
240 after 100 set x after
241 set id [after 300 set x after]
251 test timer-6.12 {Tcl_AfterCmd procedure, cancel option} {
252 foreach i [after info] {
256 after idle lappend x second
257 after idle lappend x third
258 set i [after idle lappend x fourth]
259 after cancel {lappend x second}
264 test timer-6.13 {Tcl_AfterCmd procedure, cancel option, multiple arguments for command} {
265 foreach i [after info] {
269 after idle lappend x second
270 after idle lappend x third
271 set i [after idle lappend x fourth]
272 after cancel lappend x second
277 test timer-6.14 {Tcl_AfterCmd procedure, cancel option, cancel during handler, used to dump core} {
278 foreach i [after info] {
289 test timer-6.15 {Tcl_AfterCmd procedure, cancel option, multiple interps} {
290 foreach i [after info] {
294 x eval {set a before; set b before; after idle {set a a-after};
295 after idle {set b b-after}}
296 set result [llength [x eval after info]]
297 lappend result [llength [after info]]
298 after cancel {set b b-after}
301 x eval {after cancel set a a-after}
303 lappend result $a $b [x eval {list $a $b}]
306 } {2 0 aaa bbb {before b-after}}
307 test timer-6.16 {Tcl_AfterCmd procedure, idle option} {
308 list [catch {after idle} msg] $msg
309 } {1 {wrong # args: should be "after idle script script ..."}}
310 test timer-6.17 {Tcl_AfterCmd procedure, idle option} {
312 after idle {set x after}
317 test timer-6.18 {Tcl_AfterCmd procedure, idle option} {
319 after idle set x after
324 set event1 [after idle event 1]
325 set event2 [after 1000 event 2]
327 set childEvent [x eval {after idle event in child}]
328 test timer-6.19 {Tcl_AfterCmd, info option} {
330 } [lsort "$event1 $event2"]
331 test timer-6.20 {Tcl_AfterCmd, info option} {
332 list [catch {after info a b} msg] $msg
333 } {1 {wrong # args: should be "after info ?id?"}}
334 test timer-6.21 {Tcl_AfterCmd, info option} {
335 list [catch {after info $childEvent} msg] $msg
336 } "1 {event \"$childEvent\" doesn't exist}"
337 test timer-6.22 {Tcl_AfterCmd, info option} {
338 list [after info $event1] [after info $event2]
339 } {{{event 1} idle} {{event 2} timer}}
345 test timer-6.23 {Tcl_AfterCmd procedure, no option, script with NULL} {
346 foreach i [after info] {
350 after 1 "set x ab\0cd"
355 test timer-6.24 {Tcl_AfterCmd procedure, no option, script with NULL} {
356 foreach i [after info] {
365 test timer-6.25 {Tcl_AfterCmd procedure, cancel option, script with NULL} {
366 foreach i [after info] {
371 after cancel "set x ab\0ef"
372 set x [llength [after info]]
373 foreach i [after info] {
378 test timer-6.26 {Tcl_AfterCmd procedure, cancel option, script with NULL} {
379 foreach i [after info] {
384 after cancel set x ab\0ef
385 set y [llength [after info]]
386 foreach i [after info] {
391 test timer-6.27 {Tcl_AfterCmd procedure, idle option, script with NULL} {
392 foreach i [after info] {
396 after idle "set x ab\0cd"
400 test timer-6.28 {Tcl_AfterCmd procedure, idle option, script with NULL} {
401 foreach i [after info] {
405 after idle set x ab\0cd
409 test timer-6.29 {Tcl_AfterCmd procedure, info option, script with NULL} {
410 foreach i [after info] {
415 set id [after 10 set x ab\0cd]
417 set y [string length [lindex [lindex [after info $id] 0] 2]]
418 foreach i [after info] {
424 set event [after idle foo bar]
425 scan $event after#%d id
427 test timer-7.1 {GetAfterEvent procedure} {
428 list [catch {after info xfter#$id} msg] $msg
429 } "1 {event \"xfter#$id\" doesn't exist}"
430 test timer-7.2 {GetAfterEvent procedure} {
431 list [catch {after info afterx$id} msg] $msg
432 } "1 {event \"afterx$id\" doesn't exist}"
433 test timer-7.3 {GetAfterEvent procedure} {
434 list [catch {after info after#ab} msg] $msg
435 } {1 {event "after#ab" doesn't exist}}
436 test timer-7.4 {GetAfterEvent procedure} {
437 list [catch {after info after#} msg] $msg
438 } {1 {event "after#" doesn't exist}}
439 test timer-7.5 {GetAfterEvent procedure} {
440 list [catch {after info after#${id}x} msg] $msg
441 } "1 {event \"after#${id}x\" doesn't exist}"
442 test timer-7.6 {GetAfterEvent procedure} {
443 list [catch {after info afterx[expr $id+1]} msg] $msg
444 } "1 {event \"afterx[expr $id+1]\" doesn't exist}"
447 test timer-8.1 {AfterProc procedure} {
451 after 100 {set x after}
458 test timer-8.2 {AfterProc procedure} {
459 catch {rename bgerror {}}
462 set x [list $msg $errorInfo]
465 after 100 {error "After error"}
469 catch {rename bgerror {}}
471 } {empty {{After error} {After error
473 "error "After error""
475 test timer-8.3 {AfterProc procedure, deleting handler from itself} {
476 foreach i [after info] {
482 foreach i [after info] {
483 lappend x [after info $i]
488 after 1000 {error "I shouldn't ever have executed"}
491 } {{{error "I shouldn't ever have executed"} timer}}
492 test timer-8.4 {AfterProc procedure, deleting handler from itself} {
493 foreach i [after info] {
499 foreach i [after info] {
500 lappend x [after info $i]
504 after 1000 {error "I shouldn't ever have executed"}
508 } {{{error "I shouldn't ever have executed"} timer}}
510 foreach i [after info] {
514 # No test for FreeAfterPtr, since it is already tested above.
517 test timer-9.1 {AfterCleanupProc procedure} {
518 catch {interp delete x}
522 puts "part 1: this message should not appear"
524 after 200 {lappend x after2}
527 puts "part 2: this message should not appear"
529 after 200 {lappend x after4}
532 puts "part 3: this message should not appear"
539 } {before after2 after4}
540 test timer-10.1 {Bug 1016167: [after] overwrites imports} -setup {
542 slave eval namespace export after
543 slave eval namespace eval foo namespace import ::after
545 slave eval foo::after 1
546 slave eval namespace origin foo::after
548 # Bug will cause crash here; would cause failure otherwise
552 test timer-11.2 {Bug 1350293: [after] negative argument} \
555 after 100 {lappend l 100; set done 1}
556 after -1 {lappend l -1}
563 ::tcltest::cleanupTests