-
Notifications
You must be signed in to change notification settings - Fork 0
/
testrun-ert.el
58 lines (47 loc) · 2.03 KB
/
testrun-ert.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
;;; testrun-ert.el --- ERT wrapper for testrun -*- lexical-binding: t -*-
;; Copyright (C) 2023 Alessandro Martini <[email protected]>
;; Author: Alessandro Martini <[email protected]>
;; Mantainer: Alessandro Martini <[email protected]>
;; Version: 0.1.1
;; Package-Requires: ((emacs "29"))
;; Keywords: tests convenience
;; Homepage: https://github.com/martini97/testrun.el
;; This file is NOT part of GNU Emacs.
;; This file is free software: you can redistribute it and/or modify it
;; under the terms of the GNU General Public License as published by the
;; Free Software Foundation, either version 3 of the License, or (at
;; your option) any later version.
;;
;; This file is distributed in the hope that it will be useful, but
;; WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
;; General Public License for more details.
;;
;; You should have received a copy of the GNU General Public License
;; along with this file. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; ERT helpers for `testrun'.
;;; Code:
(require 'testrun-core)
(require 'testrun-sexp)
(defun testrun-ert--get-test-name-at-point ()
"Get the name of the current test at point."
(if-let ((test-at-point (car (seq-map #'cadr (testrun-sexp--filter-car-memq
(testrun-sexp--parents)
'(ert-deftest))))))
test-at-point
(user-error "No test at point")))
;;;###autoload
(defun testrun-ert-get-test (scope)
"Get the ERT test specifier string for the SCOPE."
(string-join
(let ((filename (testrun-core--file-name)))
(pcase scope
("nearest" (list filename "-p" (testrun-core--get-test-regex
(testrun-ert--get-test-name-at-point) t)))
("namespace" (user-error "ERT does not support the \"%s\" scope" scope))
("file" (list filename))
("all" nil)))
" "))
(provide 'testrun-ert)
;;; testrun-ert.el ends here