22import logging
33import os
44import pathlib
5- import shutil
65import typing as t
76
87import pytest
98
10- from _pytest .doctest import DoctestItem
11- from _pytest .fixtures import SubRequest
12- from _pytest .monkeypatch import MonkeyPatch
13-
149from libtmux import exc
1510from libtmux .server import Server
1611from libtmux .test import TEST_SESSION_PREFIX , get_test_session_name , namer
2217USING_ZSH = "zsh" in os .getenv ("SHELL" , "" )
2318
2419
25- @pytest .fixture (autouse = True , scope = "session" )
20+ @pytest .fixture (scope = "session" )
2621def home_path (tmp_path_factory : pytest .TempPathFactory ) -> pathlib .Path :
22+ """Temporary `/home/` path."""
2723 return tmp_path_factory .mktemp ("home" )
2824
2925
30- @pytest .fixture (autouse = True , scope = "session" )
31- def user_path (home_path : pathlib .Path ) -> pathlib .Path :
32- p = home_path / getpass .getuser ()
26+ @pytest .fixture (scope = "session" )
27+ def home_user_name () -> str :
28+ """Default username to set for :func:`user_path` fixture."""
29+ return getpass .getuser ()
30+
31+
32+ @pytest .fixture (scope = "session" )
33+ def user_path (home_path : pathlib .Path , home_user_name : str ) -> pathlib .Path :
34+ """Default temporary user directory.
35+
36+ Used by:
37+
38+ - :func:`config_file`
39+
40+ Note: You will need to set the home directory, see :ref:`set_home`.
41+ """
42+ p = home_path / home_user_name
3343 p .mkdir ()
3444 return p
3545
3646
3747@pytest .mark .skipif (USING_ZSH , reason = "Using ZSH" )
38- @pytest .fixture (autouse = USING_ZSH , scope = "session" )
48+ @pytest .fixture (scope = "session" )
3949def zshrc (user_path : pathlib .Path ) -> pathlib .Path :
4050 """This quiets ZSH default message.
4151
@@ -46,11 +56,15 @@ def zshrc(user_path: pathlib.Path) -> pathlib.Path:
4656 return p
4757
4858
49- @pytest .fixture (scope = "function " )
59+ @pytest .fixture (scope = "session " )
5060def config_file (user_path : pathlib .Path ) -> pathlib .Path :
51- """Set default tmux configuration (base indexes for windows, panes)
61+ """Default `.tmux.conf` configuration.
62+
63+ - ``base-index -g 1``
5264
53- We need this for tests to work across tmux versions in our CI matrix.
65+ These guarantee pane and windows targets can be reliably referenced and asserted.
66+
67+ Note: You will need to set the home directory, see :ref:`set_home`.
5468 """
5569 c = user_path / ".tmux.conf"
5670 c .write_text (
@@ -62,8 +76,8 @@ def config_file(user_path: pathlib.Path) -> pathlib.Path:
6276 return c
6377
6478
65- @pytest .fixture ( autouse = True )
66- def clear_env (monkeypatch : MonkeyPatch ) -> None :
79+ @pytest .fixture
80+ def clear_env (monkeypatch : pytest . MonkeyPatch ) -> None :
6781 """Clear out any unnecessary environment variables that could interrupt tests.
6882
6983 tmux show-environment tests were being interrupted due to a lot of crazy env vars.
@@ -92,9 +106,12 @@ def clear_env(monkeypatch: MonkeyPatch) -> None:
92106
93107@pytest .fixture (scope = "function" )
94108def server (
95- request : SubRequest , monkeypatch : MonkeyPatch , config_file : pathlib .Path
109+ request : pytest .FixtureRequest ,
110+ monkeypatch : pytest .MonkeyPatch ,
111+ config_file : pathlib .Path ,
96112) -> Server :
97- t = Server (config_file = str (config_file .absolute ()))
113+ """Returns a new, temporary :class:`libtmux.Server`"""
114+ t = Server ()
98115 t .socket_name = "libtmux_test%s" % next (namer )
99116
100117 def fin () -> None :
@@ -106,7 +123,8 @@ def fin() -> None:
106123
107124
108125@pytest .fixture (scope = "function" )
109- def session (request : SubRequest , server : Server ) -> "Session" :
126+ def session (request : pytest .FixtureRequest , server : Server ) -> "Session" :
127+ """Returns a new, temporary :class:`libtmux.Session`"""
110128 session_name = "tmuxp"
111129
112130 if not server .has_session (session_name ):
@@ -146,16 +164,3 @@ def session(request: SubRequest, server: Server) -> "Session":
146164 assert TEST_SESSION_NAME != "tmuxp"
147165
148166 return session
149-
150-
151- @pytest .fixture (autouse = True )
152- def add_doctest_fixtures (
153- request : SubRequest ,
154- doctest_namespace : t .Dict [str , t .Any ],
155- ) -> None :
156- if isinstance (request ._pyfuncitem , DoctestItem ) and shutil .which ("tmux" ):
157- doctest_namespace ["server" ] = request .getfixturevalue ("server" )
158- session : "Session" = request .getfixturevalue ("session" )
159- doctest_namespace ["session" ] = session
160- doctest_namespace ["window" ] = session .attached_window
161- doctest_namespace ["pane" ] = session .attached_pane
0 commit comments