File: testsuite.ss

package info (click to toggle)
swig1.3 1.3.40-3
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 28,512 kB
  • ctags: 14,780
  • sloc: cpp: 41,436; ansic: 31,416; python: 9,313; java: 7,332; makefile: 5,264; cs: 5,231; yacc: 4,995; sh: 4,646; ruby: 3,774; perl: 3,638; lisp: 1,993; php: 1,736; tcl: 1,266; ml: 708
file content (12 lines) | stat: -rw-r--r-- 540 bytes parent folder | download | duplicates (13)
1
2
3
4
5
6
7
8
9
10
11
12
(define (lookup-ext-tag tag)
  (cond
    ((equal? tag '(quote swig-contract-assertion-failed))
      '( ((exn type) #f)) )
    (#t '())))

(define-macro (expect-throw tag-form form)
  `(if (condition-case (begin ,form #t)
         ,@(lookup-ext-tag tag-form)
         ((exn) (print "The form threw a different error than expected: " ',form) (exit 1))
         (var () (print "The form did not error as expected: " ',form) (exit 1)))
   (begin (print "The form returned normally when it was expected to throw an error: " ',form) (exit 1))))