-
Notifications
You must be signed in to change notification settings - Fork 53
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Testing conventions #58
Comments
There's also the question - should you use ERT in the first place? :-) I don't like it much and I think the solutions like Buttercup result in way nicer test suites. But in general I agree that's an important topic that doesn't get enough coverage. |
Totally agree about having other frameworks too included in this kind of best-practices guide (which is a bit more than style only). There should be best practices for buttercup too I think. Either way if you think this is not the place to do it let's close it. Wdyt? |
This is something I wanted to write for some time... I'm one of those perverts who enjoy testing 😊 . There's definitely a lot of approaches in elisp and quite often writing tests is the biggest pain when contributing. I've seen my share of arcane setups. Especially since ERT is very free-form by design. Buttercup is much nicer because it forces you to do things mostly one way. I have written this for the smartparens project specifically but there is some general info which could be extracted: https://github.com/Fuco1/smartparens/wiki/Testing The general remarks are sort of similar across all languages not just elisp/emacs:
Obviously apply common sense, nothing is absolute. About frameworks, I would push buttercup where possible. For "legacy" projects on ERT, migrations might be useful depending on the scope. For example in smartparens we have over 2000 test cases and migration would be very difficult. If you have 50 tests I would bite the bullet and switch. For things like "run in a sandbox" I would write a helper (for example using Naming of tests to me is not very important so long as it's unique :D For complicated setups describe the preconditions and why you are testing this thing (for example link to an issue). ERT tests can have docstrings, for example: ;; #699
(ert-deftest sp-test-get-thing-clojure-with-regexp-based-prefix nil
"When the point is inside a prefix which is not a syntactic
prefix and we try to skip to previous symbol, the prefix might
stop the skip routine and prevent the previous token from being
picked up, causing `sp-get-thing' to take the 2nd previous one."
(let ((sp-sexp-prefix '((clojure-mode regexp "#")))
(sp-pairs '((t . ((:open "(" :close ")" :actions (insert wrap autoskip navigate))
(:open "{" :close "}" :actions (insert wrap autoskip navigate)))))))
(sp-test-thing-parse-in-clojure "(atom #|{})" '(:beg 2 :end 6 :op "" :cl "" :prefix "" :suffix "") t))) When I want to group multiple tests, I use (prog1 "#821 sp-backward-kill-word skips over prefix and does not
kill it as a word/symbol"
(ert-deftest sp-test-ess-prefix-resolution-ignored-for-backward-kill-symbol--string ()
(sp-test-with-temp-buffer "mean(\"foo|\")"
(sp-test--ess-mode)
(sp-backward-kill-word 1)
(sp-buffer-equals "mean(\"|\")")))
(ert-deftest sp-test-ess-prefix-resolution-ignored-for-backward-kill-symbol--function-call ()
(sp-test-with-temp-buffer "ggplot(mtcars, aes(mpg, am)) + facet_wrap|()"
(sp-test--ess-mode)
(sp-backward-kill-word 1)
(sp-buffer-equals "ggplot(mtcars, aes(mpg, am)) + facet_|()")))) That's enough for now. |
I'd like to hear what convention the names of the tests should conform to. Typically if your main elisp file is |
And if I have a test file |
Hi and thanks for this awesome style guide. It truly helps adding standards to this community and is also a place to discover best practices by established Elisp seniors.
One thing I miss from all this is testing conventions. It seems the community is just recently investing more time in CI pipelines with testing, coverage reports and so on. From my personal opinion, though, this topic is still not widely discussed nor standardized. Things like:
Maybe this should be a NEW style guide that could first recommend this one, but I think this will help a lot too.
Anyway, if this feels out of place feel free to simply close it. Once again, thanks for all your work!
The text was updated successfully, but these errors were encountered: