|
1 | 1 | import sys |
| 2 | +import os |
2 | 3 | from unittest.mock import AsyncMock, MagicMock, PropertyMock, patch |
3 | 4 |
|
4 | 5 | import pytest |
@@ -53,21 +54,35 @@ def badfish_call( |
53 | 54 | mock_host=config.MOCK_HOST, |
54 | 55 | mock_user=config.MOCK_USER, |
55 | 56 | mock_pass=config.MOCK_PASS, |
| 57 | + use_cli_secrets=False |
56 | 58 | ): |
57 | 59 | argv = [] |
| 60 | + env_vars = os.environ.copy() |
58 | 61 |
|
59 | 62 | if mock_host is not None: |
60 | 63 | argv.extend(("-H", mock_host)) |
61 | | - if mock_user is not None: |
62 | | - argv.extend(("-u", mock_user)) |
63 | | - if mock_pass is not None: |
64 | | - argv.extend(("-p", mock_pass)) |
65 | | - |
66 | | - argv.extend(self.args) |
67 | | - try: |
68 | | - main(argv) |
69 | | - except BadfishException: |
70 | | - pass |
| 64 | + |
| 65 | + if use_cli_secrets: |
| 66 | + # Legacy behavior: Pass secrets via CLI args to test warning logic |
| 67 | + if mock_user is not None: |
| 68 | + argv.extend(("-u", mock_user)) |
| 69 | + if mock_pass is not None: |
| 70 | + argv.extend(("-p", mock_pass)) |
| 71 | + argv.extend(self.args) |
| 72 | + else: |
| 73 | + # Default behavior for tests: Use Env Vars to suppress warnings |
| 74 | + if mock_user is not None: |
| 75 | + env_vars["BADFISH_USERNAME"] = mock_user |
| 76 | + if mock_pass is not None: |
| 77 | + env_vars["BADFISH_PASSWORD"] = mock_pass |
| 78 | + argv.extend(self.args) |
| 79 | + |
| 80 | + with patch.dict(os.environ, env_vars): |
| 81 | + try: |
| 82 | + main(argv) |
| 83 | + except BadfishException: |
| 84 | + pass |
| 85 | + |
71 | 86 | out, err = self._capsys.readouterr() |
72 | 87 | return out, err |
73 | 88 |
|
|
0 commit comments