tests: Refine exception handling.

* tests/gpgscm/init.scm (catch): Bind all arguments to '*error*' in
the error handler, update and fix comment.
(*error-hook*): Revert to original definition.
* tests/gpgscm/tests.scm (tr:do): Adapt accordingly.
* tests/openpgp/issue2419.scm: Likewise.

Signed-off-by: Justus Winter <justus@g10code.com>
This commit is contained in:
Justus Winter 2016-09-19 17:19:00 +02:00
parent 83a406b38a
commit ab483eff9a
3 changed files with 7 additions and 7 deletions

View File

@ -544,13 +544,14 @@
;
; "Catch" establishes a scope spanning multiple call-frames until
; another "catch" is encountered. Within the recovery expression
; the thrown exception is bound to *error*.
; the thrown exception is bound to *error*. Errors can be rethrown
; using (apply throw *error*).
;
; Exceptions are thrown with:
;
; (throw "message")
;
; If used outside a (catch ...), reverts to (error "message)
; If used outside a (catch ...), reverts to (error "message")
(define *handlers* (list))
@ -573,13 +574,12 @@
(macro (catch form)
(let ((label (gensym)))
`(call/cc (lambda (**exit**)
(push-handler (lambda (*error*) (**exit** ,(cadr form))))
(push-handler (lambda *error* (**exit** ,(cadr form))))
(let ((,label (begin ,@(cddr form))))
(pop-handler)
,label)))))
(define (*error-hook* . args)
(throw args))
(define *error-hook* throw)
;;;;; Definition of MAKE-ENVIRONMENT, to be used with two-argument EVAL

View File

@ -411,7 +411,7 @@
(if error
(begin
(for-each remove-temporary-file tmpfiles')
(throw error)))
(apply throw error)))
(loop tmpfiles' sink (cdr cmds))))))
(define (tr:open pathname)

View File

@ -23,6 +23,6 @@
(lettmp
(onebyte)
(dearmor (in-srcdir "samplemsgs/issue2419.asc") onebyte)
(catch (assert (string-contains? *error* "invalid packet"))
(catch (assert (string-contains? (car *error*) "invalid packet"))
(call-popen `(,@GPG --list-packets ,onebyte) "")
(error "Expected an error but got none")))