This repository has been archived by the owner on Jan 21, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathrun-tests.lisp
executable file
·84 lines (69 loc) · 2.58 KB
/
run-tests.lisp
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
#!/bin/sh
#|-*- mode:lisp -*-|#
#|
exec ros -Q -- $0 "$@"
|#
(progn ;;init forms
(ros:ensure-asdf)
#+quicklisp(ql:quickload '() :silent t))
(in-package :common-lisp-user)
(eval-when (:compile-toplevel :load-toplevel :execute)
(defun ~ (path)
(merge-pathnames path (user-homedir-pathname)))
(defun load-quicklisp ()
(block nil
(flet ((try (x) (when (probe-file x) (return (load x)))))
(try (~ "quicklisp/setup.lisp"))
(try (~ ".quicklisp/setup.lisp"))
(error "Can't find an installation of quicklisp."))))
#-quicklisp
(load-quicklisp))
(eval-when (:compile-toplevel :load-toplevel :execute)
#-fiveam
(ql:quickload 'fiveam)
#-unixoptions
(ql:quickload 'unix-options))
;; CFFI grovel is needed for cl-git.asd
(ql:quickload 'cffi)
(push (truename #p"./") asdf:*central-registry*)
(ql:quickload (asdf:system-depends-on (asdf:find-system 'cl-git)))
(ql:quickload 'cl-git :verbose t)
(ql:quickload (asdf:system-depends-on (asdf:find-system 'cl-git/tests)))
(ql:quickload 'cl-git/tests :verbose t)
(defun safe-trace (sym package)
(handler-bind ((simple-error
#'(lambda (c)
(declare (ignore c))
(format t "Skipping Symbol (probably a macro)~%")
(invoke-restart 'skip-symbol))))
(when (and (fboundp sym)
(functionp (symbol-function sym))
;(not (macrop sym))
(equal (package-name (symbol-package sym))
package))
(format t "Trying to trace Symbol ~A~%" sym)
(restart-case
(eval `(trace ,(intern (symbol-name sym) package)))
(skip-symbol () nil)))))
(defun main (&rest argv)
(unix-options:with-cli-options (argv)
(help trace)
(when help
(unix-options:print-usage-summary
"Usage:~%~@{~A~%~}"
'(((#\t "trace") nil "trace the functions during a test run.")))
(uiop::quit :unix-status 1))
(when trace
(do-symbols (sym 'cl-git)
(safe-trace sym "CL-GIT"))))
(let ((result-list (fiveam:run :cl-git)))
(fiveam:explain! result-list)
#+sbcl
(sb-ext:gc :full t)
(uiop:quit
(if (remove-if-not
(lambda (res)
(typep res 'fiveam::test-failure))
result-list)
1 0))))
;;; vim: set ft=lisp lisp: