~ubuntu-branches/ubuntu/hardy/uim/hardy

« back to all changes in this revision

Viewing changes to sigscheme/test/test-assoc.scm

  • Committer: Bazaar Package Importer
  • Author(s): Masahito Omote
  • Date: 2007-04-21 03:46:09 UTC
  • mfrom: (1.1.6 upstream)
  • Revision ID: james.westby@ubuntu.com-20070421034609-gpcurkutp8vaysqj
Tags: 1:1.4.1-3
* Switch to dh_gtkmodules for the gtk 2.10 transition (Closes:
  #419318)
  - debian/control: Add ${misc:Depends} and remove libgtk2.0-bin on
    uim-gtk2.0.
  - debian/uim-gtk2.0.post{inst,rm}: Removed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
;;  Filename : test-assoc.scm
 
2
;;  About    : unit tests for assq, assv, assoc
 
3
;;
 
4
;;  Copyright (C) 2006 YAMAMOTO Kengo <yamaken AT bp.iij4u.or.jp>
 
5
;;  Copyright (c) 2007 SigScheme Project <uim AT freedesktop.org>
 
6
;;
 
7
;;  All rights reserved.
 
8
;;
 
9
;;  Redistribution and use in source and binary forms, with or without
 
10
;;  modification, are permitted provided that the following conditions
 
11
;;  are met:
 
12
;;
 
13
;;  1. Redistributions of source code must retain the above copyright
 
14
;;     notice, this list of conditions and the following disclaimer.
 
15
;;  2. Redistributions in binary form must reproduce the above copyright
 
16
;;     notice, this list of conditions and the following disclaimer in the
 
17
;;     documentation and/or other materials provided with the distribution.
 
18
;;  3. Neither the name of authors nor the names of its contributors
 
19
;;     may be used to endorse or promote products derived from this software
 
20
;;     without specific prior written permission.
 
21
;;
 
22
;;  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS
 
23
;;  IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 
24
;;  THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 
25
;;  PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR
 
26
;;  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 
27
;;  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 
28
;;  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 
29
;;  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 
30
;;  LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 
31
;;  NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 
32
;;  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
33
 
 
34
(load "./test/unittest.scm")
 
35
 
 
36
(define tn test-name)
 
37
 
 
38
(define elm0 (lambda () #f))
 
39
(define elm1 (lambda () #f))
 
40
(define elm2 (lambda () #f))
 
41
(define elm3 (lambda () #f))
 
42
(define nil  '())
 
43
(define cdr3 (cons (cons elm3 3) nil))
 
44
(define cdr2 (cons (cons elm2 2) cdr3))
 
45
(define cdr1 (cons (cons elm1 1) cdr2))
 
46
(define cdr0 (cons (cons elm0 0) cdr1))
 
47
(define alist cdr0)
 
48
 
 
49
;; Remake char object to avoid constant optimization. If the implementation
 
50
;; does not have neither immediate char nor preallocated char objects, (eq? c
 
51
;; (char c)) will be false.
 
52
(define char
 
53
  (lambda (c)
 
54
    (integer->char (char->integer c))))
 
55
 
 
56
;;
 
57
;; assq
 
58
;;
 
59
 
 
60
(tn "assq symbols")
 
61
(assert-error  (tn) (lambda () (assq 'a '(a))))
 
62
(assert-error  (tn) (lambda () (assq 'a '((A . 0) a))))
 
63
(assert-false  (tn)            (assq 'a '()))
 
64
(assert-equal? (tn) '(a . 0)   (assq 'a '((a . 0))))
 
65
(assert-false  (tn)            (assq 'b '((a . 0))))
 
66
(assert-equal? (tn) '(A . 0)   (assq 'A '((A . 0) (a . 1) (b . 2))))
 
67
(assert-equal? (tn) '(a . 1)   (assq 'a '((A . 0) (a . 1) (b . 2))))
 
68
(assert-equal? (tn) '(b . 2)   (assq 'b '((A . 0) (a . 1) (b . 2))))
 
69
(assert-false  (tn)            (assq 'c '((A . 0) (a . 1) (b . 2))))
 
70
(tn "assq builtin procedures")
 
71
(assert-false  (tn)            (assq + (list)))
 
72
(assert-equal? (tn) (cons + 0) (assq + (list (cons + 0))))
 
73
(assert-false  (tn)            (assq - (list (cons + 0))))
 
74
(assert-equal? (tn) (cons + 0) (assq + (list (cons + 0) (cons - 1) (cons * 2))))
 
75
(assert-equal? (tn) (cons - 1) (assq - (list (cons + 0) (cons - 1) (cons * 2))))
 
76
(assert-equal? (tn) (cons * 2) (assq * (list (cons + 0) (cons - 1) (cons * 2))))
 
77
(assert-false  (tn)            (assq / (list (cons + 0) (cons - 1) (cons * 2))))
 
78
(tn "assq closures")
 
79
(assert-equal? (tn) (car cdr3) (assq elm3 alist))
 
80
(assert-equal? (tn) (car cdr2) (assq elm2 alist))
 
81
(assert-equal? (tn) (car cdr1) (assq elm1 alist))
 
82
(assert-equal? (tn) (car cdr0) (assq elm0 alist))
 
83
(assert-false  (tn)            (assq (lambda() #f) alist))
 
84
(tn "assq strings with non-constant key")
 
85
;; These tests assume that (string #\a) is not optimized as constant string.
 
86
(assert-false  (tn) (assq (string #\a) '()))
 
87
(assert-false  (tn) (assq (string #\a) '(("a" . a))))
 
88
(assert-false  (tn) (assq (string #\b) '(("a" . a))))
 
89
(assert-false  (tn) (assq (string #\a) '(("a" . a) ("b" . b) ("c" . c))))
 
90
(assert-false  (tn) (assq (string #\b) '(("a" . a) ("b" . b) ("c" . c))))
 
91
(assert-false  (tn) (assq (string #\c) '(("a" . a) ("b" . b) ("c" . c))))
 
92
(assert-false  (tn) (assq (string #\d) '(("a" . a) ("b" . b) ("c" . c))))
 
93
(tn "assq lists with non-constant key")
 
94
;; These tests assume that the keys are not optimized as constant object.
 
95
(assert-false  (tn) (assq (list (string #\a)) '()))
 
96
(assert-false  (tn) (assq (list (string #\a)) '((("a") . a))))
 
97
(assert-false  (tn) (assq (list (string #\b)) '((("a") . a))))
 
98
(assert-false  (tn) (assq (list (string #\a))
 
99
                          '((("a") . a) (("b") . b) (("c") . c))))
 
100
(assert-false  (tn) (assq (list (string #\b))
 
101
                          '((("a") . a) (("b") . b) (("c") . c))))
 
102
(assert-false  (tn) (assq (list (string #\c))
 
103
                          '((("a") . a) (("b") . b) (("c") . c))))
 
104
(assert-false  (tn) (assq (list (string #\d))
 
105
                          '((("a") . a) (("b") . b) (("c") . c))))
 
106
(assert-false  (tn) (assq (list (string #\a #\B #\c)
 
107
                                (list (string #\d) (list (string #\e))))
 
108
                          '((("aBc" ("d" ("E"))) 0)
 
109
                            (("aBc" ("d" ("e"))) 1)
 
110
                            ("f")
 
111
                            ("g"))))
 
112
 
 
113
(tn "assq improper lists: symbols")
 
114
(assert-error  (tn) (lambda () (assq 'a 'a)))
 
115
(assert-equal? (tn) '(a . 1)   (assq 'a '((A . 0) (a . 1) (b . 2) . 3)))
 
116
(assert-error  (tn) (lambda () (assq 'c '((A . 0) (a . 1) (b . 2) . 3))))
 
117
(tn "assq improper lists: builtin procedures")
 
118
(assert-error  (tn) (lambda () (assq '+ '+)))
 
119
(assert-equal? (tn) '(- . 1)   (assq '- '((+ . 0) (- . 1) (* . 2) . 3)))
 
120
(assert-error  (tn) (lambda () (assq '/ '((+ . 0) (- . 1) (* . 2) . 3))))
 
121
(tn "assq improper lists: strings")
 
122
(assert-error  (tn) (lambda () (assq (string #\b)
 
123
                                     '(("a" . 0) ("b" . 1) ("c" . 2) . 3))))
 
124
(tn "assq improper lists: lists")
 
125
(assert-error  (tn) (lambda ()
 
126
                      (assq (list (string #\b))
 
127
                            '((("a") . 0) (("b") . 1) (("c") . 2) . 3))))
 
128
 
 
129
(tn "assq from R5RS examples")
 
130
(define e '((a 1) (b 2) (c 3)))
 
131
(assert-equal? (tn) '(a 1) (assq 'a e))
 
132
(assert-equal? (tn) '(b 2) (assq 'b e))
 
133
(assert-false  (tn) (assq 'd e))
 
134
(assert-false  (tn) (assq (list 'a) '(((a)) ((b)) ((c)))))
 
135
 
 
136
;;
 
137
;; assv
 
138
;;
 
139
 
 
140
(tn "assv symbols")
 
141
(assert-error  (tn) (lambda () (assv 'a '(a))))
 
142
(assert-error  (tn) (lambda () (assv 'a '((A . 0) a))))
 
143
(assert-false  (tn)            (assv 'a '()))
 
144
(assert-equal? (tn) '(a . 0)   (assv 'a '((a . 0))))
 
145
(assert-false  (tn)            (assv 'b '((a . 0))))
 
146
(assert-equal? (tn) '(A . 0)   (assv 'A '((A . 0) (a . 1) (b . 2))))
 
147
(assert-equal? (tn) '(a . 1)   (assv 'a '((A . 0) (a . 1) (b . 2))))
 
148
(assert-equal? (tn) '(b . 2)   (assv 'b '((A . 0) (a . 1) (b . 2))))
 
149
(assert-false  (tn)            (assv 'c '((A . 0) (a . 1) (b . 2))))
 
150
(tn "assv builtin procedures")
 
151
(assert-false  (tn)            (assv + (list)))
 
152
(assert-equal? (tn) (cons + 0) (assv + (list (cons + 0))))
 
153
(assert-false  (tn)            (assv - (list (cons + 0))))
 
154
(assert-equal? (tn) (cons + 0) (assv + (list (cons + 0) (cons - 1) (cons * 2))))
 
155
(assert-equal? (tn) (cons - 1) (assv - (list (cons + 0) (cons - 1) (cons * 2))))
 
156
(assert-equal? (tn) (cons * 2) (assv * (list (cons + 0) (cons - 1) (cons * 2))))
 
157
(assert-false  (tn)            (assv / (list (cons + 0) (cons - 1) (cons * 2))))
 
158
(tn "assv closures")
 
159
(assert-equal? (tn) (car cdr3) (assv elm3 alist))
 
160
(assert-equal? (tn) (car cdr2) (assv elm2 alist))
 
161
(assert-equal? (tn) (car cdr1) (assv elm1 alist))
 
162
(assert-equal? (tn) (car cdr0) (assv elm0 alist))
 
163
(assert-false  (tn)            (assv (lambda() #f) alist))
 
164
(tn "assv numbers")
 
165
(assert-false  (tn)            (assv 0 '()))
 
166
(assert-equal? (tn) '(0 . a)   (assv 0 '((0 . a))))
 
167
(assert-false  (tn)            (assv 1 '((0 . a))))
 
168
(assert-equal? (tn) '(0 . a)   (assv 0 '((0 . a) (1 . b) (2 . c))))
 
169
(assert-equal? (tn) '(1 . b)   (assv 1 '((0 . a) (1 . b) (2 . c))))
 
170
(assert-equal? (tn) '(2 . c)   (assv 2 '((0 . a) (1 . b) (2 . c))))
 
171
(assert-false  (tn)            (assv 3 '((0 . a) (1 . b) (2 . c))))
 
172
(assert-equal? (tn) '(5 7)     (assv 5 '((2 3) (5 7) (11 13))))  ;; R5RS
 
173
(tn "assv chars")
 
174
(assert-false  (tn)            (assv #\a '()))
 
175
(assert-equal? (tn) '(#\a . a) (assv #\a '((#\a . a))))
 
176
(assert-false  (tn)            (assv #\b '((#\a . a))))
 
177
(assert-equal? (tn) '(#\a . a) (assv #\a '((#\a . a) (#\b . b) (#\c . c))))
 
178
(assert-equal? (tn) '(#\b . b) (assv #\b '((#\a . a) (#\b . b) (#\c . c))))
 
179
(assert-equal? (tn) '(#\c . c) (assv #\c '((#\a . a) (#\b . b) (#\c . c))))
 
180
(assert-false  (tn)            (assv #\d '((#\a . a) (#\b . b) (#\c . c))))
 
181
(tn "assv chars with non-constant key")
 
182
(assert-false  (tn)            (assv (char #\a) '()))
 
183
(assert-equal? (tn) '(#\a . a) (assv (char #\a) '((#\a . a))))
 
184
(assert-false  (tn)            (assv (char #\b) '((#\a . a))))
 
185
(assert-equal? (tn) '(#\a . a) (assv (char #\a) '((#\a . a) (#\b . b) (#\c . c))))
 
186
(assert-equal? (tn) '(#\b . b) (assv (char #\b) '((#\a . a) (#\b . b) (#\c . c))))
 
187
(assert-equal? (tn) '(#\c . c) (assv (char #\c) '((#\a . a) (#\b . b) (#\c . c))))
 
188
(assert-false  (tn)            (assv (char #\d) '((#\a . a) (#\b . b) (#\c . c))))
 
189
(tn "assv strings with non-constant key")
 
190
;; These tests assume that (string #\a) is not optimized as constant string.
 
191
(assert-false  (tn) (assv (string #\a) '()))
 
192
(assert-false  (tn) (assv (string #\a) '(("a" . a))))
 
193
(assert-false  (tn) (assv (string #\b) '(("a" . a))))
 
194
(assert-false  (tn) (assv (string #\a) '(("a" . a) ("b" . b) ("c" . c))))
 
195
(assert-false  (tn) (assv (string #\b) '(("a" . a) ("b" . b) ("c" . c))))
 
196
(assert-false  (tn) (assv (string #\c) '(("a" . a) ("b" . b) ("c" . c))))
 
197
(assert-false  (tn) (assv (string #\d) '(("a" . a) ("b" . b) ("c" . c))))
 
198
(tn "assv lists with non-constant key")
 
199
;; These tests assume that the keys are not optimized as constant object.
 
200
(assert-false  (tn) (assv (list (string #\a)) '()))
 
201
(assert-false  (tn) (assv (list (string #\a)) '((("a") . a))))
 
202
(assert-false  (tn) (assv (list (string #\b)) '((("a") . a))))
 
203
(assert-false  (tn) (assv (list (string #\a))
 
204
                          '((("a") . a) (("b") . b) (("c") . c))))
 
205
(assert-false  (tn) (assv (list (string #\b))
 
206
                          '((("a") . a) (("b") . b) (("c") . c))))
 
207
(assert-false  (tn) (assv (list (string #\c))
 
208
                          '((("a") . a) (("b") . b) (("c") . c))))
 
209
(assert-false  (tn) (assv (list (string #\d))
 
210
                          '((("a") . a) (("b") . b) (("c") . c))))
 
211
(assert-false  (tn) (assv (list (string #\a #\B #\c)
 
212
                                (list (string #\d) (list (string #\e))))
 
213
                          '((("aBc" ("d" ("E"))) 0)
 
214
                            (("aBc" ("d" ("e"))) 1)
 
215
                            ("f")
 
216
                            ("g"))))
 
217
 
 
218
(tn "assv improper lists: symbols")
 
219
(assert-error  (tn) (lambda () (assv 'a 'a)))
 
220
(assert-equal? (tn) '(a . 1)   (assv 'a '((A . 0) (a . 1) (b . 2) . 3)))
 
221
(assert-error  (tn) (lambda () (assv 'c '((A . 0) (a . 1) (b . 2) . 3))))
 
222
(tn "assv improper lists: builtin procedures")
 
223
(assert-error  (tn) (lambda () (assv '+ '+)))
 
224
(assert-equal? (tn) '(- . 1)   (assv '- '((+ . 0) (- . 1) (* . 2) . 3)))
 
225
(assert-error  (tn) (lambda () (assv '/ '((+ . 0) (- . 1) (* . 2) . 3))))
 
226
(tn "assv improper lists: numbers")
 
227
(assert-error  (tn) (lambda () (assv 0 '0)))
 
228
(assert-equal? (tn) '(1 . b)   (assv 1 '((0 . a) (1 . b) (3 . c) . d)))
 
229
(assert-error  (tn) (lambda () (assv 4 '((0 . a) (1 . b) (3 . c) . d))))
 
230
(tn "assv improper lists: chars")
 
231
(assert-error  (tn) (lambda () (assv #\a #\a)))
 
232
(assert-equal? (tn) '(#\b . 1) (assv #\b
 
233
                                     '((#\a . 0) (#\b . 1) (#\c . 2) . 3)))
 
234
(assert-equal? (tn) '(#\b . 1) (assv (char #\b)
 
235
                                     '((#\a . 0) (#\b . 1) (#\c . 2) . 3)))
 
236
(assert-error  (tn) (lambda () (assv #\d
 
237
                                     '((#\a . 0) (#\b . 1) (#\c . 2) . 3))))
 
238
(tn "assv improper lists: strings")
 
239
(assert-error  (tn) (lambda () (assv (string #\b)
 
240
                                     '(("a" . 0) ("b" . 1) ("c" . 2) . 3))))
 
241
(tn "assv improper lists: lists")
 
242
(assert-error  (tn) (lambda ()
 
243
                      (assv (list (string #\b))
 
244
                            '((("a") . 0) (("b") . 1) (("c") . 2) . 3))))
 
245
 
 
246
;;
 
247
;; assoc
 
248
;;
 
249
 
 
250
(tn "assoc symbols")
 
251
(assert-error  (tn) (lambda () (assoc 'a '(a))))
 
252
(assert-error  (tn) (lambda () (assoc 'a '((A . 0) a))))
 
253
(assert-false  (tn)            (assoc 'a '()))
 
254
(assert-equal? (tn) '(a . 0)   (assoc 'a '((a . 0))))
 
255
(assert-false  (tn)            (assoc 'b '((a . 0))))
 
256
(assert-equal? (tn) '(A . 0)   (assoc 'A '((A . 0) (a . 1) (b . 2))))
 
257
(assert-equal? (tn) '(a . 1)   (assoc 'a '((A . 0) (a . 1) (b . 2))))
 
258
(assert-equal? (tn) '(b . 2)   (assoc 'b '((A . 0) (a . 1) (b . 2))))
 
259
(assert-false  (tn)            (assoc 'c '((A . 0) (a . 1) (b . 2))))
 
260
(tn "assoc builtin procedures")
 
261
(assert-false  (tn)            (assoc + (list)))
 
262
(assert-equal? (tn) (cons + 0) (assoc + (list (cons + 0))))
 
263
(assert-false  (tn)            (assoc - (list (cons + 0))))
 
264
(assert-equal? (tn) (cons + 0) (assoc + (list (cons + 0) (cons - 1) (cons * 2))))
 
265
(assert-equal? (tn) (cons - 1) (assoc - (list (cons + 0) (cons - 1) (cons * 2))))
 
266
(assert-equal? (tn) (cons * 2) (assoc * (list (cons + 0) (cons - 1) (cons * 2))))
 
267
(assert-false  (tn)            (assoc / (list (cons + 0) (cons - 1) (cons * 2))))
 
268
(tn "assoc closures")
 
269
(assert-equal? (tn) (car cdr3) (assoc elm3 alist))
 
270
(assert-equal? (tn) (car cdr2) (assoc elm2 alist))
 
271
(assert-equal? (tn) (car cdr1) (assoc elm1 alist))
 
272
(assert-equal? (tn) (car cdr0) (assoc elm0 alist))
 
273
(assert-false  (tn)            (assoc (lambda() #f) alist))
 
274
(tn "assoc numbers")
 
275
(assert-false  (tn)            (assoc 0 '()))
 
276
(assert-equal? (tn) '(0 . a)   (assoc 0 '((0 . a))))
 
277
(assert-false  (tn)            (assoc 1 '((0 . a))))
 
278
(assert-equal? (tn) '(0 . a)   (assoc 0 '((0 . a) (1 . b) (2 . c))))
 
279
(assert-equal? (tn) '(1 . b)   (assoc 1 '((0 . a) (1 . b) (2 . c))))
 
280
(assert-equal? (tn) '(2 . c)   (assoc 2 '((0 . a) (1 . b) (2 . c))))
 
281
(assert-false  (tn)            (assoc 3 '((0 . a) (1 . b) (2 . c))))
 
282
(assert-equal? (tn) '(5 7)     (assoc 5 '((2 3) (5 7) (11 13))))  ;; R5RS
 
283
(tn "assoc chars")
 
284
(assert-false  (tn)            (assoc #\a '()))
 
285
(assert-equal? (tn) '(#\a . a) (assoc #\a '((#\a . a))))
 
286
(assert-false  (tn)            (assoc #\b '((#\a . a))))
 
287
(assert-equal? (tn) '(#\a . a) (assoc #\a '((#\a . a) (#\b . b) (#\c . c))))
 
288
(assert-equal? (tn) '(#\b . b) (assoc #\b '((#\a . a) (#\b . b) (#\c . c))))
 
289
(assert-equal? (tn) '(#\c . c) (assoc #\c '((#\a . a) (#\b . b) (#\c . c))))
 
290
(assert-false  (tn)            (assoc #\d '((#\a . a) (#\b . b) (#\c . c))))
 
291
(tn "assoc chars with non-constant key")
 
292
(assert-false  (tn)            (assoc (char #\a) '()))
 
293
(assert-equal? (tn) '(#\a . a) (assoc (char #\a) '((#\a . a))))
 
294
(assert-false  (tn)            (assoc (char #\b) '((#\a . a))))
 
295
(assert-equal? (tn) '(#\a . a) (assoc (char #\a) '((#\a . a) (#\b . b) (#\c . c))))
 
296
(assert-equal? (tn) '(#\b . b) (assoc (char #\b) '((#\a . a) (#\b . b) (#\c . c))))
 
297
(assert-equal? (tn) '(#\c . c) (assoc (char #\c) '((#\a . a) (#\b . b) (#\c . c))))
 
298
(assert-false  (tn)            (assoc (char #\d) '((#\a . a) (#\b . b) (#\c . c))))
 
299
(tn "assoc strings")
 
300
(assert-false  (tn)            (assoc "a" '()))
 
301
(assert-equal? (tn) '("a" . a) (assoc "a" '(("a" . a))))
 
302
(assert-false  (tn)            (assoc "b" '(("a" . a))))
 
303
(assert-equal? (tn) '("a" . a) (assoc "a" '(("a" . a) ("b" . b) ("c" . c))))
 
304
(assert-equal? (tn) '("b" . b) (assoc "b" '(("a" . a) ("b" . b) ("c" . c))))
 
305
(assert-equal? (tn) '("c" . c) (assoc "c" '(("a" . a) ("b" . b) ("c" . c))))
 
306
(assert-false  (tn)            (assoc "d" '(("a" . a) ("b" . b) ("c" . c))))
 
307
(tn "assoc strings with non-constant key")
 
308
;; These tests assume that (string #\a) is not optimized as constant string.
 
309
(assert-false  (tn)            (assoc (string #\a) '()))
 
310
(assert-equal? (tn) '("a" . a) (assoc (string #\a) '(("a" . a))))
 
311
(assert-false  (tn)            (assoc (string #\b) '(("a" . a))))
 
312
(assert-equal? (tn) '("a" . a) (assoc (string #\a)
 
313
                                      '(("a" . a) ("b" . b) ("c" . c))))
 
314
(assert-equal? (tn) '("b" . b) (assoc (string #\b)
 
315
                                      '(("a" . a) ("b" . b) ("c" . c))))
 
316
(assert-equal? (tn) '("c" . c) (assoc (string #\c)
 
317
                                      '(("a" . a) ("b" . b) ("c" . c))))
 
318
(assert-false  (tn)            (assoc (string #\d)
 
319
                                      '(("a" . a) ("b" . b) ("c" . c))))
 
320
(tn "assoc lists")
 
321
;; These tests assume that the keys are not optimized as constant object.
 
322
(assert-false  (tn)              (assoc '("a") '()))
 
323
(assert-equal? (tn) '(("a") . a) (assoc '("a") '((("a") . a))))
 
324
(assert-false  (tn)              (assoc '("b") '((("a") . a))))
 
325
(assert-equal? (tn) '(("a") . a) (assoc '("a") '((("a") . a) (("b") . b) (("c") . c))))
 
326
(assert-equal? (tn) '(("b") . b) (assoc '("b") '((("a") . a) (("b") . b) (("c") . c))))
 
327
(assert-equal? (tn) '(("c") . c) (assoc '("c") '((("a") . a) (("b") . b) (("c") . c))))
 
328
(assert-false  (tn)              (assoc '("d") '((("a") . a) (("b") . b) (("c") . c))))
 
329
(assert-equal? (tn)
 
330
               '(("aBc" ("d" ("e"))) 1)
 
331
               (assoc '("aBc" ("d" ("e")))
 
332
                      '((("aBc" ("d" ("E"))) 0)
 
333
                        (("aBc" ("d" ("e"))) 1)
 
334
                        ("f")
 
335
                        ("g"))))
 
336
(tn "assoc lists with non-constant key")
 
337
(assert-false  (tn)              (assoc (list (string #\a)) '()))
 
338
(assert-equal? (tn) '(("a") . a) (assoc (list (string #\a)) '((("a") . a))))
 
339
(assert-false  (tn)              (assoc (list (string #\b)) '((("a") . a))))
 
340
(assert-equal? (tn) '(("a") . a) (assoc (list (string #\a)) '((("a") . a) (("b") . b) (("c") . c))))
 
341
(assert-equal? (tn) '(("b") . b) (assoc (list (string #\b)) '((("a") . a) (("b") . b) (("c") . c))))
 
342
(assert-equal? (tn) '(("c") . c) (assoc (list (string #\c)) '((("a") . a) (("b") . b) (("c") . c))))
 
343
(assert-false  (tn)              (assoc (list (string #\d)) '((("a") . a) (("b") . b) (("c") . c))))
 
344
(assert-equal? (tn)
 
345
               '(("aBc" ("d" ("e"))) 1)
 
346
               (assoc (list (string #\a #\B #\c)
 
347
                            (list (string #\d) (list (string #\e))))
 
348
                      '((("aBc" ("d" ("E"))) 0)
 
349
                        (("aBc" ("d" ("e"))) 1)
 
350
                        ("f")
 
351
                        ("g"))))
 
352
(assert-equal? (tn) '((a)) (assoc (list 'a) '(((a)) ((b)) ((c)))))  ;; R5RS
 
353
 
 
354
(tn "assoc improper lists: symbols")
 
355
(assert-error  (tn) (lambda () (assoc 'a 'a)))
 
356
(assert-equal? (tn) '(a . 1)   (assoc 'a '((A . 0) (a . 1) (b . 2) . 3)))
 
357
(assert-error  (tn) (lambda () (assoc 'c '((A . 0) (a . 1) (b . 2) . 3))))
 
358
(tn "assoc improper lists: builtin procedures")
 
359
(assert-error  (tn) (lambda () (assoc '+ '+)))
 
360
(assert-equal? (tn) '(- . 1)   (assoc '- '((+ . 0) (- . 1) (* . 2) . 3)))
 
361
(assert-error  (tn) (lambda () (assoc '/ '((+ . 0) (- . 1) (* . 2) . 3))))
 
362
(tn "assoc improper lists: numbers")
 
363
(assert-error  (tn) (lambda () (assoc 0 '0)))
 
364
(assert-equal? (tn) '(1 . b)   (assoc 1 '((0 . a) (1 . b) (3 . c) . d)))
 
365
(assert-error  (tn) (lambda () (assoc 4 '((0 . a) (1 . b) (3 . c) . d))))
 
366
(tn "assoc improper lists: chars")
 
367
(assert-error  (tn) (lambda () (assoc #\a #\a)))
 
368
(assert-equal? (tn) '(#\b . 1) (assoc #\b
 
369
                                      '((#\a . 0) (#\b . 1) (#\c . 2) . 3)))
 
370
(assert-equal? (tn) '(#\b . 1) (assoc (char #\b)
 
371
                                      '((#\a . 0) (#\b . 1) (#\c . 2) . 3)))
 
372
(assert-error  (tn) (lambda () (assoc #\d
 
373
                                      '((#\a . 0) (#\b . 1) (#\c . 2) . 3))))
 
374
(tn "assoc improper lists: strings")
 
375
(assert-error  (tn) (lambda () (assoc "a" "a")))
 
376
(assert-equal? (tn) '("b" . 1) (assoc "b"
 
377
                                      '(("a" . 0) ("b" . 1) ("c" . 2) . 3)))
 
378
(assert-equal? (tn) '("b" . 1) (assoc (string #\b)
 
379
                                      '(("a" . 0) ("b" . 1) ("c" . 2) . 3)))
 
380
(assert-error  (tn) (lambda () (assoc "d"
 
381
                                      '(("a" . 0) ("b" . 1) ("c" . 2) . 3))))
 
382
(tn "assoc improper lists: lists")
 
383
(assert-error  (tn) (lambda () (assoc ("a") ("a"))))
 
384
(assert-equal? (tn)
 
385
               '(("b") . 1)
 
386
               (assoc '("b") '((("a") . 0) (("b") . 1) (("c") . 2) . 3)))
 
387
(assert-equal? (tn)
 
388
               '(("b") . 1)
 
389
               (assoc (list (string #\b))
 
390
                      '((("a") . 0) (("b") . 1) (("c") . 2) . 3)))
 
391
(assert-error  (tn)
 
392
               (lambda ()
 
393
                 (assoc ("d") '((("a") . 0) (("b") . 1) (("c") . 2) . 3))))
 
394
 
 
395
 
 
396
(total-report)