Skip to content

Commit

Permalink
Refactor util tests: with-temp-buffer -> with-clojure-buffer
Browse files Browse the repository at this point in the history
Also fixes a few tests which did not enable clojure-mode
  • Loading branch information
yuhan0 committed Oct 31, 2019
1 parent 4db84fd commit a2db24c
Showing 1 changed file with 26 additions and 33 deletions.
59 changes: 26 additions & 33 deletions test/cider-util-tests.el
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,22 @@
(require 'buttercup)
(require 'cider-util)

(defmacro with-clojure-buffer (contents &rest body)
"Execute BODY in a clojure-mode with CONTENTS
CONTENTS can be a single string to be inserted before the cursor, or a cons
cell of strings (BEFORE . AFTER) where the cursor is placed in between
them."
(declare (indent 1))
`(with-temp-buffer
(delay-mode-hooks (clojure-mode))
,@(if (stringp contents)
`((insert ,contents))
`((insert ,(car contents))
(save-excursion
(insert ,(cdr contents)))))
,@body))

;;; cider-util tests

(describe "cider--version"
Expand Down Expand Up @@ -71,26 +87,20 @@

(describe "cider-symbol-at-point"
(it "doesn't move the cursor"
(with-temp-buffer
(clojure-mode)
(insert "something else\n")
(with-clojure-buffer "something else\n"
(expect (cider-symbol-at-point) :not :to-be-truthy)
(expect (cider-symbol-at-point 'lookback) :to-equal "else")
(expect (point) :to-equal (point-max))))

(describe "when there is a symbol at point"
(it "returns the symbol"
(with-temp-buffer
(clojure-mode)
(insert "some-symbol ")
(with-clojure-buffer "some-symbol "
(expect (cider-symbol-at-point) :not :to-be-truthy)
(expect (cider-symbol-at-point 'look-back) :to-equal "some-symbol"))))

(describe "when the symbol at point has a trailing ."
(it "returns the symbol without the ."
(with-temp-buffer
(clojure-mode)
(insert "SomeRecord.")
(with-clojure-buffer "SomeRecord."
(expect (cider-symbol-at-point) :to-equal "SomeRecord"))))

(describe "when there's nothing at point"
Expand All @@ -100,8 +110,7 @@

(describe "when on an opening paren"
(it "returns the following symbol"
(with-temp-buffer
(insert "(some function call)")
(with-clojure-buffer "(some function call)"
(goto-char (point-min))
(expect (cider-symbol-at-point 'look-back) :to-equal "some"))))

Expand All @@ -119,10 +128,7 @@
(describe "cider-sexp-at-point"
(describe "when the param 'bounds is not given"
(it "returns the sexp at point"
(with-temp-buffer
(clojure-mode)
(insert "a\n\n,")
(save-excursion (insert "(defn ...)\n\nb"))
(with-clojure-buffer ("a\n\n," . "(defn ...)\n\nb")
(expect (cider-sexp-at-point) :to-equal "(defn ...)")
(insert "@")
(expect (cider-sexp-at-point) :to-equal "(defn ...)")
Expand All @@ -132,31 +138,22 @@

(describe "when the param 'bounds is given"
(it "returns the bounds of starting and ending positions of the sexp"
(with-temp-buffer
(clojure-mode)
(insert "a\n\n,")
(save-excursion (insert "(defn ...)\n\nb"))
(with-clojure-buffer ("a\n\n," . "(defn ...)\n\nb")
(delete-char -1)
(insert "'")
(expect (cider-sexp-at-point 'bounds) :to-equal '(5 15))))))

(describe "cider-defun-at-point"
(describe "when the param 'bounds is not given"
(it "returns the defun at point"
(with-temp-buffer
(clojure-mode)
(insert "a\n\n(defn ...)")
(save-excursion (insert "\n\nb"))
(with-clojure-buffer ("a\n\n(defn ...)" . "\n\nb")
(expect (cider-defun-at-point) :to-equal "(defn ...)\n")
(forward-sexp -1)
(expect (cider-defun-at-point) :to-equal "(defn ...)\n"))))

(describe "when the param 'bounds is given"
(it "returns the bounds of starting and ending positions of the defun"
(with-temp-buffer
(clojure-mode)
(insert "a\n\n(defn ...)")
(save-excursion (insert "\n\nb"))
(with-clojure-buffer ("a\n\n(defn ...)" . "\n\nb")
(expect (cider-defun-at-point 'bounds) :to-equal '(4 15))))))

(describe "cider-repl-prompt-function"
Expand Down Expand Up @@ -216,10 +213,7 @@

(describe "cider-second-sexp-in-list"
(it "returns the second sexp in the list"
(with-temp-buffer
(clojure-mode)
(insert "(test-function arg1 arg2 arg3)")
(backward-char 2)
(with-clojure-buffer ("(test-function arg1 arg2 arg" . "3)")
(expect (cider-second-sexp-in-list) :to-equal "arg1"))))

(describe "cider-ansi-color-string-detect"
Expand Down Expand Up @@ -260,8 +254,7 @@

(describe "works in buffers"
(it "fontifies with correct face"
(with-temp-buffer
(insert "aaa bbb\n cccc\n ddddd")
(with-clojure-buffer "aaa bbb\n cccc\n ddddd"
(goto-char 1)
(cider-add-face "c+" 'font-lock-comment-face)
(expect (get-pos-property 11 'face)
Expand Down

0 comments on commit a2db24c

Please sign in to comment.