842802b873
PR #1365 (cherry-picked into v0.8.28) introduced `term_program_test_guard` as a fresh module-local `static Mutex<()>`, mirroring the existing `no_animations_test_guard`. Both serialize their own family of tests but not with each other — so under cargo's parallel runner, a `NO_ANIMATIONS=1` leak from one family lands in the env at the exact moment a `TERM_PROGRAM=iTerm.app` test calls the shared `apply_env_overrides`, flipping `low_motion` to true and failing `non_vscode_term_program_does_not_force_low_motion`. Both guards now return `crate::test_support::lock_test_env()` (the same fold the v0.8.28 test-stabilization commit applied to the EnvGuard family in `commands/config.rs`, `commands/network.rs`, and `tools/recall_archive.rs`). This serializes the two test groups with each other and with every other env-mutating test in the suite, eliminating the cross-test env-var race. `save_api_key_for_openrouter_writes_provider_table` was failing intermittently for the same reason — a concurrent env mutation in an unrelated test was clobbering HOME / DEEPSEEK_CONFIG_PATH in the window between our `EnvGuard::new` and `save_api_key_for`'s `default_config_path()` read. With the broader serialization in place, the race window closes. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>