streams.lisp - clic - Clic is an command line interactive client for gopher written in Common LISP (HTM) git clone git://bitreich.org/clic/ git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/clic/ (DIR) Log (DIR) Files (DIR) Refs (DIR) Tags (DIR) README (DIR) LICENSE --- streams.lisp (1968B) --- 1 ;;;; -*- Mode: lisp; indent-tabs-mode: nil -*- 2 ;;; 3 ;;; streams.lisp --- Unit and regression tests for Babel streams. 4 ;;; 5 ;;; Copyright (C) 2007, Attila Lendva <attila.lendvai@gmail.com> 6 ;;; 7 ;;; Permission is hereby granted, free of charge, to any person 8 ;;; obtaining a copy of this software and associated documentation 9 ;;; files (the "Software"), to deal in the Software without 10 ;;; restriction, including without limitation the rights to use, copy, 11 ;;; modify, merge, publish, distribute, sublicense, and/or sell copies 12 ;;; of the Software, and to permit persons to whom the Software is 13 ;;; furnished to do so, subject to the following conditions: 14 ;;; 15 ;;; The above copyright notice and this permission notice shall be 16 ;;; included in all copies or substantial portions of the Software. 17 ;;; 18 ;;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 19 ;;; EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 ;;; MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 21 ;;; NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 22 ;;; HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 23 ;;; WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 24 ;;; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 25 ;;; DEALINGS IN THE SOFTWARE. 26 27 (in-package #:babel-tests) 28 29 (eval-when (:compile-toplevel :load-toplevel :execute) 30 (use-package :babel-streams)) 31 32 (deftest in-memory-vector-stream 33 (with-output-to-sequence (output) 34 ;; TODO use a better test lib and inject asserts for the file position 35 ;(print (file-position output)) 36 (write-sequence "éáőűú" output) 37 ;(print (file-position output)) 38 (write-char #\ű output) 39 ;(print (file-position output)) 40 (write-byte 12 output) 41 (write-sequence (string-to-octets "körte") output) 42 (write-string "körte" output) 43 ;(print (file-position output)) 44 ) 45 #(195 169 195 161 197 145 197 177 195 186 197 177 12 107 195 182 114 116 101))