summaryrefslogtreecommitdiffstats
path: root/tests/common.tl
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2015-07-23 08:06:43 -0700
committerKaz Kylheku <kaz@kylheku.com>2015-07-23 08:06:43 -0700
commitb2a47642713286c195d2e4fd27b67019a0cba411 (patch)
tree18f0d330e20e3a416cda7b1f7f7ae35bba7a2221 /tests/common.tl
parent956785645ee52c5c7226d6eddd47dc01c7f33567 (diff)
downloadtxr-b2a47642713286c195d2e4fd27b67019a0cba411.tar.gz
txr-b2a47642713286c195d2e4fd27b67019a0cba411.tar.bz2
txr-b2a47642713286c195d2e4fd27b67019a0cba411.zip
Split off test macros from ifa.tl into common file.
* Makefile (TESTS_OUT): Don't use find to hunt down tests; but rather wildcard. This way common.tl is not mistakenly identified as an independent test file. * tests/012/ifa.tl: Removed test code, placed in new file which is loaded. * tests/common.tl: New file.
Diffstat (limited to 'tests/common.tl')
-rw-r--r--tests/common.tl13
1 files changed, 13 insertions, 0 deletions
diff --git a/tests/common.tl b/tests/common.tl
new file mode 100644
index 00000000..f4ad7351
--- /dev/null
+++ b/tests/common.tl
@@ -0,0 +1,13 @@
+(defmacro error-to-sym (expr)
+ ^(catch ,expr
+ (error (cond) :error)))
+
+(defmacro test (:env env expr expected)
+ (catch
+ (let ((expr-expn (macroexpand expr env)))
+ ^(ifa (not (equal (error-to-sym ,expr-expn) ',expected))
+ (error "test case ~s failed: produced ~s; expected ~s"
+ ',expr it ',expected)))
+ (error (exc)
+ (unless (eq expected :error)
+ (error "test case ~s failed to expand: expected is ~s" expr expected)))))