diff options
| author | Craig Jennings <c@cjennings.net> | 2026-05-22 16:09:49 -0500 |
|---|---|---|
| committer | Craig Jennings <c@cjennings.net> | 2026-05-22 16:09:49 -0500 |
| commit | 4fbe435f515a26ea11732c982900a1f011dff589 (patch) | |
| tree | 9e75be07cbc64220d15df48a8b4f4fe2d40753cb /Makefile | |
| parent | 98477bda43a9f0549f7b1998d9bff5bb87af9387 (diff) | |
| download | dotemacs-4fbe435f515a26ea11732c982900a1f011dff589.tar.gz dotemacs-4fbe435f515a26ea11732c982900a1f011dff589.zip | |
fix(test): make test-name resilient to load-time cwd changes
make test-name loads every test file into one Emacs, then selects by name. test-system-defaults-functions.el requires system-defaults at load, which runs (setq default-directory user-home-dir), an intentional config choice. That leaked the cwd into the shared session, so every relative -l tests/X.el load after it resolved against the wrong directory and aborted the whole run with Error 255.
I made two changes. test-name now passes absolute paths to -l so loads survive any cwd change, and the test contains the leak by let-binding default-directory around the require. The production setq stays as is.
Diffstat (limited to 'Makefile')
| -rw-r--r-- | Makefile | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -204,7 +204,7 @@ endif @echo "Running tests matching pattern: $(TEST)..." @$(EMACS_TEST) \ -l ert \ - $(foreach test,$(ALL_TESTS),-l $(test)) \ + $(foreach test,$(ALL_TESTS),-l $(abspath $(test))) \ --eval '(ert-run-tests-batch-and-exit "$(TEST)")' @echo "✓ Tests matching '$(TEST)' complete" |
