]> gitweb.factorcode.org Git - factor.git/blob - core/classes/tuple/tuple-tests.factor
Merge branch 'master' of git://factorcode.org/git/factor
[factor.git] / core / classes / tuple / tuple-tests.factor
1 USING: accessors arrays assocs calendar classes classes.algebra
2 classes.private classes.tuple classes.tuple.private columns
3 compiler.errors compiler.units continuations definitions
4 effects eval generic generic.single generic.standard grouping
5 io.streams.string kernel kernel.private math math.constants
6 math.order namespaces parser parser.notes prettyprint
7 quotations random see sequences sequences.private slots
8 slots.private splitting strings summary threads tools.test
9 vectors vocabs words words.symbol fry literals ;
10 IN: classes.tuple.tests
11
12 TUPLE: rect x y w h ;
13 : <rect> ( x y w h -- rect ) rect boa ;
14
15 : move ( x rect -- rect )
16     [ + ] change-x ;
17
18 [ f ] [ 10 20 30 40 <rect> dup clone 5 swap move = ] unit-test
19
20 [ t ] [ 10 20 30 40 <rect> dup clone 0 swap move = ] unit-test
21
22 ! Make sure we handle tuple class redefinition
23 TUPLE: redefinition-test ;
24
25 C: <redefinition-test> redefinition-test
26
27 <redefinition-test> "redefinition-test" set
28
29 [ t ] [ "redefinition-test" get redefinition-test? ] unit-test
30
31 "IN: classes.tuple.tests TUPLE: redefinition-test ;" eval( -- )
32
33 [ t ] [ "redefinition-test" get redefinition-test? ] unit-test
34
35 ! Make sure we handle changing shapes!
36 TUPLE: point x y ;
37
38 [ ] [ 100 200 point boa "p" set ] unit-test
39
40 ! Use eval to sequence parsing explicitly
41 [ ] [ "IN: classes.tuple.tests TUPLE: point x y z ;" eval( -- ) ] unit-test
42
43 [ 100 ] [ "p" get x>> ] unit-test
44 [ 200 ] [ "p" get y>> ] unit-test
45 [ f ] [ "p" get "z>>" "accessors" lookup execute ] unit-test
46
47 [ ] [ "p" get 300 ">>z" "accessors" lookup execute drop ] unit-test
48
49 [ 3 ] [ "p" get tuple-size ] unit-test
50
51 [ 300 ] [ "p" get "z>>" "accessors" lookup execute ] unit-test
52
53 [ ] [ "IN: classes.tuple.tests TUPLE: point z y ;" eval( -- ) ] unit-test
54
55 [ 2 ] [ "p" get tuple-size ] unit-test
56
57 [ "p" get x>> ] must-fail
58 [ 200 ] [ "p" get y>> ] unit-test
59 [ 300 ] [ "p" get "z>>" "accessors" lookup execute ] unit-test
60
61 TUPLE: predicate-test ;
62
63 C: <predicate-test> predicate-test
64
65 : predicate-test ( a -- ? ) drop f ;
66
67 [ t ] [ <predicate-test> predicate-test? ] unit-test
68
69 PREDICATE: silly-pred < tuple
70     class \ rect = ;
71
72 GENERIC: area ( obj -- n )
73 M: silly-pred area dup w>> swap h>> * ;
74
75 TUPLE: circle radius ;
76 M: circle area radius>> sq pi * ;
77
78 [ 200 ] [ T{ rect f 0 0 10 20 } area ] unit-test
79
80 ! Hashcode breakage
81 TUPLE: empty ;
82
83 C: <empty> empty
84
85 [ t ] [ <empty> hashcode fixnum? ] unit-test
86
87 ! Compiler regression
88 [ t length ] [ object>> t eq? ] must-fail-with
89
90 [ "<constructor-test>" ]
91 [ "IN: classes.tuple.test TUPLE: constructor-test ; C: <constructor-test> constructor-test" eval( -- ) word name>> ] unit-test
92
93 TUPLE: size-test a b c d ;
94
95 [ t ] [
96     T{ size-test } tuple-size
97     size-test tuple-layout second =
98 ] unit-test
99
100 GENERIC: <yo-momma> ( a -- b )
101
102 TUPLE: yo-momma ;
103
104 [ ] [ "IN: classes.tuple.tests C: <yo-momma> yo-momma" eval( -- ) ] unit-test
105
106 [ f ] [ \ <yo-momma> generic? ] unit-test
107
108 ! Test forget
109 [
110     [ t ] [ \ yo-momma class? ] unit-test
111     [ ] [ \ yo-momma forget ] unit-test
112     [ ] [ \ <yo-momma> forget ] unit-test
113     [ f ] [ \ yo-momma update-map get values member-eq? ] unit-test
114 ] with-compilation-unit
115
116 TUPLE: loc-recording ;
117
118 [ f ] [ \ loc-recording where not ] unit-test
119
120 ! 'forget' wasn't robust enough
121
122 TUPLE: forget-robustness ;
123
124 GENERIC: forget-robustness-generic ( a -- b )
125
126 M: forget-robustness forget-robustness-generic ;
127
128 M: integer forget-robustness-generic ;
129
130 [
131     [ ] [ \ forget-robustness-generic forget ] unit-test
132     [ ] [ \ forget-robustness forget ] unit-test
133     [ ] [ M\ forget-robustness forget-robustness-generic forget ] unit-test
134 ] with-compilation-unit
135
136 ! rapido found this one
137 GENERIC# m1 0 ( s n -- n )
138 GENERIC# m2 1 ( s n -- v )
139
140 TUPLE: t1 ;
141
142 M: t1 m1 drop ;
143 M: t1 m2 nip ;
144
145 TUPLE: t2 ;
146
147 M: t2 m1 drop ;
148 M: t2 m2 nip ;
149
150 TUPLE: t3 ;
151
152 M: t3 m1 drop ;
153 M: t3 m2 nip ;
154
155 TUPLE: t4 ;
156
157 M: t4 m1 drop ;
158 M: t4 m2 nip ;
159
160 C: <t4> t4
161
162 [ 1 ] [ 1 <t4> m1 ] unit-test
163 [ 1 ] [ <t4> 1 m2 ] unit-test
164
165 ! another combination issue
166 GENERIC: silly ( obj -- obj obj )
167
168 UNION: my-union slice repetition column array vector reversed ;
169
170 M: my-union silly "x" ;
171
172 M: array silly "y" ;
173
174 M: column silly "fdsfds" ;
175
176 M: repetition silly "zzz" ;
177
178 M: reversed silly "zz" ;
179
180 M: slice silly "tt" ;
181
182 M: string silly "t" ;
183
184 M: vector silly "z" ;
185
186 [ "zz" ] [ 123 <reversed> silly nip ] unit-test
187
188 ! Typo
189 SYMBOL: not-a-tuple-class
190
191 ! Missing check
192 [ not-a-tuple-class boa ] must-fail
193 [ not-a-tuple-class new ] must-fail
194
195 TUPLE: erg's-reshape-problem a b c d ;
196
197 C: <erg's-reshape-problem> erg's-reshape-problem
198
199 ! Inheritance
200 TUPLE: computer cpu ram ;
201 C: <computer> computer
202
203 [ "TUPLE: computer cpu ram ;" ] [
204     [ \ computer see ] with-string-writer string-lines second
205 ] unit-test
206
207 TUPLE: laptop < computer battery ;
208 C: <laptop> laptop
209
210 [ t ] [ laptop tuple-class? ] unit-test
211 [ t ] [ laptop tuple class<= ] unit-test
212 [ t ] [ laptop computer class<= ] unit-test
213 [ t ] [ laptop computer classes-intersect? ] unit-test
214
215 [ ] [ "Pentium" 128 3 hours <laptop> "laptop" set ] unit-test
216 [ t ] [ "laptop" get laptop? ] unit-test
217 [ t ] [ "laptop" get computer? ] unit-test
218 [ t ] [ "laptop" get tuple? ] unit-test
219
220 : test-laptop-slot-values ( -- )
221     [ laptop ] [ "laptop" get class ] unit-test
222     [ "Pentium" ] [ "laptop" get cpu>> ] unit-test
223     [ 128 ] [ "laptop" get ram>> ] unit-test
224     [ t ] [ "laptop" get battery>> 3 hours = ] unit-test ;
225
226 test-laptop-slot-values
227
228 [ "TUPLE: laptop < computer battery ;" ] [
229     [ \ laptop see ] with-string-writer string-lines second
230 ] unit-test
231
232 [ { tuple computer laptop } ] [ laptop superclasses ] unit-test
233
234 TUPLE: server < computer rackmount ;
235 C: <server> server
236
237 [ t ] [ server tuple-class? ] unit-test
238 [ t ] [ server tuple class<= ] unit-test
239 [ t ] [ server computer class<= ] unit-test
240 [ t ] [ server computer classes-intersect? ] unit-test
241
242 [ ] [ "PowerPC" 64 "1U" <server> "server" set ] unit-test
243 [ t ] [ "server" get server? ] unit-test
244 [ t ] [ "server" get computer? ] unit-test
245 [ t ] [ "server" get tuple? ] unit-test
246
247 : test-server-slot-values ( -- )
248     [ server ] [ "server" get class ] unit-test
249     [ "PowerPC" ] [ "server" get cpu>> ] unit-test
250     [ 64 ] [ "server" get ram>> ] unit-test
251     [ "1U" ] [ "server" get rackmount>> ] unit-test ;
252
253 test-server-slot-values
254
255 [ f ] [ "server" get laptop? ] unit-test
256 [ f ] [ "laptop" get server? ] unit-test
257
258 [ f ] [ server laptop class<= ] unit-test
259 [ f ] [ laptop server class<= ] unit-test
260 [ f ] [ laptop server classes-intersect? ] unit-test
261
262 [ f ] [ 1 2 <computer> laptop? ] unit-test
263 [ f ] [ \ + server? ] unit-test
264
265 [ "TUPLE: server < computer rackmount ;" ] [
266     [ \ server see ] with-string-writer string-lines second
267 ] unit-test
268
269 [
270     "IN: classes.tuple.tests TUPLE: bad-superclass < word ;" eval( -- )
271 ] must-fail
272
273 ! Dynamically changing inheritance hierarchy
274 TUPLE: electronic-device ;
275
276 [ ] [ "IN: classes.tuple.tests TUPLE: computer < electronic-device cpu ram ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
277
278 [ f ] [ electronic-device laptop class<= ] unit-test
279 [ t ] [ server electronic-device class<= ] unit-test
280 [ t ] [ laptop server class-or electronic-device class<= ] unit-test
281
282 [ t ] [ "laptop" get electronic-device? ] unit-test
283 [ t ] [ "laptop" get computer? ] unit-test
284 [ t ] [ "laptop" get laptop? ] unit-test
285 [ f ] [ "laptop" get server? ] unit-test
286
287 [ t ] [ "server" get electronic-device? ] unit-test
288 [ t ] [ "server" get computer? ] unit-test
289 [ f ] [ "server" get laptop? ] unit-test
290 [ t ] [ "server" get server? ] unit-test
291
292 [ ] [ "IN: classes.tuple.tests TUPLE: computer cpu ram ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
293
294 [ f ] [ "laptop" get electronic-device? ] unit-test
295 [ t ] [ "laptop" get computer? ] unit-test
296
297 [ ] [ "IN: classes.tuple.tests TUPLE: computer < electronic-device cpu ram disk ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
298
299 test-laptop-slot-values
300 test-server-slot-values
301
302 [ ] [ "IN: classes.tuple.tests TUPLE: electronic-device voltage ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
303
304 test-laptop-slot-values
305 test-server-slot-values
306
307 TUPLE: make-me-some-accessors voltage grounded? ;
308
309 [ f ] [ "laptop" get voltage>> ] unit-test
310 [ f ] [ "server" get voltage>> ] unit-test
311
312 [ ] [ "laptop" get 220 >>voltage drop ] unit-test
313 [ ] [ "server" get 110 >>voltage drop ] unit-test
314
315 [ ] [ "IN: classes.tuple.tests TUPLE: electronic-device voltage grounded? ; C: <computer> computer" eval( -- ) ] unit-test
316
317 test-laptop-slot-values
318 test-server-slot-values
319
320 [ 220 ] [ "laptop" get voltage>> ] unit-test
321 [ 110 ] [ "server" get voltage>> ] unit-test
322
323 [ ] [ "IN: classes.tuple.tests TUPLE: electronic-device grounded? voltage ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
324
325 test-laptop-slot-values
326 test-server-slot-values
327
328 [ 220 ] [ "laptop" get voltage>> ] unit-test
329 [ 110 ] [ "server" get voltage>> ] unit-test
330
331 ! Reshaping superclass and subclass simultaneously
332 [ ] [ "IN: classes.tuple.tests TUPLE: electronic-device voltage ; TUPLE: computer < electronic-device cpu ram ; C: <computer> computer C: <laptop> laptop C: <server> server" eval( -- ) ] unit-test
333
334 test-laptop-slot-values
335 test-server-slot-values
336
337 [ 220 ] [ "laptop" get voltage>> ] unit-test
338 [ 110 ] [ "server" get voltage>> ] unit-test
339
340 ! Reshape crash
341 TUPLE: test1 a ; TUPLE: test2 < test1 b ;
342
343 "a" "b" test2 boa "test" set
344
345 : test-a/b ( -- )
346     [ "a" ] [ "test" get a>> ] unit-test
347     [ "b" ] [ "test" get b>> ] unit-test ;
348
349 test-a/b
350
351 [ ] [ "IN: classes.tuple.tests TUPLE: test1 a x ; TUPLE: test2 < test1 b y ;" eval( -- ) ] unit-test
352
353 test-a/b
354
355 [ ] [ "IN: classes.tuple.tests TUPLE: test1 a ; TUPLE: test2 < test1 b ;" eval( -- ) ] unit-test
356
357 test-a/b
358
359 ! Twice in the same compilation unit
360 [
361     test1 tuple { "a" "x" "y" } define-tuple-class
362     test1 tuple { "a" "y" } define-tuple-class
363 ] with-compilation-unit
364
365 test-a/b
366
367 ! Moving slots up and down
368 TUPLE: move-up-1 a b ;
369 TUPLE: move-up-2 < move-up-1 c ;
370
371 T{ move-up-2 f "a" "b" "c" } "move-up" set
372
373 : test-move-up ( -- )
374     [ "a" ] [ "move-up" get a>> ] unit-test
375     [ "b" ] [ "move-up" get b>> ] unit-test
376     [ "c" ] [ "move-up" get c>> ] unit-test ;
377
378 test-move-up
379
380 [ ] [ "IN: classes.tuple.tests TUPLE: move-up-1 a b c ; TUPLE: move-up-2 < move-up-1 ;" eval( -- ) ] unit-test
381
382 test-move-up
383
384 [ ] [ "IN: classes.tuple.tests TUPLE: move-up-1 a c ; TUPLE: move-up-2 < move-up-1 b ;" eval( -- ) ] unit-test
385
386 test-move-up
387
388 [ ] [ "IN: classes.tuple.tests TUPLE: move-up-1 c ; TUPLE: move-up-2 < move-up-1 b a ;" eval( -- ) ] unit-test
389
390 test-move-up
391
392 [ ] [ "IN: classes.tuple.tests TUPLE: move-up-1 ; TUPLE: move-up-2 < move-up-1 a b c ;" eval( -- ) ] unit-test
393
394 ! Constructors must be recompiled when changing superclass
395 TUPLE: constructor-update-1 xxx ;
396
397 TUPLE: constructor-update-2 < constructor-update-1 yyy zzz ;
398
399 : <constructor-update-2> ( a b c -- tuple ) constructor-update-2 boa ;
400
401 { 3 1 } [ <constructor-update-2> ] must-infer-as
402
403 [ ] [ "IN: classes.tuple.tests TUPLE: constructor-update-1 xxx ttt www ;" eval( -- ) ] unit-test
404
405 { 3 1 } [ <constructor-update-2> ] must-infer-as
406
407 [ 1 2 3 4 5 <constructor-update-2> ] [ not-compiled? ] must-fail-with
408
409 [ ] [ [ \ <constructor-update-2> forget ] with-compilation-unit ] unit-test
410
411 ! Redefinition problem
412 TUPLE: redefinition-problem ;
413
414 UNION: redefinition-problem' redefinition-problem integer ;
415
416 [ t ] [ 3 redefinition-problem'? ] unit-test
417
418 TUPLE: redefinition-problem-2 ;
419
420 "IN: classes.tuple.tests TUPLE: redefinition-problem < redefinition-problem-2 ;" eval( -- )
421
422 [ t ] [ 3 redefinition-problem'? ] unit-test
423
424 ! Hardcore unit tests
425
426 \ thread "slots" word-prop "slots" set
427
428 [ ] [
429     [
430         \ thread tuple { "xxx" } "slots" get append
431         define-tuple-class
432     ] with-compilation-unit
433
434     [ 1337 sleep ] "Test" spawn drop
435
436     [
437         \ thread tuple "slots" get
438         define-tuple-class
439     ] with-compilation-unit
440 ] unit-test
441
442 \ vocab "slots" word-prop "slots" set
443
444 [ ] [
445     [
446         \ vocab tuple { "xxx" } "slots" get append
447         define-tuple-class
448     ] with-compilation-unit
449
450     all-words drop
451
452     [
453         \ vocab tuple "slots" get
454         define-tuple-class
455     ] with-compilation-unit
456 ] unit-test
457
458 [ "USE: words T{ word }" eval( -- ) ]
459 [ error>> T{ no-method f word new } = ]
460 must-fail-with
461
462 ! Accessors not being forgotten...
463 [ [ ] ] [
464     "IN: classes.tuple.tests TUPLE: forget-accessors-test x y z ;"
465     <string-reader>
466     "forget-accessors-test" parse-stream
467 ] unit-test
468
469 [ t ] [ "forget-accessors-test" "classes.tuple.tests" lookup class? ] unit-test
470
471 : accessor-exists? ( name -- ? )
472     [ "forget-accessors-test" "classes.tuple.tests" lookup ] dip
473     ">>" append "accessors" lookup method >boolean ;
474
475 [ t ] [ "x" accessor-exists? ] unit-test
476 [ t ] [ "y" accessor-exists? ] unit-test
477 [ t ] [ "z" accessor-exists? ] unit-test
478
479 [ [ ] ] [
480     "IN: classes.tuple.tests GENERIC: forget-accessors-test ( a -- b )"
481     <string-reader>
482     "forget-accessors-test" parse-stream
483 ] unit-test
484
485 [ f ] [ "forget-accessors-test" "classes.tuple.tests" lookup class? ] unit-test
486
487 [ f ] [ "x" accessor-exists? ] unit-test
488 [ f ] [ "y" accessor-exists? ] unit-test
489 [ f ] [ "z" accessor-exists? ] unit-test
490
491 TUPLE: another-forget-accessors-test ;
492
493
494 [ [ ] ] [
495     "IN: classes.tuple.tests GENERIC: another-forget-accessors-test ( a -- b )"
496     <string-reader>
497     "another-forget-accessors-test" parse-stream
498 ] unit-test
499
500 [ t ] [ \ another-forget-accessors-test class? ] unit-test
501
502 ! Shadowing test
503 [ f ] [
504     t parser-notes? [
505         [
506             "IN: classes.tuple.tests TUPLE: shadow-1 a b ; TUPLE: shadow-2 < shadow-1 a b ;" eval( -- )
507         ] with-string-writer empty?
508     ] with-variable
509 ] unit-test
510
511 ! Missing error check
512 [ "IN: classes.tuple.tests USE: words TUPLE: wrong-superclass < word ;" eval( -- ) ] must-fail
513
514 ! Class forget messyness
515 TUPLE: subclass-forget-test ;
516
517 TUPLE: subclass-forget-test-1 < subclass-forget-test ;
518 TUPLE: subclass-forget-test-2 < subclass-forget-test ;
519 TUPLE: subclass-forget-test-3 < subclass-forget-test-2 ;
520
521 [ ] [ "IN: classes.tuple.tests FORGET: subclass-forget-test" eval( -- ) ] unit-test
522
523 [ { subclass-forget-test-2 } ]
524 [ subclass-forget-test-2 class-usages ]
525 unit-test
526
527 [ { subclass-forget-test-3 } ]
528 [ subclass-forget-test-3 class-usages ]
529 unit-test
530
531 [ f ] [ subclass-forget-test-1 tuple-class? ] unit-test
532 [ f ] [ subclass-forget-test-2 tuple-class? ] unit-test
533 [ subclass-forget-test-3 new ] must-fail
534
535 [ "IN: classes.tuple.tests TUPLE: subclass-forget-test-4 < subclass-forget-test-2 ;" eval( -- ) ] must-fail
536
537 ! More
538 DEFER: subclass-reset-test
539 DEFER: subclass-reset-test-1
540 DEFER: subclass-reset-test-2
541 DEFER: subclass-reset-test-3
542
543 GENERIC: break-me ( obj -- )
544
545 [ ] [ [ M\ integer break-me forget ] with-compilation-unit ] unit-test
546
547 [ ] [ "IN: classes.tuple.tests TUPLE: subclass-reset-test ;" <string-reader> "subclass-reset-test" parse-stream drop ] unit-test
548 [ ] [ "IN: classes.tuple.tests TUPLE: subclass-reset-test-1 < subclass-reset-test ;" eval( -- ) ] unit-test
549 [ ] [ "IN: classes.tuple.tests TUPLE: subclass-reset-test-2 < subclass-reset-test ;" eval( -- ) ] unit-test
550 [ ] [ "IN: classes.tuple.tests TUPLE: subclass-reset-test-3 < subclass-reset-test-2 ;" eval( -- ) ] unit-test
551
552 [ ] [ "IN: classes.tuple.tests USE: kernel M: subclass-reset-test-1 break-me drop ;" eval( -- ) ] unit-test
553
554 [ ] [ "IN: classes.tuple.tests : subclass-reset-test ( -- ) ;" <string-reader> "subclass-reset-test" parse-stream drop ] unit-test
555
556 [ f ] [ subclass-reset-test-1 tuple-class? ] unit-test
557 [ f ] [ subclass-reset-test-2 tuple-class? ] unit-test
558 [ subclass-forget-test-3 new ] must-fail
559
560 [ t ] [ \ break-me "methods" word-prop assoc-empty? ] unit-test
561
562 [ ] [ "IN: classes.tuple.tests USE: math USE: kernel M: integer break-me drop ;" eval( -- ) ] unit-test
563
564 [ f ] [ \ break-me "methods" word-prop assoc-empty? ] unit-test
565
566 ! Insufficient type checking
567 [ \ vocab tuple>array drop ] must-fail
568
569 ! Check type declarations
570 TUPLE: declared-types { n fixnum } { m string } ;
571
572 [ T{ declared-types f 0 "hi" } ]
573 [ { declared-types 0 "hi" } >tuple ]
574 unit-test
575
576 [ { declared-types "hi" 0 } >tuple ]
577 [ T{ bad-slot-value f "hi" fixnum } = ]
578 must-fail-with
579
580 ! Check fixnum coercer
581 [ 0 ] [ 0.0 "hi" declared-types boa n>> ] unit-test
582
583 [ 0 ] [ declared-types new 0.0 >>n n>> ] unit-test
584
585 ! Check bignum coercer
586 TUPLE: bignum-coercer { n bignum initial: $[ 0 >bignum ] } ;
587
588 [ 13 bignum ] [ 13.5 bignum-coercer boa n>> dup class ] unit-test
589
590 [ 13 bignum ] [ bignum-coercer new 13.5 >>n n>> dup class ] unit-test
591
592 ! Check float coercer
593 TUPLE: float-coercer { n float } ;
594
595 [ 13.0 float ] [ 13 float-coercer boa n>> dup class ] unit-test
596
597 [ 13.0 float ] [ float-coercer new 13 >>n n>> dup class ] unit-test
598
599 ! Check integer coercer
600 TUPLE: integer-coercer { n integer } ;
601
602 [ 13 fixnum ] [ 13.5 integer-coercer boa n>> dup class ] unit-test
603
604 [ 13 fixnum ] [ integer-coercer new 13.5 >>n n>> dup class ] unit-test
605
606 : foo ( a b -- c ) declared-types boa ;
607
608 \ foo def>> must-infer
609
610 [ T{ declared-types f 0 "hi" } ] [ 0.0 "hi" foo ] unit-test
611
612 [ "hi" 0.0 declared-types boa ]
613 [ T{ no-method f "hi" >fixnum } = ]
614 must-fail-with
615
616 [ 0 { } declared-types boa ]
617 [ T{ bad-slot-value f { } string } = ]
618 must-fail-with
619
620 [ "hi" 0.0 foo ]
621 [ T{ no-method f "hi" >fixnum } = ]
622 must-fail-with
623
624 [ 0 { } foo ]
625 [ T{ bad-slot-value f { } string } = ]
626 must-fail-with
627
628 [ T{ declared-types f 0 "" } ] [ declared-types new ] unit-test
629
630 : blah ( -- vec ) vector new ;
631
632 [ vector new ] must-infer
633
634 [ V{ } ] [ blah ] unit-test
635
636 ! Test reshaping with type declarations and slot attributes
637 TUPLE: reshape-test x ;
638
639 T{ reshape-test f "hi" } "tuple" set
640
641 [ ] [ "IN: classes.tuple.tests TUPLE: reshape-test { x read-only } ;" eval( -- ) ] unit-test
642
643 [ f ] [ \ reshape-test \ (>>x) method ] unit-test
644
645 [ "tuple" get 5 >>x ] must-fail
646
647 [ "hi" ] [ "tuple" get x>> ] unit-test
648
649 [ ] [ "IN: classes.tuple.tests USE: math TUPLE: reshape-test { x integer read-only } ;" eval( -- ) ] unit-test
650
651 [ 0 ] [ "tuple" get x>> ] unit-test
652
653 [ ] [ "IN: classes.tuple.tests USE: math TUPLE: reshape-test { x fixnum initial: 4 read-only } ;" eval( -- ) ] unit-test
654
655 [ 0 ] [ "tuple" get x>> ] unit-test
656
657 TUPLE: boa-coercer-test { x array-capacity } ;
658
659 [ fixnum ] [ 0 >bignum boa-coercer-test boa x>> class ] unit-test
660
661 [ T{ boa-coercer-test f 0 } ] [ T{ boa-coercer-test } ] unit-test
662
663 ! Test error classes
664 ERROR: error-class-test a b c ;
665
666 [ "( a b c -- * )" ] [ \ error-class-test stack-effect effect>string ] unit-test
667 [ f ] [ \ error-class-test "inline" word-prop ] unit-test
668
669 [ "IN: classes.tuple.tests ERROR: error-x ; : error-x 3 ;" eval( -- ) ]
670 [ error>> error>> redefine-error? ] must-fail-with
671
672 DEFER: error-y
673
674 [ ] [ [ \ error-y dup class? [ forget-class ] [ drop ] if ] with-compilation-unit ] unit-test
675
676 [ ] [ "IN: classes.tuple.tests GENERIC: error-y ( a -- b )" eval( -- ) ] unit-test
677
678 [ f ] [ \ error-y tuple-class? ] unit-test
679
680 [ t ] [ \ error-y generic? ] unit-test
681
682 [ ] [ "IN: classes.tuple.tests ERROR: error-y ;" eval( -- ) ] unit-test
683
684 [ t ] [ \ error-y tuple-class? ] unit-test
685
686 [ f ] [ \ error-y generic? ] unit-test
687
688 [ ] [
689     "IN: classes.tuple.tests TUPLE: forget-subclass-test ; TUPLE: forget-subclass-test' < forget-subclass-test ;"
690     <string-reader> "forget-subclass-test" parse-stream
691     drop
692 ] unit-test
693
694 [ ] [ "forget-subclass-test'" "classes.tuple.tests" lookup new "bad-object" set ] unit-test
695
696 [ ] [
697     "IN: classes.tuple.tests TUPLE: forget-subclass-test a ;"
698     <string-reader> "forget-subclass-test" parse-stream
699     drop
700 ] unit-test
701
702 [ ] [
703     "IN: sequences TUPLE: reversed { seq read-only } ;" eval( -- )
704 ] unit-test
705
706 TUPLE: bogus-hashcode-1 x ;
707
708 TUPLE: bogus-hashcode-2 x ;
709
710 M: bogus-hashcode-1 hashcode* 2drop 0 >bignum ;
711
712 [ ] [ T{ bogus-hashcode-2 f T{ bogus-hashcode-1 } } hashcode drop ] unit-test
713
714 DEFER: change-slot-test
715 SLOT: kex
716
717 [ ] [
718     "IN: classes.tuple.tests USING: kernel accessors ; TUPLE: change-slot-test ; SLOT: kex M: change-slot-test kex>> drop 3 ;"
719     <string-reader> "change-slot-test" parse-stream
720     drop
721 ] unit-test
722
723 [ t ] [ \ change-slot-test \ kex>> method >boolean ] unit-test
724
725 [ ] [
726     "IN: classes.tuple.tests USING: kernel accessors ; TUPLE: change-slot-test kex ;"
727     <string-reader> "change-slot-test" parse-stream
728     drop
729 ] unit-test
730
731 [ t ] [ \ change-slot-test \ kex>> method >boolean ] unit-test
732
733 [ ] [
734     "IN: classes.tuple.tests USING: kernel accessors ; TUPLE: change-slot-test ; SLOT: kex M: change-slot-test kex>> drop 3 ;"
735     <string-reader> "change-slot-test" parse-stream
736     drop
737 ] unit-test
738
739 [ t ] [ \ change-slot-test \ kex>> method >boolean ] unit-test
740 [ f ] [ \ change-slot-test \ kex>> method "reading" word-prop ] unit-test
741
742 DEFER: redefine-tuple-twice
743
744 [ ] [ "IN: classes.tuple.tests TUPLE: redefine-tuple-twice ;" eval( -- ) ] unit-test
745
746 [ t ] [ \ redefine-tuple-twice symbol? ] unit-test
747
748 [ ] [ "IN: classes.tuple.tests DEFER: redefine-tuple-twice" eval( -- ) ] unit-test
749
750 [ t ] [ \ redefine-tuple-twice deferred? ] unit-test
751
752 [ ] [ "IN: classes.tuple.tests TUPLE: redefine-tuple-twice ;" eval( -- ) ] unit-test
753
754 [ t ] [ \ redefine-tuple-twice symbol? ] unit-test
755
756 ERROR: base-error x y ;
757 ERROR: derived-error < base-error z ;
758
759 [ (( x y z -- * )) ] [ \ derived-error stack-effect ] unit-test
760
761 USE: classes.struct
762
763 [ { } ] [
764     classes
765     [ "prototype" word-prop ] map
766     [ '[ _ hashcode drop f ] [ drop t ] recover ] filter
767 ] unit-test