core: reader: Support binary #b101.
[mes.git] / tests / scm.test
1 #! /bin/sh
2 # -*-scheme-*-
3 MES=${MES-$(dirname $0)/../src/mes}
4 $MES -s $0
5 exit $?
6 !#
7
8 ;;; -*-scheme-*-
9
10 ;;; Mes --- Maxwell Equations of Software
11 ;;; Copyright © 2016,2017,2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
12 ;;;
13 ;;; This file is part of Mes.
14 ;;;
15 ;;; Mes is free software; you can redistribute it and/or modify it
16 ;;; under the terms of the GNU General Public License as published by
17 ;;; the Free Software Foundation; either version 3 of the License, or (at
18 ;;; your option) any later version.
19 ;;;
20 ;;; Mes is distributed in the hope that it will be useful, but
21 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
22 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23 ;;; GNU General Public License for more details.
24 ;;;
25 ;;; You should have received a copy of the GNU General Public License
26 ;;; along with Mes.  If not, see <http://www.gnu.org/licenses/>.
27
28 (mes-use-module (mes scm))
29 (mes-use-module (srfi srfi-0))
30 (mes-use-module (mes test))
31
32 (pass-if "first dummy" #t)
33 (pass-if-not "second dummy" #f)
34
35 (pass-if "when" (seq? (when #t 'true) 'true))
36 (pass-if "when 2" (seq? (when #f 'true) *unspecified*))
37
38 (pass-if "map" (sequal? (map identity '(1 2 3 4)) '(1 2 3 4)))
39 (pass-if "map 2 " (sequal? (map (lambda (i a) (cons i a)) '(1 2 3 4) '(a b c d))
40                            '((1 . a) (2 . b) (3 . c) (4 . d))))
41 (pass-if "for-each" (sequal? (let ((acc '())) (for-each (lambda (x) (set! acc (cons x acc))) '(1 2 3 4)) acc) '(4 3 2 1)))
42 (define xxxa 0)
43 (pass-if "set! " (seq? (begin (set! xxxa 1) xxxa) 1))
44 (pass-if "set! 2" (seq? (let ((a 0)) (set! a 1) a) 1))
45
46
47 (pass-if "list-ref" (seq? (list-ref '(0 1 2) 1) 1))
48
49 (pass-if "do" (sequal? (let ((acc '())) (do ((i 0 (+ i 1))) ((>= i 3)) (set! acc (cons i acc))) acc) '(2 1 0)))
50
51 (pass-if ">=" (>= 3 2 1))
52
53 (pass-if-equal "string-length"
54     0
55     (string-length ""))
56 (pass-if-equal "string-length 2"
57     3
58   (string-length (string-append "a" "b" "c")))
59 (pass-if-equal "string->list"
60     '()
61     (string->list ""))
62 (pass-if-equal "string->list 2"
63     '(#\a #\b #\c #\newline)
64   (string->list "abc\n"))
65
66 (pass-if "string-append" (sequal? (string-append "a" "b" "c") "abc"))
67 (pass-if "substring" (sequal? (substring "hello world" 6) "world"))
68 (pass-if "substring 2" (sequal? (substring "hello world" 4 7) "o w"))
69 (pass-if "string-ref" (seq? (string-ref "hello world" 4) #\o))
70 (pass-if "eq?" (not (eq? (string-append "a" "b" "c") "abc")))
71 (pass-if "char" (seq? (char->integer #\A) 65))
72 (pass-if "char 2" (seq? (char->integer #\101) (char->integer #\A)))
73 (pass-if "char 3" (seq? (integer->char 10) #\newline))
74 (pass-if "char 4" (seq? (integer->char 32) #\space))
75 (pass-if "string " (sequal? (string #\a #\space #\s #\t #\r #\i #\n #\g) "a string"))
76 (pass-if "length" (seq? (length '()) 0))
77 (pass-if "length 2" (seq? (length '(a b c)) 3))
78 (pass-if "make-list" (seq? (make-list 0) '()))
79 (pass-if "make-list 1" (sequal? (make-list 1 0) '(0)))
80 (pass-if "memq" (sequal? (memq 'a '(a b c)) '(a b c)))
81 (pass-if "memq" (sequal? (memq 'b '(a b c)) '(b c)))
82 (pass-if "memq" (seq? (memq 'd '(a b c)) #f))
83 (pass-if "member" (sequal? (member '(a) '((a) b c)) '((a) b c)))
84 (pass-if "assq-ref" (seq? (assq-ref '((b . 1) (c . 2)) 'c) 2))
85 (pass-if "assq-ref 2" (seq? (assq-ref '((b . 1) (c . 2)) 'a) #f))
86 (pass-if "assq-set!" (sequal? (assq-set! '((b . 1)) 'a 0) '((a . 0) (b . 1))))
87 (pass-if "assq-set! 2" (sequal? (assq-set! '((a . 0)) 'a 1) '((a . 1))))
88 (pass-if "assoc" (sequal? (assoc '(a . 0) '((a . 0) (b . 1) ((a . 0) aa))) '((a . 0) aa)))
89 (pass-if-equal "assoc-set!" '((a . 0) (b . 2)) (assoc-set! '((a . 0) (b . 1)) 'b 2))
90 (pass-if-equal "assoc-set! new" '((b . 2) (a . 0)) (assoc-set! '((a . 0)) 'b 2))
91
92 (pass-if "builtin? car" (builtin? car))
93 (pass-if "builtin? cdr" (builtin? cdr))
94 (pass-if "builtin? cons" (builtin? cons))
95 (pass-if "builtin? eq?" (builtin? eq?))
96 (pass-if "builtin? if" (builtin? eq?))
97 (when (not guile?)
98   (pass-if "builtin? eval" (not (builtin? not))))
99 (pass-if "procedure?" (procedure? builtin?))
100 (pass-if "procedure?" (procedure? procedure?))
101 (pass-if "gensym"
102   (symbol? (gensym)))
103 (pass-if "gensym 1"
104   (not (eq? (gensym) (gensym))))
105 (pass-if "gensym 2"
106   (not (eq? (gensym) (gensym))))
107
108 (pass-if "last-pair " (sequal? (last-pair '(1 2 3 4)) '(4)))
109 (pass-if "last-pair 2" (seq? (last-pair '()) '()))
110 ;; (pass-if "circular-list? "
111 ;;   (seq?
112 ;;    (let ((x (list 1 2 3 4)))
113 ;;      (set-cdr! (last-pair x) (cddr x))
114 ;;      (circular-list? x))
115 ;;    #t))
116
117 (pass-if-equal "iota"
118     '(0 1 2) (iota 3))
119
120 (pass-if-equal "iota 0"
121     '() (iota 0))
122
123 (pass-if-equal "iota -1"
124                '() (iota -1))
125
126 (pass-if-equal "reverse" '(3 2 1)
127                (reverse '(1 2 3)))
128
129 (pass-if-equal "reverse fresh" '(1 2 3)
130                (let ((list '(1 2 3)))
131                  (reverse list)
132                  list))
133
134 (pass-if-equal "reverse!" '(1)
135                (let ((list '(1 2 3)))
136                  (reverse! list)
137                  list))
138
139 (pass-if-equal "reverse! ()" '()
140   (reverse! '()))
141
142 (pass-if "cond-expand" (sequal? (cond-expand (foobar #f) (mes (display ": pass: *YAY*") 'mes) (guile (display ": pass: *GUILE*") 'mes)) 'mes))
143
144 (pass-if "apply identity" (seq? (apply identity '(0)) 0))
145 (pass-if "apply identity 2" (sequal? (apply identity '((0 1))) '(0 1)))
146 (pass-if "apply append" (sequal? (apply append '((1 2) (3 4))) '(1 2 3 4)))
147
148 (pass-if "char-alphabetic?" (seq? (char-alphabetic? #\a) #t))
149 (pass-if "char-alphabetic? 2" (seq? (char-alphabetic? #\[) #f))
150
151 (pass-if-equal "compose" 1 ((compose car cdr car) '((0 1 2))))
152
153 (if (not guile?)
154     (pass-if "make-vector" (sequal? (make-vector 3) #(*unspecified* *unspecified* *unspecified*))))
155
156 (pass-if "make-vector 2" (sequal? (make-vector 3 1) #(1 1 1)))
157
158 (pass-if-equal "binary" 5 #b101)
159 (pass-if-equal "octal" 65 #o101)
160 (pass-if-equal "hex" 257 #x101)
161
162 (result 'report)