File: display.test

package info (click to toggle)
mes 0.24.2-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 6,908 kB
  • sloc: ansic: 24,104; lisp: 11,490; sh: 6,609; asm: 187; makefile: 36
file content (93 lines) | stat: -rwxr-xr-x 2,738 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#! /bin/sh
exec ${MES-bin/mes} --no-auto-compile -L ${0%/*} -L module -C module -e '(tests display)' -s "$0" "$@"
!#

;;; -*-scheme-*-

;;; GNU Mes --- Maxwell Equations of Software
;;; Copyright © 2016,2018 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
;;;
;;; This file is part of GNU Mes.
;;;
;;; GNU Mes is free software; you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3 of the License, or (at
;;; your option) any later version.
;;;
;;; GNU Mes is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with GNU Mes.  If not, see <http://www.gnu.org/licenses/>.

(define-module (tests display)
  #:use-module (mes mes-0)
  #:use-module (mes test))

(mes-use-module (mes display))
(mes-use-module (mes guile))
(mes-use-module (mes test))

(pass-if "first dummy" #t)
(pass-if-not "second dummy" #f)

(pass-if-equal "display"
    "0"
  (with-output-to-string (lambda () (display 0))))

(pass-if-equal "display"
    "A"
  (with-output-to-string (lambda () (display #\A))))

(pass-if-equal "write"
    "#\\A"
  (with-output-to-string (lambda () (write #\A))))

(if (or mes? guile-2?)
    (pass-if-equal "write alarm"
        "#\\alarm"
      (with-output-to-string (lambda () (write #\alarm)))))

(pass-if-equal "write string"
    "\"BOO\\n\""
  (with-output-to-string (lambda () (write "BOO\n"))))

(pass-if-equal "display string"
    "BOO\n"
  (with-output-to-string (lambda () (display "BOO\n"))))

(pass-if-equal "display symbol"
    "Bah"
  (with-output-to-string (lambda () (display 'Bah))))

(pass-if-equal "display number"
    "486"
  (with-output-to-string (lambda () (display 486))))

(if (or mes? guile-1.8?)
    (pass-if-equal "display closure"
        "#<procedure #f (a b c)>"
      (with-output-to-string (lambda () (display (lambda (a b c) #t))))))

(if (or mes? guile-2?)
    (pass-if-equal "display builtin thunk"
        "#<procedure gc ()>"
      (with-output-to-string (lambda () (display gc)))))

(if (or mes? guile-2?)
    (pass-if-equal "display builtin procedure"
        "#<procedure acons (_ _ _)>"
      (with-output-to-string (lambda () (display acons)))))

(pass-if-equal "s-exp"
    "(lambda (a b . c) #t)"
  (with-output-to-string (lambda () (display '(lambda (a b . c) #t)))))

(if mes?
    (pass-if-equal "vector nest"
        "#(0 #(...) 2 3)"
      (with-output-to-string (lambda () (display #(0 #(1) 2 3))))))

(result 'report)