-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest-io.lisp
executable file
·88 lines (79 loc) · 2.19 KB
/
test-io.lisp
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
;;;; Hey, Emacs, this is a -*- Mode: Lisp; Syntax: Common-Lisp -*- file!
;;;;
;;;; Lisp...not just beautiful, but strangely beautiful.
;;;; -- Paul Graham
;;;;
;;;; Name: test-io.lisp
;;;;
;;;; Started: Tue Nov 5 00:53:07 2024
;;;; Modifications:
;;;;
;;;; Purpose:
;;;;
;;;;
;;;;
;;;; Calling Sequence:
;;;;
;;;;
;;;; Inputs:
;;;;
;;;; Outputs:
;;;;
;;;; Example:
;;;;
;;;; Notes:
;;;;
;;;;
(load "/home/slytobias/lisp/packages/io.lisp")
(load "/home/slytobias/lisp/packages/test.lisp")
(in-package :io)
(use-package :test)
;;;
;;; No test
;;;
;print-plist
;(defun prompt-read (prompt &rest keys &key (allow-empty t) (trim t))
;; (prompt-read "This is the real deal: " :allow-empty nil :test #'(lambda (s) (member s '("pung" "foo" "bar") :test #'string-equal)))
;; (prompt-read "Is this not pung? " :test #'(lambda (s) (every #'alpha-char-p s)) :allow-empty nil)
;; (prompt-read "Is this not pung? " :test #'(lambda (s) (every #'alpha-char-p s)) :trim nil)
;; (prompt-read "Enter a letter. " :allow-empty nil :test #'(lambda (s) (and (= (length s) 1) (alpha-char-p (char s 0)))) )
;(defun get-num (prompt &key test (precision 'double-float))
(deftest test-read-num ()
(check
(handler-case (read-num "1:2")
(error (e)
(format t "Error was not handled: ~A~%" e)
nil)
(:no-error (obj)
(declare (ignore obj))
(format t "Package separator should not signal error.")
t))))
(deftest test-valid-num-p ()
(check
(valid-num-p 8)
(valid-num-p 8d0)
(valid-num-p 1/8)
(valid-num-p 8 #'is-integer)
(valid-num-p 8d0 #'is-integer)
(valid-num-p (sqrt -1))
(not (valid-num-p "8"))
(not (valid-num-p 'eight))
(not (valid-num-p 8d0 #'integerp))
(not (valid-num-p 1/8 #'is-integer))
(not (valid-num-p (sqrt -1) #'realp))))
(deftest test-is-integer ()
(check
(is-integer 2)
(is-integer 2.)
(is-integer 2d0)
(is-integer -2)
(is-integer -2.)
(is-integer -2d0)
(is-integer 4/2)
(is-integer (+ 1/4 1/4 1/4 1/4))
(is-integer (* 11 1/11))
(is-integer (sqrt 4))
(is-integer (sqrt 4d0))
(not (is-integer pi))
(not (is-integer (sqrt -1)))
(not (is-integer 1/3))))