3 # This software is part of the SBCL system. See the README file for
6 # While most of SBCL is derived from the CMU CL system, the test
7 # files (like this one) were written from scratch after the fork
10 # This software is in the public domain and is provided with
11 # absolutely no warranty. See the COPYING and CREDITS files for
17 testdir
="`pwd -P`" # resolve symbolic links in the directory.
19 set -f # disable filename expansion in the shell.
21 # Test DIRECTORY and TRUENAME.
22 echo this is a
test > test-1.tmp
23 echo this is a
test > test-2.tmp
24 echo this is a
test > wild?
test.tmp
26 ln -s "$testdir" dirlinktest
27 ln -s test-1.tmp link-1
28 ln -s "$testdir/test-2.tmp" link-2
29 ln -s i-do-not-exist link-3
32 ln -s "$testdir/link-6" link-5
33 expected_truenames
=`cat<<EOF
39 #p"$testdir/test-1.tmp"
40 #p"$testdir/test-2.tmp"
41 #p"$testdir/wild\\\\\?test.tmp")
44 # FIXME: the following tests probably can't succeed at all if the
45 # testdir name contains wildcard characters or quotes.
48 (let* ((directory (directory "./*.*"))
49 (truenames (sort directory #'string< :key #'pathname-name)))
50 (format t "~&TRUENAMES=~S~%" truenames)
52 (assert (equal truenames $expected_truenames)))
53 (assert (equal (truename "dirlinktest") #p"$testdir/"))
54 (assert (equal (truename "dirlinktest/") #p"$testdir/"))
55 (assert (equal (truename "test-1.tmp") #p"$testdir/test-1.tmp"))
56 (assert (equal (truename "link-1") #p"$testdir/test-1.tmp"))
57 (assert (equal (truename "link-2") #p"$testdir/test-2.tmp"))
58 (assert (equal (truename "link-3") #p"$testdir/link-3"))
59 (assert (equal (truename "link-4") #p"$testdir/link-4"))
60 (assert (equal (truename "link-5") #p"$testdir/link-5"))
61 (assert (equal (truename "link-6") #p"$testdir/link-6"))
62 (sb-ext:quit :unix-status $EXIT_LISP_WIN)
64 check_status_maybe_lose
"DIRECTORY/TRUENAME part 1" $?
69 (let* ((directory (directory "$testdir/*.*"))
70 (truenames (sort directory #'string< :key #'pathname-name)))
71 (format t "~&TRUENAMES=~S~%" truenames)
73 (assert (equal truenames $expected_truenames)))
74 (assert (equal (truename "$testdir/test-1.tmp") #p"$testdir/test-1.tmp"))
75 (assert (equal (truename "$testdir/link-1") #p"$testdir/test-1.tmp"))
76 (assert (equal (truename "$testdir/link-2") #p"$testdir/test-2.tmp"))
77 (assert (equal (truename "$testdir/link-3") #p"$testdir/link-3"))
78 (assert (equal (truename "$testdir/link-4") #p"$testdir/link-4"))
79 (assert (equal (truename "$testdir/link-5") #p"$testdir/link-5"))
80 (assert (equal (truename "$testdir/link-6") #p"$testdir/link-6"))
81 (sb-ext:quit :unix-status $EXIT_LISP_WIN)
83 check_status_maybe_lose
"DIRECTORY/TRUENAME part 2" $?
84 cleanup_test_subdirectory
86 # Test DIRECTORY on a tree structure of directories.
91 mkdir animal
/vertebrate animal
/invertebrate
92 mkdir animal
/vertebrate
/mammal
93 mkdir animal
/vertebrate
/snake
94 mkdir animal
/vertebrate
/bird
95 mkdir animal
/vertebrate
/mammal
/bear
96 mkdir animal
/vertebrate
/mammal
/mythical
97 mkdir animal
/vertebrate
/mammal
/rodent
98 mkdir animal
/vertebrate
/mammal
/ruminant
99 touch animal
/vertebrate
/mammal
/platypus
100 touch animal
/vertebrate
/mammal
/walrus
101 touch animal
/vertebrate
/mammal
/bear
/grizzly
102 touch animal
/vertebrate
/mammal
/mythical
/mermaid
103 touch animal
/vertebrate
/mammal
/mythical
/unicorn
104 touch animal
/vertebrate
/mammal
/rodent
/beaver
105 touch animal
/vertebrate
/mammal
/rodent
/mouse
106 touch animal
/vertebrate
/mammal
/rodent
/rabbit
107 touch animal
/vertebrate
/mammal
/rodent
/rat
108 touch animal
/vertebrate
/mammal
/ruminant
/cow
109 touch animal
/vertebrate
/snake
/python
110 touch plant
/kingsfoil plant
/pipeweed
112 (in-package :cl-user)
113 (defun absolutify (pathname)
114 "Convert a possibly-relative pathname to absolute."
115 (merge-pathnames pathname
116 (make-pathname :directory
118 *default-pathname-defaults*))))
119 (defun sorted-truenamestrings (pathname-designators)
120 "Convert a collection of pathname designators into canonical form
121 using TRUENAME, NAMESTRING, and SORT."
122 (sort (mapcar #'namestring
124 pathname-designators))
126 (defun need-match-1 (directory-pathname result-sorted-truenamestrings)
128 (let ((directory-sorted-truenamestrings (sorted-truenamestrings
129 (directory directory-pathname))))
130 (unless (equal directory-sorted-truenamestrings
131 result-sorted-truenamestrings)
132 (format t "~&~@<DIRECTORY argument = ~_~2I~S~:>~%"
134 (format t "~&~@<DIRECTORY result = ~_~2I~S~:>~%"
135 directory-sorted-truenamestrings)
136 (format t "~&~@<expected result = ~_~2I~S.~:>~%"
137 result-sorted-truenamestrings)
138 (error "mismatch between DIRECTORY and expected result"))))
139 (defun need-match (directory-pathname result-pathnames)
140 "Require that (DIRECTORY DIRECTORY-PATHNAME) return RESULT-PATHNAMES
141 (modulo TRUENAME and NAMESTRING applied to each RESULT-PATHNAME for
142 convenience in e.g. converting Unix filename syntax idiosyncrasies to
143 Lisp filename syntax idiosyncrasies)."
144 (let ((sorted-result-truenamestrings (sorted-truenamestrings
146 ;; Relative and absolute pathnames should give the same result.
147 (need-match-1 directory-pathname
148 sorted-result-truenamestrings)
149 (need-match-1 (absolutify directory-pathname)
150 sorted-result-truenamestrings)))
151 (defun need-matches ()
152 "lotso calls to NEED-MATCH"
153 ;; FIXME: As discussed on sbcl-devel ca. 2001-01-01, DIRECTORY should
154 ;; report Unix directory files contained within its output as e.g.
155 ;; "/usr/bin" instead of the CMU-CL-style "/usr/bin/". In that case,
156 ;; s:/":": in most or all the NEED-MATCHes here.
157 (need-match "./*.*" '("animal/" "dirt" "plant/" "water"))
158 (need-match "*.*" '("animal/" "dirt" "plant/" "water"))
159 (need-match "animal" '("animal/"))
160 (need-match "./animal" '("animal/"))
161 (need-match "animal/*.*" '("animal/invertebrate/" "animal/vertebrate/"))
162 (need-match "animal/*/*.*"
163 '("animal/vertebrate/bird/"
164 "animal/vertebrate/mammal/"
165 "animal/vertebrate/snake/"))
166 (need-match "plant/*.*" '("plant/kingsfoil" "plant/pipeweed"))
167 (need-match "plant/**/*.*" '("plant/kingsfoil" "plant/pipeweed"))
168 (need-match "plant/**/**/*.*" '("plant/kingsfoil" "plant/pipeweed"))
169 (let ((vertebrates (mapcar (lambda (stem)
175 "mammal/bear/" "mammal/bear/grizzly"
176 "mammal/mythical/" "mammal/mythical/mermaid"
177 "mammal/mythical/unicorn"
179 "mammal/rodent/" "mammal/rodent/beaver"
180 "mammal/rodent/mouse" "mammal/rodent/rabbit"
182 "mammal/ruminant/" "mammal/ruminant/cow"
184 "snake/" "snake/python"))))
185 (need-match "animal/vertebrate/**/*.*" vertebrates)
186 (need-match "animal/vertebrate/mammal/../**/*.*" vertebrates)
187 (need-match "animal/vertebrate/mammal/../**/**/*.*" vertebrates)
189 (need-match "animal/vertebrate/mammal/mythical/../**/../**/*.*"
191 (need-match "animal/vertebrate/**/robot.*" nil)
192 (need-match "animal/vertebrate/mammal/../**/*.robot" nil)
193 (need-match "animal/vertebrate/mammal/../**/robot/*.*" nil)
195 (need-match "animal/vertebrate/mammal/robot/../**/../**/*.*" nil))
197 (sb-ext:quit :unix-status $EXIT_LISP_WIN)
199 check_status_maybe_lose
"DIRECTORY/TRUENAME part 3" $?
201 # Test whether ENSURE-DIRECTORIES-EXIST can create a directory whose
202 # name contains a wildcard character (it used to get itself confused
204 run_sbcl
--eval '(ensure-directories-exist "foo\\*bar/baz.txt")' --eval '(sb-ext:quit)'
206 check_status_maybe_lose
"ENSURE-DIRECTORIES-EXIST part 1" $? \
207 0 "(directory exists)"
209 run_sbcl
--eval '(ensure-directories-exist "foo\\?bar/baz.txt")' --eval '(sb-ext:quit)'
211 check_status_maybe_lose
"ENSURE-DIRECTORIES-EXIST part 2" $? \
212 0 "(directory exists)"
214 # success convention for script