/usr/share/acl2-7.2dfsg/books/make-event/assert-check.lisp is in acl2-books-source 7.2dfsg-3.
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 | ; Copyright (C) 2013, Regents of the University of Texas
; Written by Matt Kaufmann
; License: A 3-clause BSD license. See the LICENSE file distributed with ACL2.
; This variant of assert.lisp runs assertions at all times, rather than
; skipping them during include-book and the second pass of encapsulate. The
; comment below "Specific to this file", below, describes the interesting
; difference between this file and assert.lisp.
(in-package "ACL2")
(defun assert!!-body (assertion form)
`(let ((assertion ,assertion))
(er-progn
(if assertion
(value nil)
(er soft 'assertion
"Assertion failed:~%~x0"
'(assert!! ,assertion ,@(and form (list form)))))
(value ',(or form '(value-triple nil))))))
(defmacro assert!! (&whole whole-form
assertion &optional form)
(list 'make-event (assert!!-body assertion form)
:check-expansion t
:on-behalf-of whole-form))
(assert!! (equal 3 3)
(defun assert-test1 (x) x))
; Check that above defun was evaluated.
(value-triple (or (equal (assert-test1 3) 3)
(er hard 'top-level
"Failed to evaluate (assert-test1 3) to 3.")))
; We use the "no_port" annotation below because a test below, labeled "Specific
; to this file", assumes that this book is certified in the boot-strap world.
; See :doc build::pre-certify-book-commands for discussion of no_port.
(include-book "eval-check") ; no_port
(must-fail!
(assert!! (equal 3 4)
(defun assert-test2 (x) x)))
; Check that above defun was not evaluated.
(defun assert-test2 (x)
(cons x x))
; Simple test with no second argument:
(assert!! (equal (append '(a b c) '(d e f))
'(a b c d e f)))
; Check failure of assertion when condition is false:
(must-fail!
(assert!! (equal (append '(a b c) '(d e f))
'(a b))))
(deflabel completed-successes)
; Specific to this file:
; The following requires that this book be certified in the initial
; certification world. It should fail at include-book time if we include the
; book after executing another command, because assert!! uses make-event with
; :check-expansion t. See assert-check-include.lisp for a successful
; include-book and assert-check-include-1.lisp (and
; assert-check-include-1.acl2) for a failed include-book.
(local (make-event
(er-let* ((c (getenv$ "ACL2_CUSTOMIZATION" state)))
(value
(if (and c (not (equal c "NONE")))
`(value-triple
(cw "SKIPPING due to ACL2_CUSTOMIZATION=~x0~%" ,c))
'(assert!!
(equal (access-command-tuple-form
(cddr (car (scan-to-command (w state)))))
'(exit-boot-strap-mode))))))))
; Make sure we get to the end when we include this book under
; assert-check-include.lisp but not under under assert-check-include-1.lisp.
(defun assert-check-end (x)
x)
|