File: testsuite.ss

package info (click to toggle)
swig 3.0.12-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 42,432 kB
  • sloc: cpp: 60,198; ansic: 26,820; java: 11,321; python: 8,837; cs: 7,181; makefile: 6,575; yacc: 5,682; sh: 5,201; ruby: 4,648; perl: 3,461; php: 2,119; lisp: 1,835; tcl: 1,068; ml: 747; xml: 115
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))))