|
6 | 6 | import random |
7 | 7 | import typing as t |
8 | 8 |
|
| 9 | +from libtmux.test.constants import ( |
| 10 | + TEST_SESSION_PREFIX, |
| 11 | +) |
| 12 | + |
| 13 | +logger = logging.getLogger(__name__) |
| 14 | + |
| 15 | +if t.TYPE_CHECKING: |
| 16 | + import sys |
| 17 | + |
| 18 | + from libtmux.server import Server |
| 19 | + from libtmux.session import Session |
| 20 | + |
| 21 | + if sys.version_info >= (3, 11): |
| 22 | + pass |
| 23 | + else: |
| 24 | + pass |
| 25 | + |
| 26 | + |
9 | 27 | logger = logging.getLogger(__name__) |
10 | 28 |
|
11 | 29 | if t.TYPE_CHECKING: |
@@ -46,3 +64,75 @@ def __next__(self) -> str: |
46 | 64 |
|
47 | 65 |
|
48 | 66 | namer = RandomStrSequence() |
| 67 | + |
| 68 | + |
| 69 | +def get_test_session_name(server: Server, prefix: str = TEST_SESSION_PREFIX) -> str: |
| 70 | + """ |
| 71 | + Faker to create a session name that doesn't exist. |
| 72 | +
|
| 73 | + Parameters |
| 74 | + ---------- |
| 75 | + server : :class:`libtmux.Server` |
| 76 | + libtmux server |
| 77 | + prefix : str |
| 78 | + prefix for sessions (e.g. ``libtmux_``). Defaults to |
| 79 | + ``TEST_SESSION_PREFIX``. |
| 80 | +
|
| 81 | + Returns |
| 82 | + ------- |
| 83 | + str |
| 84 | + Random session name guaranteed to not collide with current ones. |
| 85 | +
|
| 86 | + Examples |
| 87 | + -------- |
| 88 | + >>> get_test_session_name(server=server) |
| 89 | + 'libtmux_...' |
| 90 | +
|
| 91 | + Never the same twice: |
| 92 | + >>> get_test_session_name(server=server) != get_test_session_name(server=server) |
| 93 | + True |
| 94 | + """ |
| 95 | + while True: |
| 96 | + session_name = prefix + next(namer) |
| 97 | + if not server.has_session(session_name): |
| 98 | + break |
| 99 | + return session_name |
| 100 | + |
| 101 | + |
| 102 | +def get_test_window_name( |
| 103 | + session: Session, |
| 104 | + prefix: str | None = TEST_SESSION_PREFIX, |
| 105 | +) -> str: |
| 106 | + """ |
| 107 | + Faker to create a window name that doesn't exist. |
| 108 | +
|
| 109 | + Parameters |
| 110 | + ---------- |
| 111 | + session : :class:`libtmux.Session` |
| 112 | + libtmux session |
| 113 | + prefix : str |
| 114 | + prefix for windows (e.g. ``libtmux_``). Defaults to |
| 115 | + ``TEST_SESSION_PREFIX``. |
| 116 | +
|
| 117 | + ATM we reuse the test session prefix here. |
| 118 | +
|
| 119 | + Returns |
| 120 | + ------- |
| 121 | + str |
| 122 | + Random window name guaranteed to not collide with current ones. |
| 123 | +
|
| 124 | + Examples |
| 125 | + -------- |
| 126 | + >>> get_test_window_name(session=session) |
| 127 | + 'libtmux_...' |
| 128 | +
|
| 129 | + Never the same twice: |
| 130 | + >>> get_test_window_name(session=session) != get_test_window_name(session=session) |
| 131 | + True |
| 132 | + """ |
| 133 | + assert prefix is not None |
| 134 | + while True: |
| 135 | + window_name = prefix + next(namer) |
| 136 | + if len(session.windows.filter(window_name=window_name)) == 0: |
| 137 | + break |
| 138 | + return window_name |
0 commit comments