(module exn-test mzscheme
(require (lib "etc.ss")
(lib "string.ss" "srfi" "13"))
(require (file "test-base.ss"))
(provide exn-tests)
(define-struct (exn:test exn) (extra-arg) #f)
(define exn-tests
(test-suite
"All tests for exn"
(test-case
"raise-exn raises an exception"
(check-exn
exn:fail:unlib?
(lambda ()
(raise-exn exn:fail:unlib
"This is an exception."))))
(test-case
"raise-exn passes extra arguments to exception constructor"
(with-handlers ([exn:test?
(lambda (exn)
(check-equal? (exn:test-extra-arg exn)
123))])
(raise-exn exn:test "Message" 123)))
(test-case
"raise-exn/append raises an exception (DEPRECATED)"
(check-exn
exn:fail:unlib?
(lambda ()
(raise-exn/append exn:fail:unlib
"This is an exception. "
"Oh yes it is."))))
(test-case
"raise-exn/format raises an exception (DEPRECATED)"
(check-exn
exn:fail:unlib?
(lambda ()
(raise-exn/format exn:fail:unlib
"This is an exception. ~a Test number ~a."
"Oh yes it is."
69))))
(test-case
"reraise-exn raises an exception"
(check-exn
exn:unlib?
(lambda ()
(reraise-exn (make-exn "Boo!" (current-continuation-marks))
exn:unlib
"Foo!"))))
(test-case
"reraise-exn includes old and new messages"
(with-handlers
([exn:unlib?
(lambda (exn)
(let ([msg (exn-message exn)])
(check string-contains msg "Boo!")
(check string-contains msg "Foo!")))])
(reraise-exn (make-exn "Boo!" (current-continuation-marks))
exn:unlib
"Foo!")))
(test-case
"reraise-exn includes continuation marks of original exn"
(let ([marks #f]
[exn #f])
(with-handlers
([exn?
(lambda (e)
(set! marks (exn-continuation-marks e))
(set! exn e))])
(raise (make-exn "This is an exception" (current-continuation-marks))))
(with-handlers
([exn:unlib?
(lambda (e)
(check-equal? (exn-continuation-marks e) marks))])
(reraise-exn exn exn:unlib "Foo!"))))
(test-case
"reraise-exn passes extra arguments to exception constructor"
(with-handlers ([exn:test?
(lambda (exn)
(check-equal? (exn:test-extra-arg exn)
123))])
(reraise-exn (with-handlers ([exn? identity])
(raise-exn exn "Message 1"))
exn:test
"Message 2"
123)))
))
)