1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-18 18:40:22 +02:00
guile/test-suite/tests/print.test
Andy Wingo 87a6a23669 add truncated-print tests
* doc/ref/misc-modules.texi (Pretty Printing): Fix an error in
  truncated-print example.

* test-suite/Makefile.am:
 * test-suite/tests/print.test: Add truncated-print tests.
2010-01-03 13:35:35 +01:00

46 lines
1.6 KiB
Scheme

;;;; -*- scheme -*-
;;;;
;;;; Copyright (C) 2010 Free Software Foundation, Inc.
;;;;
;;;; This library is free software; you can redistribute it and/or
;;;; modify it under the terms of the GNU Lesser General Public
;;;; License as published by the Free Software Foundation; either
;;;; version 3 of the License, or (at your option) any later version.
;;;;
;;;; This library 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
;;;; Lesser General Public License for more details.
;;;;
;;;; You should have received a copy of the GNU Lesser General Public
;;;; License along with this library; if not, write to the Free Software
;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
(define-module (test-suite test-print)
#:use-module (ice-9 pretty-print)
#:use-module (test-suite lib))
(with-test-prefix "truncated-print"
(define exp '(a b #(c d e) f . g))
(define (tprint x width)
(with-output-to-string
(lambda ()
(truncated-print x #:width width))))
(pass-if (equal? (tprint exp 10)
"(a b . #)"))
(pass-if (equal? (tprint exp 15)
"(a b # f . g)"))
(pass-if (equal? (tprint exp 18)
"(a b #(c ...) . #)"))
(pass-if (equal? (tprint exp 20)
"(a b #(c d e) f . g)"))
(pass-if (equal? (tprint "The quick brown fox" 20)
"\"The quick brown...\""))
(pass-if (equal? (tprint (current-module) 20)
"#<directory (tes...>")))