aboutsummaryrefslogtreecommitdiff
path: root/tests/tmux-util/test_tmux_util.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/tmux-util/test_tmux_util.py')
-rw-r--r--tests/tmux-util/test_tmux_util.py105
1 files changed, 98 insertions, 7 deletions
diff --git a/tests/tmux-util/test_tmux_util.py b/tests/tmux-util/test_tmux_util.py
index afc1ebc..b3eab8d 100644
--- a/tests/tmux-util/test_tmux_util.py
+++ b/tests/tmux-util/test_tmux_util.py
@@ -66,7 +66,7 @@ class TmuxUtilHarness(unittest.TestCase):
pids_csv = ",".join(str(p) for p in pids) if pids else "-"
f.write(f"{name} {attached} {pids_csv} {activity} {windows} {cwd}\n")
- def run_script(self, *args, env_extra=None):
+ def run_script(self, *args, env_extra=None, stdin=None):
env = os.environ.copy()
# Prepend the bin dir so the fakes win
env["PATH"] = self.bin_dir + os.pathsep + env.get("PATH", "")
@@ -76,6 +76,7 @@ class TmuxUtilHarness(unittest.TestCase):
return subprocess.run(
[SCRIPT] + list(args),
env=env,
+ input=stdin,
capture_output=True,
text=True,
timeout=10,
@@ -127,12 +128,6 @@ class TestDispatch(TmuxUtilHarness):
self.assertIn("unknown subcommand", result.stderr)
self.assertIn("Usage: tmux-util", result.stderr)
- def test_unimplemented_subcommand_exits_nonzero(self):
- # rename stubs out for now; pick one to confirm the stub path.
- result = self.run_script("rename")
- self.assertNotEqual(result.returncode, 0)
- self.assertIn("not implemented yet", result.stderr)
-
# -----------------------------------------------------------------------------
# Reap — Normal cases
@@ -617,5 +612,101 @@ class TestPickBoundary(TmuxUtilHarness):
f"unexpected attach/switch in {calls!r}")
+# -----------------------------------------------------------------------------
+# rename — Normal cases
+# -----------------------------------------------------------------------------
+
+class TestRenameNormal(TmuxUtilHarness):
+
+ def test_rename_picks_session_and_renames_it(self):
+ self.set_sessions([
+ ("old", 0, ["101:zsh"], 950, 1, "/tmp/old"),
+ ("other", 0, ["201:zsh"], 900, 1, "/tmp/other"),
+ ])
+ result = self.run_script(
+ "rename",
+ env_extra={"FAKE_FZF_CHOICE_LINE": "1"}, # picks "old"
+ stdin="new\n",
+ )
+ self.assertEqual(result.returncode, 0, msg=result.stderr)
+ calls = self.tmux_calls()
+ self.assertTrue(
+ any("rename-session -t old new" in c for c in calls),
+ f"expected rename-session -t old new in {calls!r}",
+ )
+ # State should reflect the rename
+ names = self.remaining_sessions()
+ self.assertIn("new", names)
+ self.assertIn("other", names)
+ self.assertNotIn("old", names)
+ self.assertIn("Renamed: old", result.stdout)
+
+
+# -----------------------------------------------------------------------------
+# rename — Boundary / Error cases
+# -----------------------------------------------------------------------------
+
+class TestRenameBoundary(TmuxUtilHarness):
+
+ def test_rename_no_sessions_prints_message(self):
+ self.set_sessions([])
+ result = self.run_script("rename")
+ self.assertEqual(result.returncode, 0)
+ self.assertIn("No tmux sessions", result.stdout)
+ # fzf should never have been invoked
+ self.assertFalse(any(c.startswith("fzf ") for c in self.tmux_calls()))
+
+ def test_rename_user_cancels_fzf_no_action(self):
+ self.set_sessions([
+ ("old", 0, ["101:zsh"], 950, 1, "/tmp/old"),
+ ])
+ # No FAKE_FZF_CHOICE → fzf exits 130
+ result = self.run_script("rename")
+ self.assertEqual(result.returncode, 0, msg=result.stderr)
+ self.assertFalse(any("rename-session" in c for c in self.tmux_calls()))
+ # State unchanged
+ self.assertEqual(self.remaining_sessions(), ["old"])
+
+ def test_rename_empty_new_name_exits_nonzero(self):
+ self.set_sessions([
+ ("old", 0, ["101:zsh"], 950, 1, "/tmp/old"),
+ ])
+ result = self.run_script(
+ "rename",
+ env_extra={"FAKE_FZF_CHOICE_LINE": "1"},
+ stdin="\n", # empty new name
+ )
+ self.assertNotEqual(result.returncode, 0)
+ self.assertIn("empty new name", result.stderr)
+ self.assertFalse(any("rename-session" in c for c in self.tmux_calls()))
+
+ def test_rename_same_name_is_noop(self):
+ self.set_sessions([
+ ("old", 0, ["101:zsh"], 950, 1, "/tmp/old"),
+ ])
+ result = self.run_script(
+ "rename",
+ env_extra={"FAKE_FZF_CHOICE_LINE": "1"},
+ stdin="old\n", # same as current name
+ )
+ self.assertEqual(result.returncode, 0, msg=result.stderr)
+ self.assertIn("same as old", result.stdout)
+ self.assertFalse(any("rename-session" in c for c in self.tmux_calls()))
+
+ def test_rename_conflict_with_existing_exits_nonzero(self):
+ self.set_sessions([
+ ("old", 0, ["101:zsh"], 950, 1, "/tmp/old"),
+ ("taken", 0, ["201:zsh"], 900, 1, "/tmp/taken"),
+ ])
+ result = self.run_script(
+ "rename",
+ env_extra={"FAKE_FZF_CHOICE_LINE": "1"}, # picks "old"
+ stdin="taken\n", # collides with existing
+ )
+ self.assertNotEqual(result.returncode, 0)
+ self.assertIn("already exists", result.stderr)
+ self.assertFalse(any("rename-session" in c for c in self.tmux_calls()))
+
+
if __name__ == "__main__":
unittest.main()