X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=tests%2Farray.pure.lisp;h=7f5c11f70258a3b214142bd9df60643da24909b1;hb=f81f78b9a2a4ec8e2bef6074de121885c6f19e44;hp=7760a6ce76ef65ca46cc2e1981d52dcd8b9d446a;hpb=88dab5bc2cb92077bced88729dc95096b3b6a127;p=sbcl.git diff --git a/tests/array.pure.lisp b/tests/array.pure.lisp index 7760a6c..7f5c11f 100644 --- a/tests/array.pure.lisp +++ b/tests/array.pure.lisp @@ -226,3 +226,38 @@ (let ((ary (make-array '(2 2)))) ;; SBCL used to give multidimensional arrays a bogus fill-pointer (assert (not (array-has-fill-pointer-p (adjust-array ary '(2 2))))))) + +(with-test (:name %set-fill-pointer/error) + (let ((v (make-array 3 :fill-pointer 0))) + (handler-case + (progn + (setf (fill-pointer v) 12) + (error "WTF")) + (error (e) + (assert (eql 12 (type-error-datum e))) + (assert (equal '(integer 0 3) (type-error-expected-type e))))))) + +(with-test (:name array-storage-vector) + (let ((vec (vector 1 2 3))) + (assert (eq vec (sb-ext:array-storage-vector vec))) + (assert (equalp (vector 1 2 3 4) + (sb-ext:array-storage-vector + (make-array '(2 2) :initial-contents '((1 2) (3 4)))))) + (assert (eq 'fixnum (array-element-type + (sb-ext:array-storage-vector (make-array '(3 4 5) + :element-type 'fixnum))))) + (assert (not (array-has-fill-pointer-p + (sb-ext::array-storage-vector + (make-array 5 :fill-pointer 4))))))) + +(with-test (:name invalid-array-index-error) + (let ((array (make-array '(3 3 3)))) + (assert + (eq :right + (handler-case + (eval `(aref ,array 0 1 3)) + (sb-int:invalid-array-index-error (e) + (when (and (eq array (sb-kernel::invalid-array-index-error-array e)) + (= 3 (type-error-datum e)) + (equal '(integer 0 (3)) (type-error-expected-type e))) + :right)))))))