aboutsummaryrefslogtreecommitdiff
path: root/tests/test-org-drill-resume-nil-session.el
diff options
context:
space:
mode:
authorCraig Jennings <c@cjennings.net>2026-05-05 14:35:45 -0500
committerCraig Jennings <c@cjennings.net>2026-05-05 14:35:45 -0500
commitdf4caddc17091b67b5afa7864b53ccffc00ce076 (patch)
tree8243b853af8a4a1d3c2664a988ed0617090a8b68 /tests/test-org-drill-resume-nil-session.el
parent46bcf53e970e05f6c58b08040a72cc61cc476fb4 (diff)
downloadorg-drill-df4caddc17091b67b5afa7864b53ccffc00ce076.tar.gz
org-drill-df4caddc17091b67b5afa7864b53ccffc00ce076.zip
test: cover --pick-next-marker and resume happy-paths
I extended `tests/test-org-drill-route-rating-result.el' with four `org-drill--pick-next-marker' cases (no resume → pop, resume with live drill marker → keep current-item and clear resume-p, resume with nil or non-drill current-item → fall through to fresh pop). I also extended the resume regression file with the three happy-path branches of `org-drill-resume': pending entries → resume, finished with pending count → y-or-n-p offers a new session, finished with nothing → print 'finished'. Coverage moved from 91.7% to 92.1%.
Diffstat (limited to 'tests/test-org-drill-resume-nil-session.el')
-rw-r--r--tests/test-org-drill-resume-nil-session.el46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/test-org-drill-resume-nil-session.el b/tests/test-org-drill-resume-nil-session.el
index fd64faf..a2b2e7c 100644
--- a/tests/test-org-drill-resume-nil-session.el
+++ b/tests/test-org-drill-resume-nil-session.el
@@ -34,6 +34,52 @@ not an obscure eieio type error."
(let ((org-drill-last-session nil))
(should-error (org-drill-resume) :type 'user-error)))
+;;;; org-drill-resume — happy paths
+
+(ert-deftest test-org-drill-resume-with-pending-entries-resumes ()
+ "When the prior session has pending entries, resume calls org-drill with resume-p=t."
+ (let* ((session (org-drill-session))
+ (org-drill-last-session session)
+ (resume-args nil))
+ (cl-letf (((symbol-function 'org-drill-entries-pending-p) (lambda (_) t))
+ ((symbol-function 'org-drill)
+ (lambda (&rest args) (setq resume-args args))))
+ (org-drill-resume))
+ (should resume-args)
+ (should (nth 2 resume-args))))
+
+(ert-deftest test-org-drill-resume-finished-with-no-pending-says-finished ()
+ "When the session is done with no remaining pending count, prints the
+'finished' message."
+ (let* ((session (org-drill-session))
+ (org-drill-last-session session)
+ (messages nil))
+ (cl-letf (((symbol-function 'message)
+ (lambda (fmt &rest args)
+ (when fmt (push (apply #'format fmt args) messages)))))
+ (org-drill-resume))
+ (should (cl-some (lambda (m) (string-match-p "finished" m)) messages))))
+
+(ert-deftest test-org-drill-resume-finished-with-y-starts-new ()
+ "When session is done but pending count is positive and user answers y,
+org-drill-again runs."
+ (let* ((session (org-drill-session))
+ (org-drill-last-session session)
+ (m (let ((mk (make-marker))) (set-marker mk 1) mk))
+ (again-called nil))
+ ;; Done-entries non-empty + new-entries non-empty + done-entries reaches limit
+ ;; tricky to set up cleanly. Easier: stub the predicates.
+ (cl-letf (((symbol-function 'org-drill-entries-pending-p)
+ (lambda (_) nil))
+ ((symbol-function 'org-drill-pending-entry-count)
+ (lambda (_) 5))
+ ((symbol-function 'y-or-n-p) (lambda (&rest _) t))
+ ((symbol-function 'org-drill-again)
+ (lambda (&rest _) (setq again-called t)))
+ ((symbol-function 'message) #'ignore))
+ (org-drill-resume))
+ (should again-called)))
+
(provide 'test-org-drill-resume-nil-session)
;;; test-org-drill-resume-nil-session.el ends here