aboutsummaryrefslogtreecommitdiff
path: root/test/test-macros.el
diff options
context:
space:
mode:
authorSean Allred <code@seanallred.com>2015-01-01 19:11:21 -0500
committerSean Allred <code@seanallred.com>2015-01-01 19:11:21 -0500
commitde9bf24bb7ccbb5f94cc523d4eb291ed793537fd (patch)
tree30a03a95b3184c00432bc01144435b4a2e28ce14 /test/test-macros.el
parent39116611ea99b3b0ba33545d38c2983a17db487d (diff)
parente05f937910bb4ca0e7ea1c9f1273fbafac523921 (diff)
Merge branch 'master' into search
Diffstat (limited to 'test/test-macros.el')
-rw-r--r--test/test-macros.el22
1 files changed, 22 insertions, 0 deletions
diff --git a/test/test-macros.el b/test/test-macros.el
new file mode 100644
index 0000000..2169088
--- /dev/null
+++ b/test/test-macros.el
@@ -0,0 +1,22 @@
+(defmacro sx-test-with-json-data (cell &rest body)
+ "Run BODY with sample data let-bound to CELL"
+ (declare (indent 1))
+ `(let ((,cell '((test . nil) (test-one . 1) (test-two . 2)
+ (link . "http://meta.emacs.stackexchange.com/"))))
+ ,@body))
+
+(ert-deftest macro-test--sx-assoc-let ()
+ "Test `sx-assoc-let'"
+ (sx-test-with-json-data data
+ (should
+ (null (let-alist data .site))))
+
+ (sx-test-with-json-data data
+ (should
+ (equal (sx-assoc-let data .site)
+ "meta.emacs")))
+
+ (sx-test-with-json-data data
+ (should
+ (equal (sx-assoc-let data (cons .test-one .test-two))
+ '(1 . 2)))))