| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 | ;;; test-org-protocol.el --- tests for org-protocol.el                  -*- lexical-binding: t; -*-;; Copyright (c)  Sacha Chua;; Authors: Sacha Chua;; This file is not part of GNU Emacs.;; This program 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 program 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 program.  If not, see <https://www.gnu.org/licenses/>.;;; Code:(require 'cl-lib)(unless (featurep 'org-protocol)  (signal 'missing-test-dependency "Support for org-protocol"))(ert-deftest test-org-protocol/org-protocol-parse-parameters ()  "Test `org-protocol-parse-parameters' specifications."  ;; Ignore lists  (let ((data (org-protocol-parse-parameters '(:url "abc" :title "def") nil)))    (should (string= (plist-get data :url) "abc"))    (should (string= (plist-get data :title) "def")))  ;; Parse new-style links  (let ((data (org-protocol-parse-parameters "url=abc&title=def" t)))    (should (string= (plist-get data :url) "abc"))    (should (string= (plist-get data :title) "def")))  ;; Parse new-style complex links  (let* ((url (concat "template=p&"		      "url=https%3A%2F%2Forgmode.org%2Forg.html%23capture-protocol&"		      "title=The%20Org%20Manual&"		      "body=9.4.2%20capture%20protocol"))	 (data (org-protocol-parse-parameters url t)))    (should (string= (plist-get data :template) "p"))    (should (string= (plist-get data :url) "https://orgmode.org/org.html#capture-protocol"))    (should (string= (plist-get data :title) "The Org Manual"))    (should (string= (plist-get data :body) "9.4.2 capture protocol")))  ;; Parse old-style links  (let ((data (org-protocol-parse-parameters "abc/def" nil '(:url :title))))    (should (string= (plist-get data :url) "abc"))    (should (string= (plist-get data :title) "def")))  ;; Parse old-style links even without keys  (let ((data (org-protocol-parse-parameters "b/abc/def" nil)))    (should (equal data '("b" "abc" "def"))))  ;; Parse old-style links with key/val pairs  (let ((data (org-protocol-parse-parameters "b/abc/extrakey/extraval" nil '(:param1 :param2))))    (should (string= (plist-get data :param1) "b"))    (should (string= (plist-get data :param2) "abc"))    (should (string= (plist-get data :extrakey) "extraval"))))(ert-deftest test-org-protocol/org-protocol-store-link ()  "Test `org-protocol-store-link' specifications."  ;; Old link style  (let ((uri "/some/directory/org-protocol:/store-link:/URL/TITLE"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("URL" "TITLE"))))  ;; URL encoded  (let ((uri (format "/some/directory/org-protocol:/store-link:/%s/TITLE"		     (url-hexify-string "http://example.com"))))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("http://example.com" "TITLE"))))  ;; Handle multiple slashes, old link style  (let ((uri "/some/directory/org-protocol://store-link://URL2//TITLE2"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("URL2" "TITLE2"))))  ;; New link style  (let ((uri "/some/directory/org-protocol://store-link?url=URL3&title=TITLE3"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("URL3" "TITLE3"))))  ;; Do not decode "+" in old-style link  (let ((uri "/org-protocol:/store-link:/one+one/plus+preserved"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("one+one" "plus+preserved"))))  ;; Decode "+" to space in new-style link  (let ((uri "/org-protocol:/store-link/?url=one+two&title=plus+is+space"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("one two" "plus is space")))))(ert-deftest test-org-protocol/org-protocol-store-link-file ()  "store-link: `org-protocol-sanitize-uri' could distort URL."  :expected-result :failed  (let ((uri "/org-protocol:/store-link:/file%3A%2F%2F%2Fetc%2Fmailcap/Triple%20Slash"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("file:///etc/mailcap" "Triple Slash"))))  (let ((uri "/org-protocol:/store-link?url=file%3A%2F%2F%2Fetc%2Fmailcap&title=Triple%20Slash"))    (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))    (should (equal (car org-stored-links) '("file:///etc/mailcap" "Triple Slash")))))(ert-deftest test-org-protocol/org-protocol-capture ()  "Test `org-protocol-capture' specifications."  (let* ((org-protocol-default-template-key "t")	 (temp-file-name (make-temp-file "org-protocol-test"))	 (org-capture-templates	  `(("t" "Test" entry (file ,temp-file-name) "** TODO\n\n%i\n\n%a\n" :kill-buffer t)	    ("x" "With params" entry (file ,temp-file-name) "** SOMEDAY\n\n%i\n\n%a\n" :kill-buffer t)	    ("X" "Just the template" entry (file ,temp-file-name) "** Hello World\n\n%i\n\nGoodbye World\n" :kill-buffer t)))	 (test-urls	  '(	    ;; Old style:	    ;; - multiple slashes	    ("/some/directory/org-protocol:/capture:/URL/TITLE"	     . "** TODO\n\n\n\n[[URL][TITLE]]\n")	    ;; - body specification	    ("/some/directory/org-protocol:/capture:/URL/TITLE/BODY"	     . "** TODO\n\nBODY\n\n[[URL][TITLE]]\n")	    ;; - template	    ("/some/directory/org-protocol:/capture:/x/URL/TITLE/BODY"	     . "** SOMEDAY\n\nBODY\n\n[[URL][TITLE]]\n")	    ;; - query parameters, not sure how to include them in template	    ("/some/directory/org-protocol:/capture:/x/URL/TITLE/BODY/from/example"	     . "** SOMEDAY\n\nBODY\n\n[[URL][TITLE]]\n")	    ;; New style:	    ;; - multiple slashes	    ("/some/directory/org-protocol:/capture?url=NEWURL&title=TITLE"	     . "** TODO\n\n\n\n[[NEWURL][TITLE]]\n")	    ;; - body specification	    ("/some/directory/org-protocol:/capture?url=NEWURL&title=TITLE&body=BODY"	     . "** TODO\n\nBODY\n\n[[NEWURL][TITLE]]\n")	    ;; - template	    ("/some/directory/org-protocol:/capture?template=x&url=NEWURL&title=TITLE&body=BODY"	     . "** SOMEDAY\n\nBODY\n\n[[NEWURL][TITLE]]\n")	    ;; - no url specified	    ("/some/directory/org-protocol:/capture?template=x&title=TITLE&body=BODY"	    . "** SOMEDAY\n\nBODY\n\nTITLE\n")	    ;; - no title specified	    ("/some/directory/org-protocol:/capture?template=x&url=NEWURL&body=BODY"	     . "** SOMEDAY\n\nBODY\n\n[[NEWURL][NEWURL]]\n")	    ;; - just the template	    ("/some/directory/org-protocol:/capture?template=X"	     . "** Hello World\n\n\n\nGoodbye World\n")	    ;; - query parameters, not sure how to include them in template	    ("/some/directory/org-protocol:/capture?template=x&url=URL&title=TITLE&body=BODY&from=example"	     . "** SOMEDAY\n\nBODY\n\n[[URL][TITLE]]\n")            ;; - "+" is not decoded to space in old-style URIs            ("/org-protocol:/capture:/t/https%3A%2F%2Forgmode.org%2Fsome+thing/org+mode/Body+plus"             . "** TODO\n\nBody+plus\n\n[[https://orgmode.org/some+thing][org+mode]]\n")            ;; - decode "+" to space            ("/org-protocol:/capture?template=t&url=URL&title=Mailing+list&body=Body+no+plus"             . "** TODO\n\nBody no plus\n\n[[URL][Mailing list]]\n")	    )))    ;; Old link style    (mapc     (lambda (test-case)       (let ((uri (car test-case)))	 (org-protocol-check-filename-for-protocol uri (list uri) nil)	 (should (string= (buffer-string) (cdr test-case)))	 (org-capture-kill)))     test-urls)    (delete-file temp-file-name)))(ert-deftest test-org-protocol/org-protocol-capture-file ()  "capture: `org-protocol-sanitize-uri' could distort URL."  :expected-result :failed  (let* ((org-protocol-default-template-key "t")	 (temp-file-name (make-temp-file "org-protocol-test"))	 (org-capture-templates	  `(("t" "Test" plain (file ,temp-file-name) "%a\n%i\n" :kill-buffer t))))    (let ((uri "/org-protocol:/capture:/t/file%3A%2F%2F%2Fetc%2Fmailcap/Triple%20Slash/Body"))      (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))      (should (string= (buffer-string) "[[file:///etc/mailcap][Triple Slash]]\nBody")))    (let ((uri "/org-protocol:/capture?template=t&url=file%3A%2F%2F%2Fetc%2Fmailcap&title=Triple%20Slash&body=Body"))      (should (null (org-protocol-check-filename-for-protocol uri (list uri) nil)))      (should (string= (buffer-string) "[[file:///etc/mailcap][Triple Slash]]\nBody")))))(ert-deftest test-org-protocol/org-protocol-open-source ()  "Test org-protocol://open-source links."  (let* ((temp-file-name1 (make-temp-file "org-protocol-test1"))	 (temp-file-name2 (make-temp-file "org-protocol-test2"))	 (org-protocol-project-alist	  `((test1	     :base-url "http://example.com/"	     :online-suffix ".html"	     :working-directory ,(file-name-directory temp-file-name1))	    (test2	     :base-url "http://another.example.com/"	     :online-suffix ".js"	     :working-directory ,(file-name-directory temp-file-name2))	    (test3	     :base-url "https://blog-example.com/"	     :working-directory ,(file-name-directory temp-file-name2)	     :online-suffix ".html"	     :working-suffix ".md"	     :rewrites (("\\(https://blog-example.com/[0-9]+/[0-9]+/[0-9]+/\\)" . ".md")))))	 (test-cases	  (list	   ;; Old-style URLs	   (cons	    (concat "/some/directory/org-protocol:/open-source:/"		    (url-hexify-string		     (concat "http://example.com/" (file-name-nondirectory temp-file-name1) ".html")))	    temp-file-name1)	   (cons	    (concat "/some/directory/org-protocol:/open-source:/"		    (url-hexify-string		     (concat "http://another.example.com/" (file-name-nondirectory temp-file-name2) ".js")))	    temp-file-name2)	   ;; New-style URLs	   (cons	    (concat "/some/directory/org-protocol:/open-source?url="		    (url-hexify-string		     (concat "http://example.com/" (file-name-nondirectory temp-file-name1) ".html")))	    temp-file-name1)	   (cons	    (concat "/some/directory/org-protocol:/open-source?url="		    (url-hexify-string		     (concat "http://another.example.com/" (file-name-nondirectory temp-file-name2) ".js")))	    temp-file-name2))))    (mapc (lambda (test-case)	    (should (string=		     (org-protocol-check-filename-for-protocol		      (car test-case)		      (list (car test-case)) nil)		     (cdr test-case))))	  test-cases)    (delete-file temp-file-name1)    (delete-file temp-file-name2)))(defun test-org-protocol/org-protocol-greedy-handler (fname)  ;; fname should be a list of parsed items  (should (listp fname))  nil)(ert-deftest test-org-protocol/org-protocol-with-greedy-handler ()  "Check that greedy handlers are called with all the filenames."  (let ((org-protocol-protocol-alist	 '(("protocol-a" :protocol "greedy" :function test-org-protocol/org-protocol-greedy-handler :kill-client t :greedy t))))    ;; Neither of these should signal errors    (let ((uri "/some/dir/org-protocol://greedy?a=b&c=d")	  (uri2 "/some/dir/org-protocol://greedy?e=f&g=h"))      (org-protocol-check-filename-for-protocol uri (list uri uri2) nil))));; TODO: Verify greedy protocol handling;;; test-org-protocol.el ends here
 |