summaryrefslogtreecommitdiffstats
path: root/test/t/test_python.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:03:18 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:03:18 +0000
commitf2621414ee5f2f601424c22f00e207903e3b6104 (patch)
tree56a856dafd1ca684bb23263cacaa723ee4f404fc /test/t/test_python.py
parentAdding debian version 1:2.11-8. (diff)
downloadbash-completion-f2621414ee5f2f601424c22f00e207903e3b6104.tar.xz
bash-completion-f2621414ee5f2f601424c22f00e207903e3b6104.zip
Merging upstream version 1:2.12.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'test/t/test_python.py')
-rw-r--r--test/t/test_python.py47
1 files changed, 47 insertions, 0 deletions
diff --git a/test/t/test_python.py b/test/t/test_python.py
index 5308dcb..bcc566b 100644
--- a/test/t/test_python.py
+++ b/test/t/test_python.py
@@ -37,3 +37,50 @@ class TestPython:
@pytest.mark.complete("python -m json.", require_cmd=True)
def test_9(self, completion):
assert "json.tool" in completion
+
+ @pytest.mark.complete(
+ "python -b",
+ require_cmd=True,
+ skipif="! python -h | command grep -qwF -- -bb",
+ )
+ def test_bb(self, completion):
+ assert "-bb" in completion
+
+ @pytest.mark.complete("python foo ", cwd="python")
+ def test_script_arg(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -- foo ", cwd="python")
+ def test_script_arg_with_double_hyphen(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -m foo bar -p ", cwd="python")
+ def test_module_arg(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python foo bar -p ", cwd="python")
+ def test_script_arg_after_option(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -- foo bar -p ", cwd="python")
+ def test_script_arg_after_option_with_double_hyphen(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -m foo bar -p ", cwd="python")
+ def test_module_arg_after_option(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -mfoo bar -p ", cwd="python")
+ def test_module_arg_after_option_with_connected_m_arg(self, completion):
+ assert "bar.txt" in completion
+
+ @pytest.mark.complete("python -- ", cwd="python")
+ def test_script_name(self, completion):
+ assert "bar.txt" not in completion
+
+ @pytest.mark.complete("python -W -mfoo ", cwd="python")
+ def test_script_name_with_fake_m_arg(self, completion):
+ """In this case, -mfoo looks like an option to specify the module, but
+ it should not be treated as the module name because it is an option
+ argument to -W."""
+ assert "bar.txt" not in completion