jim.c: missing va_end
[jimtcl.git] / tests / event.test
bloba969f4c54f08aa34b5f2816d45b45733c0a91ee4
1 # This file contains a collection of tests for the procedures in the file
2 # tclEvent.c, which includes the "update", and "vwait" Tcl
3 # commands.  Sourcing this file into Tcl runs the tests and generates
4 # output for errors.  No output means no errors were found.
6 # Copyright (c) 1995-1997 Sun Microsystems, Inc.
7 # Copyright (c) 1998-1999 by Scriptics Corporation.
9 # See the file "license.terms" for information on usage and redistribution
10 # of this file, and for a DISCLAIMER OF ALL WARRANTIES.
12 source [file dirname [info script]]/testing.tcl
14 needs cmd after eventloop
15 testConstraint socket [expr {[info commands socket] ne ""}]
16 testConstraint exec [expr {[info commands exec] ne ""}]
17 testConstraint signal [expr {[info commands signal] ne ""}]
19 test event-5.1 {Tcl_BackgroundError, HandleBgErrors procedures} jim {
20     catch {rename bgerror {}}
21     proc bgerror msg {
22         lappend ::x $msg
23     }
24     after idle {error "a simple error"}
25     after idle {open non_existent}
26     after idle {set errorInfo foobar; set errorCode xyzzy}
27     set x {}
28     update idletasks
29     rename bgerror {}
30     set x
31 } {{a simple error} {non_existent: No such file or directory}}
33 test event-7.1 {bgerror / regular} {
34     set errRes {}
35     proc bgerror {err} {
36         global errRes;
37         set errRes $err;
38     }
39     after 0 {error err1}
40     vwait errRes;
41     set errRes;
42 } err1
44 test event-7.2 {bgerror / accumulation} {
45     set errRes {}
46     proc bgerror {err} {
47         global errRes;
48         lappend errRes $err;
49     }
50     after 0 {error err1}
51     after 0 {error err2}
52     after 0 {error err3}
53     update
54     set errRes;
55 } {err1 err2 err3}
57 test event-7.3 {bgerror / accumulation / break} {
58     set errRes {}
59     proc bgerror {err} {
60         global errRes;
61         lappend errRes $err;
62         return -code break "skip!";
63     }
64     after 0 {error err1}
65     after 0 {error err2}
66     after 0 {error err3}
67     update
68     set errRes;
69 } err1
71 # end of bgerror tests
72 catch {rename bgerror {}}
75 test event-10.1 {Tcl_Exit procedure} exec {
76     set cmd [list exec [info nameofexecutable] "<<exit 3"]
77     list [catch $cmd msg] [lindex $errorCode 0] \
78         [lindex $errorCode 2]
79 } {1 CHILDSTATUS 3}
81 test event-11.1 {Tcl_VwaitCmd procedure} {
82     list [catch {vwait} msg] $msg
83 } {1 {wrong # args: should be "vwait name"}}
84 test event-11.2 {Tcl_VwaitCmd procedure} {
85     list [catch {vwait a b} msg] $msg
86 } {1 {wrong # args: should be "vwait name"}}
87 test event-11.3 {Tcl_VwaitCmd procedure} jim {
88     catch {unset x}
89     set x 1
90     list [catch {vwait x(1)} msg] $msg
91 } {1 {can't read "x(1)": variable isn't array}}
92 test event-11.4 {Tcl_VwaitCmd procedure} {
93     foreach i [after info] {
94         after cancel $i
95     }
96     after 10; update; # On Mac make sure update won't take long
97     after 100 {set x x-done}
98     after 200 {set y y-done}
99     after 300 {set z z-done}
100     after idle {set q q-done}
101     set x before
102     set y before
103     set z before
104     set q before
105     list [vwait y] $x $y $z $q
106 } {{} x-done y-done before q-done}
108 foreach i [after info] {
109     after cancel $i
112 test event-11.5 {Tcl_VwaitCmd procedure: round robin scheduling, 2 sources} {jim socket} {
113     set f1 [open test1 w]
114     proc accept {s args} {
115         puts $s foobar
116         close $s
117     }
118     set s1 [socket stream.server 5001]
119     after 200
120     set s2 [socket stream 127.0.0.1:5001]
121     close $s1
122     set x 0
123     set y 0
124     set z 0
125     fileevent $s2 readable { incr z }
126     vwait z
127     fileevent $f1 writable { incr x; if { $y == 3 } { set z done } }
128     fileevent $s2 readable { incr y; if { $x == 3 } { set z done } }
129     vwait z
130     close $f1
131     close $s2
132     file delete test1 test2
133     list $x $y $z
134 } {3 3 done}
136 # Note: This one doesn't really require socket, but mingw32 doesn't have socket and
137 #       also doesn't allow file events (select) on non-sockets
138 test event-11.6 {Tcl_VwaitCmd procedure: round robin scheduling, same source} {socket} {
139     file delete test1 test2
140     set f1 [open test1 w]
141     set f2 [open test2 w]
142     set x 0
143     set y 0
144     set z 0
145     update
146     fileevent $f1 writable { incr x; if { $y == 3 } { set z done } }
147     fileevent $f2 writable { incr y; if { $x == 3 } { set z done } }
148     vwait z
149     close $f1
150     close $f2
151     file delete test1 test2
152     list $x $y $z
153 } {3 3 done}
156 test event-12.1 {Tcl_UpdateCmd procedure} {
157     list [catch {update a b} msg] $msg
158 } {1 {wrong # args: should be "update ?idletasks?"}}
159 test event-12.3 {Tcl_UpdateCmd procedure} {
160     foreach i [after info] {
161         after cancel $i
162     }
163     after 500 {set x after}
164     after idle {set y after}
165     after idle {set z "after, y = $y"}
166     set x before
167     set y before
168     set z before
169     update idletasks
170     list $x $y $z
171 } {before after {after, y = after}}
172 test event-12.4 {Tcl_UpdateCmd procedure} {
173     foreach i [after info] {
174         after cancel $i
175     }
176     after 10; update; # On Mac make sure update won't take long
177     after 200 {set x x-done}
178     after 400 {set y y-done}
179     after idle {set z z-done}
180     set x before
181     set y before
182     set z before
183     after 300
184     update
185     list $x $y $z
186 } {x-done before z-done}
188 # cleanup
189 foreach i [after info] {
190     after cancel $i
193 test event-13.1 "vwait/signal" signal {
194     signal handle ALRM
195     list [catch -signal {
196         alarm 0.1
197         # This is just to prevent the vwait from exiting immediately
198         stdin readable { format test }
199         vwait forever
200     } msg] $msg
201 } {5 SIGALRM}
203 testreport