123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- (require 'org-test)
- (require 'org-attach)
- (eval-and-compile (require 'cl-lib))
- (ert-deftest test-org-attach/dir ()
- "Test `org-attach-get' specifications."
- (let ((org-file-apps '((t . emacs))))
- (should (equal "Text in fileA\n"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 157)
- (org-open-at-point)
- (buffer-string))))
- (should-not (equal "Text in fileB\n"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 219)
- (let ((org-attach-use-inheritance nil))
- (org-open-at-point)
- (buffer-string)))))
- (should (equal "Text in fileB\n"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 219)
- (let ((org-attach-use-inheritance t))
- (org-open-at-point)
- (buffer-string)))))
- (should-not (equal "att1"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 179)
- (let ((org-attach-use-inheritance nil))
- (org-attach-dir)))))
- (should (equal "att1"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 179)
- (let ((org-attach-use-inheritance t))
- (org-attach-dir)))))
- (should (equal '("fileC" "fileD")
- (org-test-in-example-file org-test-attachments-file
- (goto-char 239)
- (org-attach-file-list (org-attach-dir)))))
- (should (equal '("fileC" "fileD")
- (org-test-in-example-file org-test-attachments-file
- (goto-char 239)
- (org-attach-file-list (org-attach-dir)))))
- (should (equal '("fileE")
- (org-test-in-example-file org-test-attachments-file
- (goto-char 289)
- (let ((org-attach-id-dir "data/"))
- (org-attach-file-list (org-attach-dir))))))
- (should (equal "peek-a-boo\n"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 289)
- (let ((org-attach-id-dir "data/"))
- (org-attach-open-in-emacs)
- (buffer-string)))))
- (should (equal '("fileA" "fileB")
- (org-test-in-example-file org-test-attachments-file
- (goto-char 336)
- (org-attach-file-list (org-attach-dir)))))
-
- (should-not (org-test-in-example-file org-test-attachments-file
- (goto-char 401)
- (let ((org-attach-use-inheritance nil)
- (org-attach-id-dir "data/"))
- (org-attach-dir))))
-
-
- (should (equal "data/ab/cd12345"
- (org-test-in-example-file org-test-attachments-file
- (goto-char 401)
- (let ((org-attach-use-inheritance nil)
- (org-attach-id-dir "data/"))
- (file-relative-name (org-attach-dir nil t))))))
- (should (equal '("fileA" "fileB")
- (org-test-in-example-file org-test-attachments-file
- (goto-char 401)
- (let ((org-attach-use-inheritance t))
-
-
-
-
-
- (org-attach-file-list (org-attach-dir))))))))
- (ert-deftest test-org-attach/dired-attach-to-next-best-subtree/1 ()
- "Attach file at point in dired to subtree."
- (should
- (let ((a-filename (make-temp-file "a"))
- (org-attach-id-dir "data/"))
- (unwind-protect
- (org-test-with-temp-text-in-file
- "* foo :foo:"
- (split-window)
- (let ((org-buffer (current-buffer))
- (dired-buffer (dired temporary-file-directory)))
- (cl-assert (eq 'dired-mode major-mode))
- (revert-buffer)
- (dired-goto-file a-filename)
-
- (call-interactively #'org-attach-dired-to-subtree)
-
- (delete-window)
- (switch-to-buffer org-buffer)
- (cl-assert (eq 'org-mode major-mode)))
- (beginning-of-buffer)
- (search-forward "* foo")
-
- (cl-reduce (lambda (x y) (or x y))
- (mapcar (lambda (x) (string-equal "ATTACH" x))
- (plist-get
- (plist-get
- (org-element-at-point) 'headline) :tags))))
- (delete-file a-filename)))))
- (ert-deftest test-org-attach/dired-attach-to-next-best-subtree/2 ()
- "Attach 2 marked files."
- (should
- (let ((a-filename (make-temp-file "a"))
- (b-filename (make-temp-file "b"))
- (org-attach-id-dir "data/"))
- (unwind-protect
- (org-test-with-temp-text-in-file
- "* foo"
- (split-window)
- (let ((org-buffer (current-buffer))
- (dired-buffer (dired temporary-file-directory)))
- (cl-assert (eq 'dired-mode major-mode))
- (revert-buffer)
- (dired-goto-file a-filename)
- (dired-mark 1)
- (dired-goto-file b-filename)
- (dired-mark 1)
-
- (call-interactively #'org-attach-dired-to-subtree)
-
- (delete-window)
- (switch-to-buffer org-buffer))
- (cl-assert (eq 'org-mode major-mode))
- (beginning-of-buffer)
- (search-forward "* foo")
- (and (file-exists-p (concat (org-attach-dir) "/"
- (file-name-nondirectory a-filename)))
- (file-exists-p (concat (org-attach-dir) "/"
- (file-name-nondirectory b-filename)))))
- (delete-file a-filename)
- (delete-file b-filename)))))
- (provide 'test-org-attach)
|