1 ;;;; This software is part of the SBCL system. See the README file for
4 ;;;; While most of SBCL is derived from the CMU CL system, the test
5 ;;;; files (like this one) were written from scratch after the fork
8 ;;;; This software is in the public domain and is provided with
9 ;;;; absolutely no warranty. See the COPYING and CREDITS files for
10 ;;;; more information.
12 (in-package "CL-USER")
14 ;;; Test for monotonicity of GET-INTERNAL-RUN-TIME.
15 #+nil ; FIXME: This test can't work as long as
16 ; (FUNCALL (COMPILE NIL (LAMBDA (X) (+ X 12))) 44)
18 ; #<FUNCTION {5009BF31}> was defined in a non-null environment.
21 (declare (type fixnum n-seconds))
22 (let* ((n-internal-time-units
24 internal-time-units-per-second))
25 (time0 (get-internal-run-time))
26 (time1 (+ time0 n-internal-time-units)))
28 (let ((time (get-internal-run-time)))
29 (assert (>= time time0))
35 (declare (notinline mapcar))
36 (mapcar (lambda (args)
37 (destructuring-bind (obj type-spec result) args
38 (flet ((matches-result? (x)
39 (eq (if x t nil) result)))
40 (assert (matches-result? (typep obj type-spec)))
41 (assert (matches-result? (sb-kernel:ctypep
43 (sb-kernel:specifier-type
45 '((nil (or null vector) t)
46 (nil (or number vector) nil)
47 (12 (or null vector) nil)
48 (12 (and (or number vector) real) t))))