This file is indexed.

/usr/share/common-lisp/source/hunchentoot/run-test.lisp is in cl-hunchentoot 1.2.35-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
;;; -*- Mode: LISP; Syntax: COMMON-LISP; Package: HUNCHENTOOT; Base: 10 -*-

;;; Copyright (c) 2011, Hans Huebner.  All rights reserved.

;;; Redistribution and use in source and binary forms, with or without
;;; modification, are permitted provided that the following conditions
;;; are met:

;;;   * Redistributions of source code must retain the above copyright
;;;     notice, this list of conditions and the following disclaimer.

;;;   * Redistributions in binary form must reproduce the above
;;;     copyright notice, this list of conditions and the following
;;;     disclaimer in the documentation and/or other materials
;;;     provided with the distribution.

;;; THIS SOFTWARE IS PROVIDED BY THE AUTHOR 'AS IS' AND ANY EXPRESSED
;;; OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
;;; WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
;;; ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
;;; DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
;;; DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
;;; GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
;;; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
;;; WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
;;; NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
;;; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

(in-package :cl-user)

(defparameter *test-port* 4241)

(asdf:oos 'asdf:load-op :hunchentoot-test)

(defun run-tests ()
  (format t "~&;; Starting web server on localhost:~A." *test-port*)
  (force-output)
  (let ((server (hunchentoot:start (make-instance 'hunchentoot:easy-acceptor :port *test-port*))))
    (unwind-protect
         (progn
           (format t "~&;; Sleeping 2 seconds to give the server some time to start...")
           (force-output)
           (sleep 2)
           (format t "~&;; Now running confidence tests.")
           (force-output)
           (hunchentoot-test:test-hunchentoot (format nil "http://localhost:~A" *test-port*)))
      (format t "~&;; Stopping server.")
      (force-output)
      (hunchentoot:stop server)
      (format t "~&;; Cleaning temporary files.")
      (hunchentoot-test::clean-tmp-dir))))

#-sbcl
(run-tests)

;;; KLUDGE (by Nikodemus Siivola)
;;;
;;; SBCL grabs a massive lock in WITH-COMPILATION-UNIT, which ASDF
;;; uses in PERFORM-PLAN ... which makes spawning threads during testing
;;; problematic to say the least.
;;;
;;; So, release the world lock for the duration. Nikodemus says that in this
;;; specific usage this should be safe --- and promises that people who copy
;;; this code and use it elsewhere will burn in hell for their sins.
;;;
;;; More promisingly, he swears up and down that that massive lock from
;;; W-C-U will be gone by early 2012 at the latest, so this will not be
;;; an eternal kludge, we hope.
(defun %call-without-world-lock-kludge (thunk)
  #+(and sbcl sb-thread)
  (let ((s (find-symbol "**WORLD-LOCK**" :sb-c)))
    (if (and s (boundp s))
        (let ((lock (symbol-value s)))
          (unwind-protect
               (progn
                 (if (sb-thread:holding-mutex-p lock)
                     (sb-thread:release-mutex lock)
                     (setf lock nil))
                 (funcall thunk))
            (when lock
              (sb-thread:grab-mutex lock))))
        (funcall thunk)))
  #-(and sbcl sb-thread)
  (funcall thunk))

#+sbcl
(%call-without-world-lock-kludge 'run-tests)