2
;;;; Author: Paul Dietz
3
;;;; Created: Thu Oct 3 21:12:40 2002
4
;;;; Contains: Tests for NSTRING-UPCASE
8
(deftest nstring-upcase.1
9
(let* ((s (copy-seq "a"))
10
(s2 (nstring-upcase s)))
11
(values (eqt s s2) s))
14
(deftest nstring-upcase.2
15
(let* ((s (copy-seq "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"))
16
(s2 (nstring-upcase s)))
17
(values (eqt s s2) s))
19
"ABCDEFGHIJKLMNOPQRSTUVWXYZABCDEFGHIJKLMNOPQRSTUVWXYZ")
21
(deftest nstring-upcase.3
22
(let* ((s (copy-seq "0123456789!@#$%^&*()_-+=|\\{}[]:\";'<>?,./ "))
23
(s2 (nstring-upcase s)))
24
(values (eqt s s2) s))
26
"0123456789!@#$%^&*()_-+=|\\{}[]:\";'<>?,./ ")
28
(deftest nstring-upcase.6
29
(let* ((s (make-array 6 :element-type 'character
30
:initial-contents '(#\a #\b #\c #\d #\e #\f)))
31
(s2 (nstring-upcase s)))
32
(values (eqt s s2) s))
35
(deftest nstring-upcase.7
36
(let* ((s (make-array 6 :element-type 'standard-char
37
:initial-contents '(#\a #\b #\7 #\d #\e #\f)))
38
(s2 (nstring-upcase s)))
39
(values (eqt s s2) s))
42
;; Tests with :start, :end
44
(deftest nstring-upcase.8
46
(loop for i from 0 to 6
47
collect (nstring-upcase (copy-seq s) :start i)))
48
("ABCDEF" "aBCDEF" "abCDEF" "abcDEF" "abcdEF" "abcdeF" "abcdef"))
50
(deftest nstring-upcase.9
52
(loop for i from 0 to 6
54
(nstring-upcase (copy-seq s) :start i :end nil)))
55
("ABCDEF" "aBCDEF" "abCDEF" "abcDEF" "abcdEF" "abcdeF" "abcdef"))
57
(deftest nstring-upcase.10
59
(loop for i from 0 to 4
60
collect (loop for j from i to 5
61
collect (nstring-upcase (copy-seq s)
63
(("abcde" "Abcde" "ABcde" "ABCde" "ABCDe" "ABCDE")
64
("abcde" "aBcde" "aBCde" "aBCDe" "aBCDE")
65
("abcde" "abCde" "abCDe" "abCDE")
66
("abcde" "abcDe" "abcDE")
69
(deftest nstring-upcase.11
70
:notes (:nil-vectors-are-strings)
71
(nstring-upcase (make-array '(0) :element-type nil))
74
(deftest nstring-upcase.order.1
75
(let ((i 0) a b c (s (copy-seq "abcdef")))
78
(progn (setf a (incf i)) s)
79
:start (progn (setf b (incf i)) 1)
80
:end (progn (setf c (incf i)) 4))
84
(deftest nstring-upcase.order.2
85
(let ((i 0) a b c (s (copy-seq "abcdef")))
88
(progn (setf a (incf i)) s)
89
:end (progn (setf b (incf i)) 4)
90
:start (progn (setf c (incf i)) 1))
97
(deftest nstring-upcase.error.1
98
(signals-error (nstring-upcase) program-error)
101
(deftest nstring-upcase.error.2
102
(signals-error (nstring-upcase (copy-seq "abc") :bad t) program-error)
105
(deftest nstring-upcase.error.3
106
(signals-error (nstring-upcase (copy-seq "abc") :start) program-error)
109
(deftest nstring-upcase.error.4
110
(signals-error (nstring-upcase (copy-seq "abc") :bad t
111
:allow-other-keys nil)
115
(deftest nstring-upcase.error.5
116
(signals-error (nstring-upcase (copy-seq "abc") :end) program-error)
119
(deftest nstring-upcase.error.6
120
(signals-error (nstring-upcase (copy-seq "abc") 1 2) program-error)