Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/tcl8.5.2/tests/lset.test @ 33

Last change on this file since 33 was 25, checked in by landauf, 17 years ago

added tcl to libs

File size: 14.5 KB
Line 
1# This file is a -*- tcl -*- test script
2
3# Commands covered: lset
4#
5# This file contains a collection of tests for one or more of the Tcl
6# built-in commands.  Sourcing this file into Tcl runs the tests and
7# generates output for errors.  No output means no errors were found.
8#
9# Copyright (c) 2001 by Kevin B. Kenny.  All rights reserved.
10#
11# See the file "license.terms" for information on usage and redistribution
12# of this file, and for a DISCLAIMER OF ALL WARRANTIES.
13#
14# RCS: @(#) $Id$
15
16if {[lsearch [namespace children] ::tcltest] == -1} {
17    package require tcltest
18    namespace import -force ::tcltest::*
19}
20
21proc failTrace {name1 name2 op} {
22    error "trace failed"
23}
24
25testConstraint testevalex [llength [info commands testevalex]]
26
27set noRead {}
28trace add variable noRead read failTrace
29set noWrite {a b c}
30trace add variable noWrite write failTrace
31
32test lset-1.1 {lset, not compiled, arg count} testevalex {
33    list [catch {testevalex lset} msg] $msg
34} "1 {wrong \# args: should be \"lset listVar index ?index...? value\"}"
35test lset-1.2 {lset, not compiled, no such var} testevalex {
36    list [catch {testevalex {lset noSuchVar 0 {}}} msg] $msg
37} "1 {can't read \"noSuchVar\": no such variable}"
38test lset-1.3 {lset, not compiled, var not readable} testevalex {
39    list [catch {testevalex {lset noRead 0 {}}} msg] $msg
40} "1 {can't read \"noRead\": trace failed}"
41
42test lset-2.1 {lset, not compiled, 3 args, second arg a plain index} testevalex {
43    set x {0 1 2}
44    list [testevalex {lset x 0 3}] $x
45} {{3 1 2} {3 1 2}}
46test lset-2.2 {lset, not compiled, 3 args, second arg neither index nor list} testevalex {
47    set x {0 1 2}
48    list [catch {
49        testevalex {lset x {{bad}1} 3}
50    } msg] $msg
51} {1 {bad index "{bad}1": must be integer?[+-]integer? or end?[+-]integer?}}
52
53test lset-3.1 {lset, not compiled, 3 args, data duplicated} testevalex {
54    set x {0 1 2}
55    list [testevalex {lset x 0 $x}] $x
56} {{{0 1 2} 1 2} {{0 1 2} 1 2}}
57test lset-3.2 {lset, not compiled, 3 args, data duplicated} testevalex {
58    set x {0 1}
59    set y $x
60    list [testevalex {lset x 0 2}] $x $y
61} {{2 1} {2 1} {0 1}}
62test lset-3.3 {lset, not compiled, 3 args, data duplicated} testevalex {
63    set x {0 1}
64    set y $x
65    list [testevalex {lset x 0 $x}] $x $y
66} {{{0 1} 1} {{0 1} 1} {0 1}}
67test lset-3.4 {lset, not compiled, 3 args, data duplicated} testevalex {
68    set x {0 1 2}
69    list [testevalex {lset x [list 0] $x}] $x
70} {{{0 1 2} 1 2} {{0 1 2} 1 2}}
71test lset-3.5 {lset, not compiled, 3 args, data duplicated} testevalex {
72    set x {0 1}
73    set y $x
74    list [testevalex {lset x [list 0] 2}] $x $y
75} {{2 1} {2 1} {0 1}}
76test lset-3.6 {lset, not compiled, 3 args, data duplicated} testevalex {
77    set x {0 1}
78    set y $x
79    list [testevalex {lset x [list 0] $x}] $x $y
80} {{{0 1} 1} {{0 1} 1} {0 1}}
81
82test lset-4.1 {lset, not compiled, 3 args, not a list} testevalex {
83    set a "x \{"
84    list [catch {
85        testevalex {lset a [list 0] y}
86    } msg] $msg
87} {1 {unmatched open brace in list}}
88test lset-4.2 {lset, not compiled, 3 args, bad index} testevalex {
89    set a {x y z}
90    list [catch {
91        testevalex {lset a [list 2a2] w}
92    } msg] $msg
93} {1 {bad index "2a2": must be integer?[+-]integer? or end?[+-]integer?}}
94test lset-4.3 {lset, not compiled, 3 args, index out of range} testevalex {
95    set a {x y z}
96    list [catch {
97        testevalex {lset a [list -1] w}
98    } msg] $msg
99} {1 {list index out of range}}
100test lset-4.4 {lset, not compiled, 3 args, index out of range} testevalex {
101    set a {x y z}
102    list [catch {
103        testevalex {lset a [list 3] w}
104    } msg] $msg
105} {1 {list index out of range}}
106test lset-4.5 {lset, not compiled, 3 args, index out of range} testevalex {
107    set a {x y z}
108    list [catch {
109        testevalex {lset a [list end--1] w}
110    } msg] $msg
111} {1 {list index out of range}}
112test lset-4.6 {lset, not compiled, 3 args, index out of range} testevalex {
113    set a {x y z}
114    list [catch {
115        testevalex {lset a [list end-3] w}
116    } msg] $msg
117} {1 {list index out of range}}
118test lset-4.7 {lset, not compiled, 3 args, not a list} testevalex {
119    set a "x \{"
120    list [catch {
121        testevalex {lset a 0 y}
122    } msg] $msg
123} {1 {unmatched open brace in list}}
124test lset-4.8 {lset, not compiled, 3 args, bad index} testevalex {
125    set a {x y z}
126    list [catch {
127        testevalex {lset a 2a2 w}
128    } msg] $msg
129} {1 {bad index "2a2": must be integer?[+-]integer? or end?[+-]integer?}}
130test lset-4.9 {lset, not compiled, 3 args, index out of range} testevalex {
131    set a {x y z}
132    list [catch {
133        testevalex {lset a -1 w}
134    } msg] $msg
135} {1 {list index out of range}}
136test lset-4.10 {lset, not compiled, 3 args, index out of range} testevalex {
137    set a {x y z}
138    list [catch {
139        testevalex {lset a 3 w}
140    } msg] $msg
141} {1 {list index out of range}}
142test lset-4.11 {lset, not compiled, 3 args, index out of range} testevalex {
143    set a {x y z}
144    list [catch {
145        testevalex {lset a end--1 w}
146    } msg] $msg
147} {1 {list index out of range}}
148test lset-4.12 {lset, not compiled, 3 args, index out of range} testevalex {
149    set a {x y z}
150    list [catch {
151        testevalex {lset a end-3 w}
152    } msg] $msg
153} {1 {list index out of range}}
154
155test lset-5.1 {lset, not compiled, 3 args, can't set variable} testevalex {
156    list [catch {
157        testevalex {lset noWrite 0 d}
158    } msg] $msg $noWrite
159} {1 {can't set "noWrite": trace failed} {d b c}}
160test lset-5.2 {lset, not compiled, 3 args, can't set variable} testevalex {
161    list [catch {
162        testevalex {lset noWrite [list 0] d}
163    } msg] $msg $noWrite
164} {1 {can't set "noWrite": trace failed} {d b c}}
165
166test lset-6.1 {lset, not compiled, 3 args, 1-d list basics} testevalex {
167    set a {x y z}
168    list [testevalex {lset a 0 a}] $a
169} {{a y z} {a y z}}
170test lset-6.2 {lset, not compiled, 3 args, 1-d list basics} testevalex {
171    set a {x y z}
172    list [testevalex {lset a [list 0] a}] $a
173} {{a y z} {a y z}}
174test lset-6.3 {lset, not compiled, 1-d list basics} testevalex {
175    set a {x y z}
176    list [testevalex {lset a 2 a}] $a
177} {{x y a} {x y a}}
178test lset-6.4 {lset, not compiled, 1-d list basics} testevalex {
179    set a {x y z}
180    list [testevalex {lset a [list 2] a}] $a
181} {{x y a} {x y a}}
182test lset-6.5 {lset, not compiled, 1-d list basics} testevalex {
183    set a {x y z}
184    list [testevalex {lset a end a}] $a
185} {{x y a} {x y a}}
186test lset-6.6 {lset, not compiled, 1-d list basics} testevalex {
187    set a {x y z}
188    list [testevalex {lset a [list end] a}] $a
189} {{x y a} {x y a}}
190test lset-6.7 {lset, not compiled, 1-d list basics} testevalex {
191    set a {x y z}
192    list [testevalex {lset a end-0 a}] $a
193} {{x y a} {x y a}}
194test lset-6.8 {lset, not compiled, 1-d list basics} testevalex {
195    set a {x y z}
196    list [testevalex {lset a [list end-0] a}] $a
197} {{x y a} {x y a}}
198test lset-6.9 {lset, not compiled, 1-d list basics} testevalex {
199    set a {x y z}
200    list [testevalex {lset a end-2 a}] $a
201} {{a y z} {a y z}}
202test lset-6.10 {lset, not compiled, 1-d list basics} testevalex {
203    set a {x y z}
204    list [testevalex {lset a [list end-2] a}] $a
205} {{a y z} {a y z}}
206
207test lset-7.1 {lset, not compiled, data sharing} testevalex {
208    set a 0
209    list [testevalex {lset a $a {gag me}}] $a
210} {{{gag me}} {{gag me}}}
211test lset-7.2 {lset, not compiled, data sharing} testevalex {
212    set a [list 0]
213    list [testevalex {lset a $a {gag me}}] $a
214} {{{gag me}} {{gag me}}}
215test lset-7.3 {lset, not compiled, data sharing} testevalex {
216    set a {x y}
217    list [testevalex {lset a 0 $a}] $a
218} {{{x y} y} {{x y} y}}
219test lset-7.4 {lset, not compiled, data sharing} testevalex {
220    set a {x y}
221    list [testevalex {lset a [list 0] $a}] $a
222} {{{x y} y} {{x y} y}}
223test lset-7.5 {lset, not compiled, data sharing} testevalex {
224    set n 0
225    set a {x y}
226    list [testevalex {lset a $n $n}] $a $n
227} {{0 y} {0 y} 0}
228test lset-7.6 {lset, not compiled, data sharing} testevalex {
229    set n [list 0]
230    set a {x y}
231    list [testevalex {lset a $n $n}] $a $n
232} {{0 y} {0 y} 0}
233test lset-7.7 {lset, not compiled, data sharing} testevalex {
234    set n 0
235    set a [list $n $n]
236    list [testevalex {lset a $n 1}] $a $n
237} {{1 0} {1 0} 0}
238test lset-7.8 {lset, not compiled, data sharing} testevalex {
239    set n [list 0]
240    set a [list $n $n]
241    list [testevalex {lset a $n 1}] $a $n
242} {{1 0} {1 0} 0}
243test lset-7.9 {lset, not compiled, data sharing} testevalex {
244    set a 0
245    list [testevalex {lset a $a $a}] $a
246} {0 0}
247test lset-7.10 {lset, not compiled, data sharing} testevalex {
248    set a [list 0]
249    list [testevalex {lset a $a $a}] $a
250} {0 0}
251
252test lset-8.1 {lset, not compiled, malformed sublist} testevalex {
253    set a [list "a \{" b]
254    list [catch {testevalex {lset a 0 1 c}} msg] $msg
255} {1 {unmatched open brace in list}}
256test lset-8.2 {lset, not compiled, malformed sublist} testevalex {
257    set a [list "a \{" b]
258    list [catch {testevalex {lset a {0 1} c}} msg] $msg
259} {1 {unmatched open brace in list}}
260test lset-8.3 {lset, not compiled, bad second index} testevalex {
261    set a {{b c} {d e}}
262    list [catch {testevalex {lset a 0 2a2 f}} msg] $msg
263} {1 {bad index "2a2": must be integer?[+-]integer? or end?[+-]integer?}}
264test lset-8.4 {lset, not compiled, bad second index} testevalex {
265    set a {{b c} {d e}}
266    list [catch {testevalex {lset a {0 2a2} f}} msg] $msg
267} {1 {bad index "2a2": must be integer?[+-]integer? or end?[+-]integer?}}
268test lset-8.5 {lset, not compiled, second index out of range} testevalex {
269    set a {{b c} {d e} {f g}}
270    list [catch {testevalex {lset a 2 -1 h}} msg] $msg
271} {1 {list index out of range}}
272test lset-8.6 {lset, not compiled, second index out of range} testevalex {
273    set a {{b c} {d e} {f g}}
274    list [catch {testevalex {lset a {2 -1} h}} msg] $msg
275} {1 {list index out of range}}
276test lset-8.7 {lset, not compiled, second index out of range} testevalex {
277    set a {{b c} {d e} {f g}}
278    list [catch {testevalex {lset a 2 2 h}} msg] $msg
279} {1 {list index out of range}}
280test lset-8.8 {lset, not compiled, second index out of range} testevalex {
281    set a {{b c} {d e} {f g}}
282    list [catch {testevalex {lset a {2 2} h}} msg] $msg
283} {1 {list index out of range}}
284test lset-8.9 {lset, not compiled, second index out of range} testevalex {
285    set a {{b c} {d e} {f g}}
286    list [catch {testevalex {lset a 2 end--1 h}} msg] $msg
287} {1 {list index out of range}}
288test lset-8.10 {lset, not compiled, second index out of range} testevalex {
289    set a {{b c} {d e} {f g}}
290    list [catch {testevalex {lset a {2 end--1} h}} msg] $msg
291} {1 {list index out of range}}
292test lset-8.11 {lset, not compiled, second index out of range} testevalex {
293    set a {{b c} {d e} {f g}}
294    list [catch {testevalex {lset a 2 end-2 h}} msg] $msg
295} {1 {list index out of range}}
296test lset-8.12 {lset, not compiled, second index out of range} testevalex {
297    set a {{b c} {d e} {f g}}
298    list [catch {testevalex {lset a {2 end-2} h}} msg] $msg
299} {1 {list index out of range}}
300
301test lset-9.1 {lset, not compiled, entire variable} testevalex {
302    set a x
303    list [testevalex {lset a y}] $a
304} {y y}
305test lset-9.2 {lset, not compiled, entire variable} testevalex {
306    set a x
307    list [testevalex {lset a {} y}] $a
308} {y y}
309
310test lset-10.1 {lset, not compiled, shared data} testevalex {
311    set row {p q}
312    set a [list $row $row]
313    list [testevalex {lset a 0 0 x}] $a
314} {{{x q} {p q}} {{x q} {p q}}}
315test lset-10.2 {lset, not compiled, shared data} testevalex {
316    set row {p q}
317    set a [list $row $row]
318    list [testevalex {lset a {0 0} x}] $a
319} {{{x q} {p q}} {{x q} {p q}}}
320test lset-10.3 {lset, not compiled, shared data, [Bug 1333036]} testevalex {
321    set a [list [list p q] [list r s]]
322    set b $a
323    list [testevalex {lset b {0 0} x}] $a
324} {{{x q} {r s}} {{p q} {r s}}}
325
326test lset-11.1 {lset, not compiled, 2-d basics} testevalex {
327    set a {{b c} {d e}}
328    list [testevalex {lset a 0 0 f}] $a
329} {{{f c} {d e}} {{f c} {d e}}}
330test lset-11.2 {lset, not compiled, 2-d basics} testevalex {
331    set a {{b c} {d e}}
332    list [testevalex {lset a {0 0} f}] $a
333} {{{f c} {d e}} {{f c} {d e}}}
334test lset-11.3 {lset, not compiled, 2-d basics} testevalex {
335    set a {{b c} {d e}}
336    list [testevalex {lset a 0 1 f}] $a
337} {{{b f} {d e}} {{b f} {d e}}}
338test lset-11.4 {lset, not compiled, 2-d basics} testevalex {
339    set a {{b c} {d e}}
340    list [testevalex {lset a {0 1} f}] $a
341} {{{b f} {d e}} {{b f} {d e}}}
342test lset-11.5 {lset, not compiled, 2-d basics} testevalex {
343    set a {{b c} {d e}}
344    list [testevalex {lset a 1 0 f}] $a
345} {{{b c} {f e}} {{b c} {f e}}}
346test lset-11.6 {lset, not compiled, 2-d basics} testevalex {
347    set a {{b c} {d e}}
348    list [testevalex {lset a {1 0} f}] $a
349} {{{b c} {f e}} {{b c} {f e}}}
350test lset-11.7 {lset, not compiled, 2-d basics} testevalex {
351    set a {{b c} {d e}}
352    list [testevalex {lset a 1 1 f}] $a
353} {{{b c} {d f}} {{b c} {d f}}}
354test lset-11.8 {lset, not compiled, 2-d basics} testevalex {
355    set a {{b c} {d e}}
356    list [testevalex {lset a {1 1} f}] $a
357} {{{b c} {d f}} {{b c} {d f}}}
358
359test lset-12.0 {lset, not compiled, typical sharing pattern} testevalex {
360    set zero 0
361    set row [list $zero $zero $zero $zero]
362    set ident [list $row $row $row $row]
363    for { set i 0 } { $i < 4 } { incr i } {
364        testevalex {lset ident $i $i 1}
365    }
366    set ident
367} {{1 0 0 0} {0 1 0 0} {0 0 1 0} {0 0 0 1}}
368
369test lset-13.0 {lset, not compiled, shimmering hell} testevalex {
370    set a 0
371    list [testevalex {lset a $a $a $a $a {gag me}}] $a
372} {{{{{{gag me}}}}} {{{{{gag me}}}}}}
373test lset-13.1 {lset, not compiled, shimmering hell} testevalex {
374    set a [list 0]
375    list [testevalex {lset a $a $a $a $a {gag me}}] $a
376} {{{{{{gag me}}}}} {{{{{gag me}}}}}}
377test lset-13.2 {lset, not compiled, shimmering hell} testevalex {
378    set a [list 0 0 0 0]
379    list [testevalex {lset a $a {gag me}}] $a
380} {{{{{{gag me}}}} 0 0 0} {{{{{gag me}}}} 0 0 0}}
381
382test lset-14.1 {lset, not compiled, list args, is string rep preserved?} testevalex {
383    set a { { 1 2 } { 3 4 } }
384    catch { testevalex {lset a {1 5} 5} }
385    list $a [lindex $a 1]
386} "{ { 1 2 } { 3 4 } } { 3 4 }"
387test lset-14.2 {lset, not compiled, flat args, is string rep preserved?} testevalex {
388    set a { { 1 2 } { 3 4 } }
389    catch { testevalex {lset a 1 5 5} }
390    list $a [lindex $a 1]
391} "{ { 1 2 } { 3 4 } } { 3 4 }"
392
393testConstraint testobj [llength [info commands testobj]]
394test lset-15.1 {lset: shared intrep [Bug 1677512]} -setup {
395    teststringobj set 1 {{1 2} 3}
396    testobj convert 1 list
397    testobj duplicate 1 2
398    variable x [teststringobj get 1]
399    variable y [teststringobj get 2]
400    testobj freeallvars
401    set l [list $y z]
402    unset y
403} -constraints testobj -body {
404    lset l 0 0 0 5
405    lindex $x 0 0
406} -cleanup {
407    unset -nocomplain x l
408} -result 1
409
410catch {unset noRead}
411catch {unset noWrite}
412catch {rename failTrace {}}
413catch {unset ::x}
414catch {unset ::y}
415
416# cleanup
417::tcltest::cleanupTests
418return
Note: See TracBrowser for help on using the repository browser.