Mercurial > hg > xemacs-beta
changeset 4856:9bf09492cff7
Clean up macro Assert
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Thu, 14 Jan 2010 02:29:13 -0600 |
parents | 189fb67ca31a |
children | 34ff4dd7397d |
files | tests/automated/test-harness.el |
diffstat | 1 files changed, 24 insertions(+), 22 deletions(-) [+] |
line wrap: on
line diff
--- a/tests/automated/test-harness.el Thu Jan 14 02:18:03 2010 -0600 +++ b/tests/automated/test-harness.el Thu Jan 14 02:29:13 2010 -0600 @@ -1,7 +1,7 @@ ;; test-harness.el --- Run Emacs Lisp test suites. ;;; Copyright (C) 1998, 2002, 2003 Free Software Foundation, Inc. -;;; Copyright (C) 2002 Ben Wing. +;;; Copyright (C) 2002, 2010 Ben Wing. ;; Author: Martin Buchholz ;; Maintainer: Stephen J. Turnbull <stephen@xemacs.org> @@ -269,27 +269,29 @@ (defmacro Assert (assertion &optional failing-case description) "Test passes if ASSERTION is true. -Optional FAILING-CASE describes the particular failure. -Optional DESCRIPTION describes the assertion. -FAILING-CASE and DESCRIPTION are useful when Assert is used in a loop." - `(condition-case error-info - (progn - (assert ,assertion) - (Print-Pass "%S" ,(or description `(quote ,assertion))) - (incf passes)) - (cl-assertion-failed - (Print-Failure (if ,failing-case - "Assertion failed: %S; failing case = %S" - "Assertion failed: %S") - ,(or description `(quote ,assertion)) ,failing-case) - (incf assertion-failures)) - (t (Print-Failure (if ,failing-case - "%S ==> error: %S; failing case = %S" - "%S ==> error: %S") - ,(or description `(quote ,assertion)) - error-info ,failing-case) - (incf other-failures) - ))) +Optional FAILING-CASE describes the particular failure. Optional +DESCRIPTION describes the assertion; by default, the unevalated assertion +expression is given. FAILING-CASE and DESCRIPTION are useful when Assert +is used in a loop." + (let ((description + (or description `(quote ,assertion)))) + `(condition-case error-info + (progn + (assert ,assertion) + (Print-Pass "%S" ,description) + (incf passes)) + (cl-assertion-failed + (Print-Failure (if ,failing-case + "Assertion failed: %S; failing case = %S" + "Assertion failed: %S") + ,description ,failing-case) + (incf assertion-failures)) + (t (Print-Failure (if ,failing-case + "%S ==> error: %S; failing case = %S" + "%S ==> error: %S") + ,description error-info ,failing-case) + (incf other-failures) + )))) (defmacro Assert-test (test testval expected &optional failing-case description)