~ chicken-core (chicken-5) /tests/module-tests.scm
Trap1;;;; module-tests.scm23(import (chicken eval) (chicken load))45(cond-expand6 (compiling7 (include "test.scm") )8 (else9 (load-relative "test.scm")))1011(test-begin "modules")1213(test-assert14 "r4rs"15 (module test-r4rs ()16 (import r4rs)17 (equal? 1 1)))1819(test-assert20 "r4rs-null"21 (module test-r4rs-null ()22 (import r4rs-null)23 (begin #t)))2425(test-equal "internal/variable"26(module foo (abc def)27 (import scheme)28 (define (abc x) (+ x 33))29 (define-syntax def30 (syntax-rules ()31 ((_ x) (+ 99 (abc x)))))32 (abc 1))3334)3435(test-error "external/unimported variable (fail)" (abc 2))36(test-error "external/unimported syntax (fail)" (def 3))3738(import foo)3940(test-equal "external/imported variable" (abc 4) 37)41(test-equal "external/imported syntax" (def 5) 137)4243(module bar (x y)44 (import (prefix scheme s:))45 (s:define (x y) (s:* y 2))46 (s:define y 1))4748(import (prefix (only (except (rename bar (x z)) y) z) "bar-"))49(test-equal "modified import" (bar-z 10) 20)50(test-error "hidden import" y)5152(module baz ((x s:list))53 (import (prefix scheme s:))54 (s:define-syntax x55 (syntax-rules ()56 ((_ x) (s:list x)))))5758(import baz)59(test-equal "prefixed import and reexport" (x 1) '(1))6061(module m1 ((bar gna))62 (import scheme)63 (define (gna x) (list 'gna x))64 (define-syntax bar65 (syntax-rules ()66 ((_ x) (baz x))))67 (define-syntax baz68 (syntax-rules ()69 ((_ x) (gna 'x)))))7071(module m2 (run)72 (import scheme (chicken base) m1)73 (define-syntax baz74 (syntax-rules ()75 ((_ x) (list 'goo 'x))))76 (define (gna x) (print "ok."))77 (define (run) (gna 9) (bar 99)))7879(import (only m2 run))80(test-equal "indirect imports" (run) '(gna 99))8182(module m1 ((s1 f1))83 (import scheme (chicken base))84 (define (f1) (print "f1") 'f1)85 (define-syntax s186 (syntax-rules ()87 ((_) (f1)))))8889(module m2 (s2)90 (import scheme m1)91 (define-syntax s292 (syntax-rules ()93 ((_) (s1)))))9495(module m3 (s3)96 (import scheme m2)97 (define-syntax s398 (syntax-rules ()99 ((_) (s2)))))100101(import m3)102(test-equal "chained indirect imports" (s3) 'f1)103104(module literal-compare-test (s1)105 (import scheme)106 (define-syntax s1107 (syntax-rules (and)108 ((_ (and x)) (list x))))109)110111(import literal-compare-test)112(test-equal "literal compare and export" (s1 (and 100)) '(100))113114(module y (y1)115 (import scheme)116 (define y1 10))117118(module x (magnitude)119 (import (except scheme magnitude) y)120 (define magnitude y1))121122(test-equal "redefinition of indirect import" (procedure? magnitude) #t)123124(import x)125(test-equal "redefinition of indirect import (II)" magnitude 10)126127(module m10 (m10x m10y)128 (import scheme)129 (define m10x 99)130 (define-syntax m10y131 (syntax-rules ()132 ((_ x) (list 'x)))))133134(module m11 (m10x m10y)135 (import m10))136137(import m11)138(test-equal "value reexport" m10x 99)139(test-equal "syntax reexport" (m10y 3) '(3))140141;; found by Jim Ursetto;142143(module m12 (begin0)144 (import scheme)145 (define-syntax begin0146 (syntax-rules ()147 ((_ e0 e1 ...)148 (##sys#call-with-values149 (lambda () e0)150 (lambda var151 (begin152 e1 ...153 (apply ##sys#values var))))))))154155(test-equal "primitive indirect value-binding reexport"156 (module m13 ()157 (import m12) ; note absence of "scheme"158 (begin0 1 2 3))159 1)160161(module m14 (test-extlambda)162 (import scheme)163 (define (test-extlambda string #!optional whatever)164 string))165166(import m14)167168(test-equal "extended lambda list uses expansion environment"169 "some text"170 (test-extlambda "some text"))171172;;; import-forms in `require-extension':173174(module m15 ()175 (import scheme (chicken base))176 (import (prefix (rename srfi-4 (u8vector u)) 99:))177 (print 99:u))178179180;;; expansion of macros into modules:181182(module m16 (foo-module)183184(import scheme)185186(define-syntax foo-module187 (syntax-rules ()188 ((_ name)189 (module name (maker definer)190 (import scheme)191 (define (maker) 'name)192 (define-syntax definer193 (syntax-rules ()194 ((_) (define (name) 'name))))))))195196)197198(import m16)199(foo-module abc)200(import abc)201202(test-equal203 "function defined in module that is the result of an expansion"204 'abc (maker))205206(definer)207208(test-equal209 "syntax defined in module that is the result of an expansion"210 'abc (abc))211212(module m17 (a) (import scheme) (define a 1))213(begin-for-syntax ; XXX workaround for missing module alias functionality214 (##sys#register-module-alias 'm18 'm17))215(module m19 (a) (import scheme) (define a 2))216217(test-equal218 "global module alias scope (1)"219 (module m20 ()220 (import scheme)221 (import m18)222 a)223 1)224225(test-equal226 "local module alias scope"227 (module m21 ()228 (import scheme (chicken syntax))229 (begin-for-syntax ; XXX s.a.230 (##sys#register-module-alias 'm18 'm19))231 (import m18)232 a)233 2)234235(test-equal236 "global module alias scope (2)"237 (module m20 ()238 (import scheme)239 (import m18)240 a)241 1)242243;; #865 - "*" export list needs special treatment when using "export"244;; (fix contributed by "megane")245246(module247 m22248 *249 (import scheme)250 (define b 2))251252(module253 m23254 *255 (import (chicken module))256 (import m22)257 (export b) )258259(test-equal260 "`*' export-list + explicit export"261 (module m24 ()262 (import m23)263 b)264 2)265266;; (contributed by "megane")267268(module m25 *269 (import scheme)270 (define foo 1))271272(module m26 (bar)273 (import (chicken module) scheme)274 (reexport m25)275 (define bar 2))276277(module m27 *278 (import (chicken module) scheme)279 (reexport m25) ;; <- oops, bar not exported anymore280 (define bar 2))281282(test-equal283 "handle star-exporting module with reexport"284 (module m28 ()285 (import scheme (chicken base))286 (import (prefix m26 b/))287 (import (prefix m27 c/))288 (print b/foo)289 (print c/foo)290 (print b/bar)291 c/bar) ;; <- Error: unbound variable: c/bar292 2)293294;; somewhat related, but with syntax (#882, found by megane):295296(module m29 *297 (import (chicken syntax) scheme)298 (define-syntax m29-baz299 (er-macro-transformer300 (lambda _301 ''foo))))302303(module m30 *304 (import (chicken module))305 (import m29)306 (export m29-baz))307308(test-equal309 "star-export with explicit re-export of syntax"310 (module m31 ()311 (import scheme)312 (import m30)313 (m29-baz))314 'foo)315316;; list-style library names317318(test-assert319 (module (m33 a) *320 (import (scheme))321 (define (foo) 'ok)))322323(test-assert324 (module (m33 b) ()325 (import (scheme) (m33 a))326 (eq? (foo) 'ok)))327328(test-assert (import (prefix (m33 a) m33/a/)))329(test-assert (eq? (m33/a/foo) 'ok))330(test-assert (module-environment '(m33 a)))331332;; Ensure that the modules system is simply an aliasing mechanism:333;; Module instantion does not create multiple variable copies.334335(module m31 *336 (import (chicken base) scheme)337 (define mutation-count 0)338 (define (internally-mutate!)339 (set! mutation-count (add1 mutation-count)))340 (define (get-count)341 mutation-count))342343(module m32 *344 (import (chicken base) scheme m31)345 (define (externally-mutate!)346 (set! mutation-count (add1 mutation-count))))347348(import m31 m32)349(test-equal350 "initial state"351 0 mutation-count)352353(internally-mutate!)354355(test-equal356 "After mutating inside defining module"357 1 mutation-count)358359(set! mutation-count 2)360361(test-equal362 "After mutating outside module"363 2 mutation-count)364365(externally-mutate!)366367(test-equal368 "After mutation by another module"369 3 mutation-count)370371(test-equal372 "Internal getter returns same thing"373 3 (get-count))374375(test-assert376 (not (current-module)))377378(test-assert379 (module m33 ()380 (import (scheme) (chicken module))381 (eq? (current-module) 'm33)))382383(module m34 ((syn bar) alias)384 (import scheme (chicken base) (chicken module))385 (export/rename (bar baz) (syn syn2))386 (define bar 123)387 (assert (equal? bar 123))388 (define-syntax alias389 (syntax-rules ()390 ((_) (syn))))391 (define-syntax syn392 (syntax-rules ()393 ((_) (list bar)))))394395(module m35 ()396 (import scheme (chicken base) (chicken module))397 (import (only (rename m34 (syn2 syn3)) syn3 alias))398 (import (rename m34 (baz bax)))399 (define bar 99)400 (assert (equal? bax 123))401 (assert (equal? (syn3) '(123)))402 (assert (equal? (alias) '(123)))403 (assert (equal? bar 99)))404405;; corner case, found by DeeEff, actually not really a good idea,406;; but the expander looped here endlessly407(module m36 (xcons)408 (import scheme)409 (define (xcons x y) (cons y x)))410411(module m37 ()412 (import (rename m36413 (xcons m36#xcons)))414 (import scheme (chicken base))415 (define (xcons x y) (m36#xcons 'X x))416 (assert (equal? '(1 . X) (xcons 1 2))))417418(test-end "modules")419420(test-exit)