aboutsummaryrefslogtreecommitdiff
path: root/tests/test-reconcile--git-directory.el
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test-reconcile--git-directory.el')
-rw-r--r--tests/test-reconcile--git-directory.el94
1 files changed, 94 insertions, 0 deletions
diff --git a/tests/test-reconcile--git-directory.el b/tests/test-reconcile--git-directory.el
new file mode 100644
index 00000000..ab4a6323
--- /dev/null
+++ b/tests/test-reconcile--git-directory.el
@@ -0,0 +1,94 @@
+;;; test-reconcile--git-directory.el --- Tests for cj/reconcile-git-directory -*- lexical-binding: t; -*-
+
+;;; Commentary:
+;; Tests for the top-level reconcile function that dispatches to skip/clean/dirty.
+
+;;; Code:
+
+(require 'ert)
+(require 'testutil-reconcile-open-repos)
+(require 'reconcile-open-repos)
+
+;;; Normal Cases
+
+(ert-deftest test-reconcile-git-directory-normal-clean-repo-pulls ()
+ "Clean SSH repo calls pull-clean, not pull-dirty."
+ (reconcile-test-with-temp-dirs
+ ("repo/.git/")
+ (let ((dir (expand-file-name "repo" test-root))
+ (clean-called nil)
+ (dirty-called nil))
+ (reconcile-test-with-shell-mocks
+ (lambda (_cmd) 0)
+ (lambda (cmd)
+ (cond ((string-match-p "remote.origin.url" cmd) "git@host:repo.git")
+ ((string-match-p "status --porcelain" cmd) "")
+ (t "")))
+ (cl-letf (((symbol-function 'cj/reconcile--pull-clean)
+ (lambda (_dir) (setq clean-called t)))
+ ((symbol-function 'cj/reconcile--pull-dirty)
+ (lambda (_dir) (setq dirty-called t)))
+ ((symbol-function 'message) (lambda (_fmt &rest _args))))
+ (cj/reconcile-git-directory dir)))
+ (should clean-called)
+ (should-not dirty-called))))
+
+(ert-deftest test-reconcile-git-directory-normal-dirty-repo-stashes ()
+ "Dirty SSH repo calls pull-dirty, not pull-clean."
+ (reconcile-test-with-temp-dirs
+ ("repo/.git/")
+ (let ((dir (expand-file-name "repo" test-root))
+ (clean-called nil)
+ (dirty-called nil))
+ (reconcile-test-with-shell-mocks
+ (lambda (_cmd) 0)
+ (lambda (cmd)
+ (cond ((string-match-p "remote.origin.url" cmd) "git@host:repo.git")
+ ((string-match-p "status --porcelain" cmd) " M file.el\n")
+ (t "")))
+ (cl-letf (((symbol-function 'cj/reconcile--pull-clean)
+ (lambda (_dir) (setq clean-called t)))
+ ((symbol-function 'cj/reconcile--pull-dirty)
+ (lambda (_dir) (setq dirty-called t)))
+ ((symbol-function 'message) (lambda (_fmt &rest _args))))
+ (cj/reconcile-git-directory dir)))
+ (should-not clean-called)
+ (should dirty-called))))
+
+(ert-deftest test-reconcile-git-directory-normal-skipped-repo-no-calls ()
+ "HTTP repo is skipped entirely — neither pull-clean nor pull-dirty called."
+ (reconcile-test-with-temp-dirs
+ ("repo/.git/")
+ (let ((dir (expand-file-name "repo" test-root))
+ (clean-called nil)
+ (dirty-called nil))
+ (reconcile-test-with-shell-mocks
+ (lambda (_cmd) 0)
+ (lambda (cmd)
+ (if (string-match-p "remote.origin.url" cmd)
+ "https://github.com/user/repo.git"
+ ""))
+ (cl-letf (((symbol-function 'cj/reconcile--pull-clean)
+ (lambda (_dir) (setq clean-called t)))
+ ((symbol-function 'cj/reconcile--pull-dirty)
+ (lambda (_dir) (setq dirty-called t)))
+ ((symbol-function 'message) (lambda (_fmt &rest _args))))
+ (cj/reconcile-git-directory dir)))
+ (should-not clean-called)
+ (should-not dirty-called))))
+
+;;; Boundary Cases
+
+(ert-deftest test-reconcile-git-directory-boundary-emits-checking-message ()
+ "Always emits 'checking: <dir>' message, even for skipped repos."
+ (reconcile-test-with-temp-dirs
+ ("repo/readme.txt")
+ (let ((dir (expand-file-name "repo" test-root))
+ (messages nil))
+ (cl-letf (((symbol-function 'message)
+ (lambda (fmt &rest args) (push (apply #'format fmt args) messages))))
+ (cj/reconcile-git-directory dir))
+ (should (cl-some (lambda (m) (string-match-p "checking:" m)) messages)))))
+
+(provide 'test-reconcile--git-directory)
+;;; test-reconcile--git-directory.el ends here