1 ;;; test-org-capture.el --- Tests for org-capture.el -*- lexical-binding: t; -*-
3 ;; Copyright (C) 2015 Nicolas Goaziou
5 ;; Author: Nicolas Goaziou <mail@nicolasgoaziou.fr>
7 ;; This program is free software; you can redistribute it and/or modify
8 ;; it under the terms of the GNU General Public License as published by
9 ;; the Free Software Foundation, either version 3 of the License, or
10 ;; (at your option) any later version.
12 ;; This program is distributed in the hope that it will be useful,
13 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
14 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 ;; GNU General Public License for more details.
17 ;; You should have received a copy of the GNU General Public License
18 ;; along with this program. If not, see <http://www.gnu.org/licenses/>.
22 ;; Unit tests for Org Capture library.
26 (require 'org-capture
)
28 (ert-deftest test-org-capture
/fill-template
()
29 "Test `org-capture-fill-template' specifications."
31 ;; When working on these tests consider to also change
32 ;; `test-org-feed/fill-template'.
34 ;; %(sexp) placeholder.
37 (org-capture-fill-template "%(concat \"success\" \"!\")")))
38 ;; %<...> placeholder.
40 (equal (concat (format-time-string "%Y") "\n")
41 (org-capture-fill-template "%<%Y>")))
42 ;; %t and %T placeholders.
44 (equal (concat (format-time-string (org-time-stamp-format nil nil
)) "\n")
45 (org-capture-fill-template "%t")))
47 (equal (concat (format-time-string (org-time-stamp-format t nil
)) "\n")
48 (org-capture-fill-template "%T")))
49 ;; %u and %U placeholders.
52 (concat (format-time-string (org-time-stamp-format nil t
)) "\n")
53 (org-capture-fill-template "%u")))
56 (concat (format-time-string (org-time-stamp-format t t
)) "\n")
57 (org-capture-fill-template "%U")))
58 ;; %i placeholder. Make sure sexp placeholders are not expanded
59 ;; when they are inserted through this one.
62 (let ((org-store-link-plist nil
))
63 (org-capture-fill-template "%i" "success!"))))
65 (equal "%(concat \"no \" \"evaluation\")\n"
66 (let ((org-store-link-plist nil
))
67 (org-capture-fill-template
68 "%i" "%(concat \"no \" \"evaluation\")"))))
69 ;; Test %-escaping with \ character.
72 (let ((org-store-link-plist nil
))
73 (org-capture-fill-template "\\%i" "success!"))))
76 (let ((org-store-link-plist nil
))
77 (org-capture-fill-template "\\\\%i" "success!"))))
80 (let ((org-store-link-plist nil
))
81 (org-capture-fill-template "\\\\\\%i" "success!"))))
82 ;; More than one placeholder in the same template.
84 (equal "success! success! success! success!\n"
85 (let ((org-store-link-plist nil
))
86 (org-capture-fill-template "%i %i %i %i" "success!"))))
87 ;; %(sexp) placeholder with an input containing the traps %, " and )
88 ;; all at once which is complicated to parse.
90 (equal "5 % Less (See Item \"3)\" Somewhere)\n"
91 (let ((org-store-link-plist nil
))
92 (org-capture-fill-template
93 "%(capitalize \"%i\")"
94 "5 % less (see item \"3)\" somewhere)")))))
96 (ert-deftest test-org-capture
/refile
()
97 "Test `org-capture-refile' specifications."
98 ;; When refiling, make sure the headline being refiled is the one
99 ;; being captured. In particular, empty lines after the entry may
100 ;; be removed, and we don't want to shift onto the next heading.
104 (org-test-with-temp-text-in-file "* A\n* B\n"
105 (let* ((file (buffer-file-name))
106 (org-capture-templates
107 `(("t" "Todo" entry
(file+headline
,file
"A") "** H1 %?"))))
108 (org-capture nil
"t")
110 (cl-letf (((symbol-function 'org-refile
)
114 (buffer-substring-no-properties
115 (line-beginning-position)
116 (line-end-position))))))
117 (catch :return
(org-capture-refile))))))))
120 (provide 'test-org-capture
)
121 ;;; test-org-capture.el ends here