File: testsuite.ss

package info (click to toggle)
swig 3.0.10-1.1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 40,672 kB
  • ctags: 18,134
  • sloc: cpp: 57,901; ansic: 26,762; java: 11,026; python: 8,544; cs: 6,999; makefile: 6,450; yacc: 5,649; sh: 5,201; ruby: 4,680; perl: 3,461; php: 1,880; lisp: 1,827; tcl: 1,068; ml: 747; xml: 115
file content (12 lines) | stat: -rw-r--r-- 540 bytes parent folder | download | duplicates (14)
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))))