Skip to content

Commit

Permalink
Fix loading of fiveam-asdf defsystem.
Browse files Browse the repository at this point in the history
Previously, we were forced to load that system by hand, when reading
the ASDF system definition. By pulling some code out, and by using
strings for class designators in shop3.asd's tester systems, we no
longer have to do this.
  • Loading branch information
rpgoldman committed Feb 13, 2024
1 parent 96ab960 commit 8bc4937
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 31 deletions.
3 changes: 3 additions & 0 deletions shop3/shop-silent-test.asd
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
(defsystem shop-silent-test
:depends-on ((:version "fiveam-asdf" "2"))
:components ((:file "silent-shop-test")))
33 changes: 6 additions & 27 deletions shop3/shop3.asd
Original file line number Diff line number Diff line change
Expand Up @@ -195,27 +195,6 @@ minimal affected subtree."
;;; Testing
;;;---------------------------------------------------------------------------

(asdf:load-system "fiveam-asdf")

(defclass tester-cl-source-file ( cl-file )
()
(:documentation "Special class that will have to recompile no matter
what..."))

(defmethod operation-done-p
((o compile-op)
(c tester-cl-source-file))
"We are crushing the normal operation-done-p for compile-op, so that
the tester files get recompiled, to take into account any changes to
shop3."
(values nil))

(defclass shop-tester-mixin ()
()
(:documentation "Mixin that adds silent functioning of SHOP3."))


(defclass shop-fiveam-tester (shop-tester-mixin fiveam-tester-system) ())

(defsystem shop3/openstacks
:depends-on (:shop3)
Expand All @@ -232,8 +211,8 @@ shop3."


(defsystem shop3/test
:defsystem-depends-on ((:version "fiveam-asdf" "2"))
:class shop-fiveam-tester
:defsystem-depends-on ("shop-silent-test")
:class "silent-shop-test:shop-fiveam-tester"
:test-names ((pddl-tests . :shop3) ; 144
(protection-test . :protection-test) ; 16
;; all the following are now subsumed into all-shop3-internal-tests
Expand Down Expand Up @@ -377,8 +356,8 @@ shop3."


(defsystem shop3/test-satellite
:defsystem-depends-on ((:version "fiveam-asdf" "2"))
:class shop-fiveam-tester
:defsystem-depends-on ("shop-silent-test")
:class "silent-shop-test:shop-fiveam-tester"
:test-names (("SATELLITE-ADL-TESTS" . "TEST-SATELLITE"))
:num-checks 80
:depends-on ((:version "shop3" (:read-file-form "shop-version.lisp-expr"))
Expand All @@ -389,8 +368,8 @@ shop3."
:components ((:file "test-satellite")))

(defsystem shop3/test-unifier
:defsystem-depends-on ((:version "fiveam-asdf" "2"))
:class shop-fiveam-tester
:defsystem-depends-on ("shop-silent-test")
:class "silent-shop-test:shop-fiveam-tester"
:test-names (("TEST-SHOP-UNIFIER" . "SHOP-UNIFIER-TESTS"))
:num-checks 36
:depends-on ("shop3/unifier" "alexandria")
Expand Down
19 changes: 15 additions & 4 deletions shop3/silent-shop-test.lisp
Original file line number Diff line number Diff line change
@@ -1,6 +1,17 @@
(defpackage :silent-shop-test
(:use :asdf :common-lisp)
(:export #:shop-fiveam-tester))

(defmethod asdf:perform :around ((op asdf:test-op)
(component shop2-asd::shop-tester-mixin))
(let ((shop::*silent* t))
(declare (special shop::*silent*))
(in-package #:silent-shop-test)


(defclass shop-tester-mixin ()
()
(:documentation "Mixin that adds silent functioning of SHOP3."))

(defclass shop-fiveam-tester (shop-tester-mixin fiveam-tester-system) ())

(defmethod perform :around ((op test-op)
(component shop-tester-mixin))
(progv (list (uiop:intern* '#:*silent* '#:shop))
(call-next-method)))

0 comments on commit 8bc4937

Please sign in to comment.