-
-
Notifications
You must be signed in to change notification settings - Fork 680
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
0.5.0: pytest is failing #413
Comments
@kloczek, I don’t want to hijack this upstream issue, but I want to make sure you know that I’ve been maintaining a python-typer package in Fedora Linux. I would be happy if that fact can help with whatever you’re trying to do. I also welcome co-maintainers. |
Feel free to add my Fedora account kloczek to list co-maintainers. |
Just tested and looks like this version is failing in yet another new unit + PYTHONPATH=/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.6.1-2.fc35.x86_64/usr/lib64/python3.8/site-packages:/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.6.1-2.fc35.x86_64/usr/lib/python3.8/site-packages
+ /usr/bin/pytest -ra --deselect tests/test_tracebacks.py::test_traceback_rich --deselect tests/test_completion/test_completion.py::test_show_completion --deselect tests/test_completion/test_completion.py::test_install_completion --deselect tests/test_completion/test_completion_install.py::test_completion_install_bash
=========================================================================== test session starts ============================================================================
platform linux -- Python 3.8.13, pytest-7.1.2, pluggy-1.0.0
rootdir: /home/tkloczko/rpmbuild/BUILD/typer-0.6.1
plugins: cov-3.0.0
collected 567 items / 3 deselected / 564 selected
docs_src/testing/app01/test_main.py . [ 0%]
docs_src/testing/app02/test_main.py . [ 0%]
docs_src/testing/app03/test_main.py . [ 0%]
tests/test_exit_errors.py ... [ 1%]
tests/test_others.py ........... [ 3%]
tests/test_prog_name.py . [ 3%]
tests/test_rich_utils.py . [ 3%]
tests/test_tracebacks.py ... [ 3%]
tests/test_type_conversion.py .......... [ 5%]
tests/test_compat/test_option_get_help.py .... [ 6%]
tests/test_completion/test_completion.py ........ [ 7%]
tests/test_completion/test_completion_complete.py .......... [ 9%]
tests/test_completion/test_completion_complete_no_help.py .... [ 10%]
tests/test_completion/test_completion_install.py .... [ 10%]
tests/test_completion/test_completion_show.py ...... [ 12%]
tests/test_tutorial/test_arguments/test_default/test_tutorial001.py .... [ 12%]
tests/test_tutorial/test_arguments/test_default/test_tutorial002.py .... [ 13%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial001.py ...... [ 14%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial002.py ..... [ 15%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial003.py ..... [ 16%]
tests/test_tutorial/test_arguments/test_help/test_tutorial001.py .... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial002.py ... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial003.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial004.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial005.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial006.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial007.py ... [ 20%]
tests/test_tutorial/test_arguments/test_help/test_tutorial008.py .... [ 20%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial001.py ..... [ 21%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial002.py .... [ 22%]
tests/test_tutorial/test_commands/test_arguments/test_tutorial001.py ..... [ 23%]
tests/test_tutorial/test_commands/test_callback/test_tutorial001.py ........ [ 24%]
tests/test_tutorial/test_commands/test_callback/test_tutorial002.py .. [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial003.py ... [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial004.py ... [ 26%]
tests/test_tutorial/test_commands/test_context/test_tutorial001.py ... [ 26%]
tests/test_tutorial/test_commands/test_context/test_tutorial002.py .... [ 27%]
tests/test_tutorial/test_commands/test_context/test_tutorial003.py .... [ 28%]
tests/test_tutorial/test_commands/test_context/test_tutorial004.py .. [ 28%]
tests/test_tutorial/test_commands/test_help/test_tutorial001.py ............ [ 30%]
tests/test_tutorial/test_commands/test_help/test_tutorial002.py ...... [ 31%]
tests/test_tutorial/test_commands/test_help/test_tutorial003.py .... [ 32%]
tests/test_tutorial/test_commands/test_help/test_tutorial004.py ...... [ 33%]
tests/test_tutorial/test_commands/test_help/test_tutorial005.py ...... [ 34%]
tests/test_tutorial/test_commands/test_help/test_tutorial006.py ... [ 35%]
tests/test_tutorial/test_commands/test_help/test_tutorial007.py .... [ 35%]
tests/test_tutorial/test_commands/test_help/test_tutorial008.py ... [ 36%]
tests/test_tutorial/test_commands/test_index/test_tutorial001.py ... [ 36%]
tests/test_tutorial/test_commands/test_index/test_tutorial002.py .... [ 37%]
tests/test_tutorial/test_commands/test_name/test_tutorial001.py .... [ 38%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial001.py ... [ 38%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial002.py ... [ 39%]
tests/test_tutorial/test_commands/test_options/test_tutorial001.py ......... [ 40%]
tests/test_tutorial/test_exceptions/test_tutorial001.py ... [ 41%]
tests/test_tutorial/test_exceptions/test_tutorial002.py ... [ 42%]
tests/test_tutorial/test_exceptions/test_tutorial003.py .. [ 42%]
tests/test_tutorial/test_exceptions/test_tutorial004.py .. [ 42%]
tests/test_tutorial/test_first_steps/test_tutorial001.py .. [ 43%]
tests/test_tutorial/test_first_steps/test_tutorial002.py ... [ 43%]
tests/test_tutorial/test_first_steps/test_tutorial003.py ... [ 44%]
tests/test_tutorial/test_first_steps/test_tutorial004.py ...... [ 45%]
tests/test_tutorial/test_first_steps/test_tutorial005.py ...... [ 46%]
tests/test_tutorial/test_first_steps/test_tutorial006.py ...... [ 47%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial001.py .. [ 47%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial002.py ..... [ 48%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial001.py .... [ 49%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial002.py .... [ 50%]
tests/test_tutorial/test_multiple_values/test_options_with_multiple_values/test_tutorial001.py ..... [ 50%]
tests/test_tutorial/test_options/test_callback/test_tutorial001.py ... [ 51%]
tests/test_tutorial/test_options/test_callback/test_tutorial003.py .... [ 52%]
tests/test_tutorial/test_options/test_callback/test_tutorial004.py .... [ 52%]
tests/test_tutorial/test_options/test_completion/test_tutorial002.py ... [ 53%]
tests/test_tutorial/test_options/test_completion/test_tutorial003.py ... [ 53%]
tests/test_tutorial/test_options/test_completion/test_tutorial004.py ... [ 54%]
tests/test_tutorial/test_options/test_completion/test_tutorial007.py ... [ 54%]
tests/test_tutorial/test_options/test_completion/test_tutorial008.py ... [ 55%]
tests/test_tutorial/test_options/test_completion/test_tutorial009.py ... [ 56%]
tests/test_tutorial/test_options/test_help/test_tutorial001.py ..... [ 56%]
tests/test_tutorial/test_options/test_help/test_tutorial002.py .... [ 57%]
tests/test_tutorial/test_options/test_help/test_tutorial003.py ... [ 58%]
tests/test_tutorial/test_options/test_name/test_tutorial001.py ... [ 58%]
tests/test_tutorial/test_options/test_name/test_tutorial002.py .... [ 59%]
tests/test_tutorial/test_options/test_name/test_tutorial003.py ... [ 59%]
tests/test_tutorial/test_options/test_name/test_tutorial004.py .... [ 60%]
tests/test_tutorial/test_options/test_name/test_tutorial005.py ...... [ 61%]
tests/test_tutorial/test_options/test_prompt/test_tutorial001.py .... [ 62%]
tests/test_tutorial/test_options/test_prompt/test_tutorial002.py .... [ 63%]
tests/test_tutorial/test_options/test_prompt/test_tutorial003.py ..... [ 64%]
tests/test_tutorial/test_options/test_required/test_tutorial002.py ..... [ 64%]
tests/test_tutorial/test_options/test_version/test_tutorial003.py ..... [ 65%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial001.py ..... [ 66%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial002.py ....... [ 67%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial003.py .... [ 68%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial004.py ..... [ 69%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial001.py .... [ 70%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial002.py ... [ 70%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial001.py .... [ 71%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial002.py ... [ 71%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial001.py .. [ 72%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial002.py .. [ 72%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial003.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial004.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial005.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_index/test_tutorial001.py .... [ 74%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial001.py ........ [ 75%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial002.py ... [ 76%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial003.py ....... [ 77%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial001.py ..... [ 78%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial002.py F... [ 79%]
tests/test_tutorial/test_parameter_types/test_uuid/test_tutorial001.py ... [ 79%]
tests/test_tutorial/test_prompt/test_tutorial001.py .. [ 80%]
tests/test_tutorial/test_prompt/test_tutorial002.py ... [ 80%]
tests/test_tutorial/test_prompt/test_tutorial003.py ... [ 81%]
tests/test_tutorial/test_subcommands/test_tutorial001.py ......... [ 82%]
tests/test_tutorial/test_subcommands/test_tutorial002.py ......... [ 84%]
tests/test_tutorial/test_subcommands/test_tutorial003.py ................ [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial001.py .. [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial002.py .. [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial003.py ... [ 88%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial004.py ... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial001.py .... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial002.py .... [ 90%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial003.py .... [ 91%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial004.py .... [ 91%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial005.py .... [ 92%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial006.py .... [ 93%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial007.py .... [ 93%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial008.py .... [ 94%]
tests/test_tutorial/test_terminating/test_tutorial001.py .... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial002.py ... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial003.py ..... [ 96%]
tests/test_tutorial/test_testing/test_app01.py ... [ 97%]
tests/test_tutorial/test_testing/test_app02.py ... [ 97%]
tests/test_tutorial/test_testing/test_app03.py ... [ 98%]
tests/test_tutorial/test_using_click/test_tutorial003.py .... [ 99%]
tests/test_tutorial/test_using_click/test_tutorial004.py ..... [100%]
================================================================================= FAILURES =================================================================================
_____________________________________________________________________________ test_not_exists ______________________________________________________________________________
tmpdir = local('/tmp/pytest-of-tkloczko/pytest-317/test_not_exists1')
def test_not_exists(tmpdir):
config_file = Path(tmpdir) / "config.txt"
if config_file.exists(): # pragma no cover
config_file.unlink()
result = runner.invoke(app, ["--config", f"{config_file}"])
assert result.exit_code != 0
assert "Invalid value for '--config': File" in result.output
> assert "does not exist" in result.output
E assert 'does not exist' in "Usage: main [OPTIONS]\nTry 'main --help' for help.\n╭─ Error ────────────────────────────────────────────────────────... │\n╰──────────────────────────────────────────────────────────────────────────────╯\n"
E + where "Usage: main [OPTIONS]\nTry 'main --help' for help.\n╭─ Error ────────────────────────────────────────────────────────... │\n╰──────────────────────────────────────────────────────────────────────────────╯\n" = <Result SystemExit(2)>.output
tests/test_tutorial/test_parameter_types/test_path/test_tutorial002.py:22: AssertionError
============================================================================= warnings summary =============================================================================
tests/test_tutorial/test_options/test_completion/test_tutorial002.py::test_1
tests/test_tutorial/test_options/test_completion/test_tutorial003.py::test_1
tests/test_tutorial/test_options/test_completion/test_tutorial004.py::test_1
tests/test_tutorial/test_options/test_completion/test_tutorial007.py::test_1
tests/test_tutorial/test_options/test_completion/test_tutorial008.py::test_1
tests/test_tutorial/test_options/test_completion/test_tutorial009.py::test_1
/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.6.1-2.fc35.x86_64/usr/lib/python3.8/site-packages/typer/core.py:491: DeprecationWarning: 'autocompletion' is renamed to 'shell_complete'. The old name is deprecated and will be removed in Click 8.1. See the docs about 'Parameter' for information about new behavior.
_typer_param_setup_autocompletion_compat(
-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
========================================================================= short test summary info ==========================================================================
FAILED tests/test_tutorial/test_parameter_types/test_path/test_tutorial002.py::test_not_exists - assert 'does not exist' in "Usage: main [OPTIONS]\nTry 'main --help' for...
==================================================== 1 failed, 563 passed, 3 deselected, 6 warnings in 70.30s (0:01:10) ==================================================== |
I’m also seeing the same I suspect that the expected output comes from a dependency, and the version available in the distribution is different from what would be installed with |
I saw the same failure when updating typer to Debian, the problem is related to Rich. This library respects some standard environment variables such as COLUMNS, but this variable can break tests that perform string comparisons if the terminal width is small. The Typer CI passes by running tests with a large terminal width as it is possible to override the terminal width by setting the TERMINAL_WIDTH variable. |
Thanks for the help here @sergiosacj ! 👏 🙇 If that solves the original problem, then you can close this issue @kloczek ✔️ |
As @sergiosacj suggested, export TERMINAL_WIDTH=3000 fixes the problem for me in the Fedora Linux package for version 0.6.1. Updating to 0.7.0 also makes the problem go away, whether I set |
On building package build procedure has no access to pty so terminal width is unknown. |
Have you tried with the latest source? There was some similar thing with OpenSUSE and they contributed a PR with what they needed. You might also create a PR with what you need and why that is needed. For my use case as maintainer, the tests and Pytest are working correctly in CI. But if there's something you would need different and a reason why the current default setup doesn't work for you, maybe you could suggest a PR. |
I cannot locate exact commit which could be applied on top of last tagged state to test that. |
What do you mean? It's just the |
I've testes pytest with + PYTHONPATH=/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.7.0-3.fc35.x86_64/usr/lib64/python3.8/site-packages:/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.7.0-3.fc35.x86_64/usr/lib/python3.8/site-packages
+ /usr/bin/pytest -ra
=========================================================================== test session starts ============================================================================
platform linux -- Python 3.8.15, pytest-7.1.3, pluggy-1.0.0
rootdir: /home/tkloczko/rpmbuild/BUILD/typer-0.7.0, configfile: pyproject.toml
plugins: cov-3.0.0
collected 567 items
docs_src/testing/app01/test_main.py . [ 0%]
docs_src/testing/app02/test_main.py . [ 0%]
docs_src/testing/app03/test_main.py . [ 0%]
tests/test_exit_errors.py ... [ 1%]
tests/test_others.py ........... [ 2%]
tests/test_prog_name.py . [ 3%]
tests/test_rich_utils.py . [ 3%]
tests/test_tracebacks.py ... [ 3%]
tests/test_type_conversion.py .......... [ 5%]
tests/test_compat/test_option_get_help.py .... [ 6%]
tests/test_completion/test_completion.py FF........ [ 8%]
tests/test_completion/test_completion_complete.py .......... [ 9%]
tests/test_completion/test_completion_complete_no_help.py .... [ 10%]
tests/test_completion/test_completion_install.py .F... [ 11%]
tests/test_completion/test_completion_show.py ...... [ 12%]
tests/test_tutorial/test_arguments/test_default/test_tutorial001.py .... [ 13%]
tests/test_tutorial/test_arguments/test_default/test_tutorial002.py .... [ 13%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial001.py ...... [ 14%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial002.py ..... [ 15%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial003.py ..... [ 16%]
tests/test_tutorial/test_arguments/test_help/test_tutorial001.py .... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial002.py ... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial003.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial004.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial005.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial006.py ... [ 20%]
tests/test_tutorial/test_arguments/test_help/test_tutorial007.py ... [ 20%]
tests/test_tutorial/test_arguments/test_help/test_tutorial008.py .... [ 21%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial001.py ..... [ 22%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial002.py .... [ 22%]
tests/test_tutorial/test_commands/test_arguments/test_tutorial001.py ..... [ 23%]
tests/test_tutorial/test_commands/test_callback/test_tutorial001.py ........ [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial002.py .. [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial003.py ... [ 26%]
tests/test_tutorial/test_commands/test_callback/test_tutorial004.py ... [ 26%]
tests/test_tutorial/test_commands/test_context/test_tutorial001.py ... [ 27%]
tests/test_tutorial/test_commands/test_context/test_tutorial002.py .... [ 27%]
tests/test_tutorial/test_commands/test_context/test_tutorial003.py .... [ 28%]
tests/test_tutorial/test_commands/test_context/test_tutorial004.py .. [ 28%]
tests/test_tutorial/test_commands/test_help/test_tutorial001.py ............ [ 31%]
tests/test_tutorial/test_commands/test_help/test_tutorial002.py ...... [ 32%]
tests/test_tutorial/test_commands/test_help/test_tutorial003.py .... [ 32%]
tests/test_tutorial/test_commands/test_help/test_tutorial004.py ...... [ 33%]
tests/test_tutorial/test_commands/test_help/test_tutorial005.py ...... [ 34%]
tests/test_tutorial/test_commands/test_help/test_tutorial006.py ... [ 35%]
tests/test_tutorial/test_commands/test_help/test_tutorial007.py .... [ 36%]
tests/test_tutorial/test_commands/test_help/test_tutorial008.py ... [ 36%]
tests/test_tutorial/test_commands/test_index/test_tutorial001.py ... [ 37%]
tests/test_tutorial/test_commands/test_index/test_tutorial002.py .... [ 37%]
tests/test_tutorial/test_commands/test_name/test_tutorial001.py .... [ 38%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial001.py ... [ 39%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial002.py ... [ 39%]
tests/test_tutorial/test_commands/test_options/test_tutorial001.py ......... [ 41%]
tests/test_tutorial/test_exceptions/test_tutorial001.py ... [ 41%]
tests/test_tutorial/test_exceptions/test_tutorial002.py ... [ 42%]
tests/test_tutorial/test_exceptions/test_tutorial003.py .. [ 42%]
tests/test_tutorial/test_exceptions/test_tutorial004.py .. [ 43%]
tests/test_tutorial/test_first_steps/test_tutorial001.py .. [ 43%]
tests/test_tutorial/test_first_steps/test_tutorial002.py ... [ 43%]
tests/test_tutorial/test_first_steps/test_tutorial003.py ... [ 44%]
tests/test_tutorial/test_first_steps/test_tutorial004.py ...... [ 45%]
tests/test_tutorial/test_first_steps/test_tutorial005.py ...... [ 46%]
tests/test_tutorial/test_first_steps/test_tutorial006.py ...... [ 47%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial001.py .. [ 47%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial002.py ..... [ 48%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial001.py .... [ 49%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial002.py .... [ 50%]
tests/test_tutorial/test_multiple_values/test_options_with_multiple_values/test_tutorial001.py ..... [ 51%]
tests/test_tutorial/test_options/test_callback/test_tutorial001.py ... [ 51%]
tests/test_tutorial/test_options/test_callback/test_tutorial003.py .... [ 52%]
tests/test_tutorial/test_options/test_callback/test_tutorial004.py .... [ 53%]
tests/test_tutorial/test_options/test_help/test_tutorial001.py ..... [ 53%]
tests/test_tutorial/test_options/test_help/test_tutorial002.py .... [ 54%]
tests/test_tutorial/test_options/test_help/test_tutorial003.py ... [ 55%]
tests/test_tutorial/test_options/test_name/test_tutorial001.py ... [ 55%]
tests/test_tutorial/test_options/test_name/test_tutorial002.py .... [ 56%]
tests/test_tutorial/test_options/test_name/test_tutorial003.py ... [ 56%]
tests/test_tutorial/test_options/test_name/test_tutorial004.py .... [ 57%]
tests/test_tutorial/test_options/test_name/test_tutorial005.py ...... [ 58%]
tests/test_tutorial/test_options/test_prompt/test_tutorial001.py .... [ 59%]
tests/test_tutorial/test_options/test_prompt/test_tutorial002.py .... [ 60%]
tests/test_tutorial/test_options/test_prompt/test_tutorial003.py ..... [ 61%]
tests/test_tutorial/test_options/test_required/test_tutorial002.py ..... [ 61%]
tests/test_tutorial/test_options/test_version/test_tutorial003.py ..... [ 62%]
tests/test_tutorial/test_options_autocompletion/test_tutorial002.py ... [ 63%]
tests/test_tutorial/test_options_autocompletion/test_tutorial003.py ... [ 63%]
tests/test_tutorial/test_options_autocompletion/test_tutorial004.py ... [ 64%]
tests/test_tutorial/test_options_autocompletion/test_tutorial007.py ... [ 64%]
tests/test_tutorial/test_options_autocompletion/test_tutorial008.py ... [ 65%]
tests/test_tutorial/test_options_autocompletion/test_tutorial009.py ... [ 65%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial001.py ..... [ 66%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial002.py ....... [ 68%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial003.py .... [ 68%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial004.py ..... [ 69%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial001.py .... [ 70%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial002.py ... [ 70%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial001.py .... [ 71%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial002.py ... [ 72%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial001.py .. [ 72%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial002.py .. [ 72%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial003.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial004.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial005.py .. [ 73%]
tests/test_tutorial/test_parameter_types/test_index/test_tutorial001.py .... [ 74%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial001.py ........ [ 76%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial002.py ... [ 76%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial003.py ....... [ 77%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial001.py ..... [ 78%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial002.py .... [ 79%]
tests/test_tutorial/test_parameter_types/test_uuid/test_tutorial001.py ... [ 79%]
tests/test_tutorial/test_prompt/test_tutorial001.py .. [ 80%]
tests/test_tutorial/test_prompt/test_tutorial002.py ... [ 80%]
tests/test_tutorial/test_prompt/test_tutorial003.py ... [ 81%]
tests/test_tutorial/test_subcommands/test_tutorial001.py ......... [ 82%]
tests/test_tutorial/test_subcommands/test_tutorial002.py ......... [ 84%]
tests/test_tutorial/test_subcommands/test_tutorial003.py ................ [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial001.py .. [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial002.py .. [ 88%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial003.py ... [ 88%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial004.py ... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial001.py .... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial002.py .... [ 90%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial003.py .... [ 91%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial004.py .... [ 91%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial005.py .... [ 92%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial006.py .... [ 93%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial007.py .... [ 94%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial008.py .... [ 94%]
tests/test_tutorial/test_terminating/test_tutorial001.py .... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial002.py ... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial003.py ..... [ 96%]
tests/test_tutorial/test_testing/test_app01.py ... [ 97%]
tests/test_tutorial/test_testing/test_app02.py ... [ 97%]
tests/test_tutorial/test_testing/test_app03.py ... [ 98%]
tests/test_tutorial/test_using_click/test_tutorial003.py .... [ 99%]
tests/test_tutorial/test_using_click/test_tutorial004.py ..... [100%]
================================================================================= FAILURES =================================================================================
___________________________________________________________________________ test_show_completion ___________________________________________________________________________
def test_show_completion():
result = subprocess.run(
[
"bash",
"-c",
f"{sys.executable} -m coverage run {mod.__file__} --show-completion",
],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
encoding="utf-8",
env={**os.environ, "SHELL": "/bin/bash", "_TYPER_COMPLETE_TESTING": "True"},
)
> assert "_TUTORIAL001.PY_COMPLETE=complete_bash" in result.stdout
E AssertionError: assert '_TUTORIAL001.PY_COMPLETE=complete_bash' in ''
E + where '' = CompletedProcess(args=['bash', '-c', '/usr/bin/python3 -m coverage run /home/tkloczko/rpmbuild/BUILD/typer-0.7.0/docs_src/commands/index/tutorial001.py --show-completion'], returncode=1, stdout='', stderr='Shell sh not supported.\n').stdout
tests/test_completion/test_completion.py:21: AssertionError
_________________________________________________________________________ test_install_completion __________________________________________________________________________
def test_install_completion():
bash_completion_path: Path = Path.home() / ".bashrc"
text = ""
if bash_completion_path.is_file(): # pragma: nocover
text = bash_completion_path.read_text()
result = subprocess.run(
[
"bash",
"-c",
f"{sys.executable} -m coverage run {mod.__file__} --install-completion",
],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
encoding="utf-8",
env={**os.environ, "SHELL": "/bin/bash", "_TYPER_COMPLETE_TESTING": "True"},
)
new_text = bash_completion_path.read_text()
> bash_completion_path.write_text(text)
tests/test_completion/test_completion.py:41:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/usr/lib64/python3.8/pathlib.py:1255: in write_text
with self.open(mode='w', encoding=encoding, errors=errors) as f:
/usr/lib64/python3.8/pathlib.py:1222: in open
return io.open(self, mode, buffering, encoding, errors, newline,
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = PosixPath('/home/tkloczko/.bashrc'), name = '/home/tkloczko/.bashrc', flags = 524865, mode = 438
def _opener(self, name, flags, mode=0o666):
# A stub for the opener argument to built-in open()
> return self._accessor.open(self, flags, mode)
E PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
/usr/lib64/python3.8/pathlib.py:1078: PermissionError
_______________________________________________________________________ test_completion_install_bash _______________________________________________________________________
def test_completion_install_bash():
bash_completion_path: Path = Path.home() / ".bashrc"
text = ""
if bash_completion_path.is_file():
text = bash_completion_path.read_text()
result = subprocess.run(
["coverage", "run", mod.__file__, "--install-completion", "bash"],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
encoding="utf-8",
env={
**os.environ,
"_TYPER_COMPLETE_TESTING": "True",
"_TYPER_COMPLETE_TEST_DISABLE_SHELL_DETECTION": "True",
},
)
new_text = bash_completion_path.read_text()
> bash_completion_path.write_text(text)
tests/test_completion/test_completion_install.py:53:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/usr/lib64/python3.8/pathlib.py:1255: in write_text
with self.open(mode='w', encoding=encoding, errors=errors) as f:
/usr/lib64/python3.8/pathlib.py:1222: in open
return io.open(self, mode, buffering, encoding, errors, newline,
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = PosixPath('/home/tkloczko/.bashrc'), name = '/home/tkloczko/.bashrc', flags = 524865, mode = 438
def _opener(self, name, flags, mode=0o666):
# A stub for the opener argument to built-in open()
> return self._accessor.open(self, flags, mode)
E PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
/usr/lib64/python3.8/pathlib.py:1078: PermissionError
========================================================================= short test summary info ==========================================================================
FAILED tests/test_completion/test_completion.py::test_show_completion - AssertionError: assert '_TUTORIAL001.PY_COMPLETE=complete_bash' in ''
FAILED tests/test_completion/test_completion.py::test_install_completion - PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
FAILED tests/test_completion/test_completion_install.py::test_completion_install_bash - PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
================================================================= 3 failed, 564 passed in 68.94s (0:01:08) ================================================================= Why test units are trying fiddle in files outside build env? 🤔 |
Gentle ping .. any update? 🤔 |
Just tested 0.11.0 and still I see that test suite tries to write something in ~.bashrc. Here is pytest output:+ export TERMINAL_WIDTH=3000 _TYPER_FORCE_DISABLE_TERMINAL=1
+ TERMINAL_WIDTH=3000
+ _TYPER_FORCE_DISABLE_TERMINAL=1
+ PYTHONPATH=/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.11.0-2.fc36.x86_64/usr/lib64/python3.9/site-packages:/home/tkloczko/rpmbuild/BUILDROOT/python-typer-0.11.0-2.fc36.x86_64/usr/lib/python3.9/site-packages
+ /usr/bin/pytest -ra -m 'not network'
==================================================================================== test session starts ====================================================================================
platform linux -- Python 3.9.18, pytest-8.1.1, pluggy-1.4.0
rootdir: /home/tkloczko/rpmbuild/BUILD/typer-0.11.0
configfile: pyproject.toml
collected 901 items
docs_src/testing/app01/test_main.py . [ 0%]
docs_src/testing/app02/test_main.py . [ 0%]
docs_src/testing/app02_an/test_main.py . [ 0%]
docs_src/testing/app03/test_main.py . [ 0%]
tests/test_ambiguous_params.py ................... [ 2%]
tests/test_annotated.py .s.. [ 2%]
tests/test_compat/test_option_get_help.py .... [ 3%]
tests/test_completion/test_completion.py FF........ [ 4%]
tests/test_completion/test_completion_complete.py .......... [ 5%]
tests/test_completion/test_completion_complete_no_help.py .... [ 6%]
tests/test_completion/test_completion_install.py .F... [ 6%]
tests/test_completion/test_completion_show.py ....... [ 7%]
tests/test_exit_errors.py ... [ 7%]
tests/test_others.py .............. [ 9%]
tests/test_prog_name.py . [ 9%]
tests/test_rich_utils.py . [ 9%]
tests/test_tracebacks.py ... [ 9%]
tests/test_tutorial/test_arguments/test_default/test_tutorial001.py .... [ 10%]
tests/test_tutorial/test_arguments/test_default/test_tutorial001_an.py .... [ 10%]
tests/test_tutorial/test_arguments/test_default/test_tutorial002.py .... [ 11%]
tests/test_tutorial/test_arguments/test_default/test_tutorial002_an.py .... [ 11%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial001.py ...... [ 12%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial001_an.py ...... [ 12%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial002.py ..... [ 13%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial002_an.py ..... [ 14%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial003.py ..... [ 14%]
tests/test_tutorial/test_arguments/test_envvar/test_tutorial003_an.py ..... [ 15%]
tests/test_tutorial/test_arguments/test_help/test_tutorial001.py .... [ 15%]
tests/test_tutorial/test_arguments/test_help/test_tutorial001_an.py .... [ 16%]
tests/test_tutorial/test_arguments/test_help/test_tutorial002.py ... [ 16%]
tests/test_tutorial/test_arguments/test_help/test_tutorial002_an.py ... [ 16%]
tests/test_tutorial/test_arguments/test_help/test_tutorial003.py ... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial003_an.py ... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial004.py ... [ 17%]
tests/test_tutorial/test_arguments/test_help/test_tutorial004_an.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial005.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial005_an.py ... [ 18%]
tests/test_tutorial/test_arguments/test_help/test_tutorial006.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial006_an.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial007.py ... [ 19%]
tests/test_tutorial/test_arguments/test_help/test_tutorial007_an.py ... [ 20%]
tests/test_tutorial/test_arguments/test_help/test_tutorial008.py .... [ 20%]
tests/test_tutorial/test_arguments/test_help/test_tutorial008_an.py .... [ 20%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial001.py ..... [ 21%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial001_an.py ..... [ 22%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial002.py .... [ 22%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial002_an.py .... [ 22%]
tests/test_tutorial/test_arguments/test_optional/test_tutorial003.py ..... [ 23%]
tests/test_tutorial/test_commands/test_arguments/test_tutorial001.py ..... [ 24%]
tests/test_tutorial/test_commands/test_callback/test_tutorial001.py ........ [ 24%]
tests/test_tutorial/test_commands/test_callback/test_tutorial002.py .. [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial003.py ... [ 25%]
tests/test_tutorial/test_commands/test_callback/test_tutorial004.py ... [ 25%]
tests/test_tutorial/test_commands/test_context/test_tutorial001.py ... [ 26%]
tests/test_tutorial/test_commands/test_context/test_tutorial002.py .... [ 26%]
tests/test_tutorial/test_commands/test_context/test_tutorial003.py .... [ 27%]
tests/test_tutorial/test_commands/test_context/test_tutorial004.py .. [ 27%]
tests/test_tutorial/test_commands/test_help/test_tutorial001.py ............ [ 28%]
tests/test_tutorial/test_commands/test_help/test_tutorial001_an.py ............ [ 29%]
tests/test_tutorial/test_commands/test_help/test_tutorial002.py ...... [ 30%]
tests/test_tutorial/test_commands/test_help/test_tutorial003.py .... [ 31%]
tests/test_tutorial/test_commands/test_help/test_tutorial004.py ...... [ 31%]
tests/test_tutorial/test_commands/test_help/test_tutorial004_an.py ...... [ 32%]
tests/test_tutorial/test_commands/test_help/test_tutorial005.py ...... [ 33%]
tests/test_tutorial/test_commands/test_help/test_tutorial005_an.py ...... [ 33%]
tests/test_tutorial/test_commands/test_help/test_tutorial006.py ... [ 34%]
tests/test_tutorial/test_commands/test_help/test_tutorial007.py .... [ 34%]
tests/test_tutorial/test_commands/test_help/test_tutorial007_an.py .... [ 34%]
tests/test_tutorial/test_commands/test_help/test_tutorial008.py ... [ 35%]
tests/test_tutorial/test_commands/test_index/test_tutorial001.py ... [ 35%]
tests/test_tutorial/test_commands/test_index/test_tutorial002.py .... [ 36%]
tests/test_tutorial/test_commands/test_index/test_tutorial003.py .... [ 36%]
tests/test_tutorial/test_commands/test_name/test_tutorial001.py .... [ 36%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial001.py ... [ 37%]
tests/test_tutorial/test_commands/test_one_or_multiple/test_tutorial002.py ... [ 37%]
tests/test_tutorial/test_commands/test_options/test_tutorial001.py ......... [ 38%]
tests/test_tutorial/test_commands/test_options/test_tutorial001_an.py ......... [ 39%]
tests/test_tutorial/test_exceptions/test_tutorial001.py ... [ 39%]
tests/test_tutorial/test_exceptions/test_tutorial002.py ... [ 40%]
tests/test_tutorial/test_exceptions/test_tutorial003.py .. [ 40%]
tests/test_tutorial/test_exceptions/test_tutorial004.py .. [ 40%]
tests/test_tutorial/test_first_steps/test_tutorial001.py .. [ 40%]
tests/test_tutorial/test_first_steps/test_tutorial002.py ... [ 41%]
tests/test_tutorial/test_first_steps/test_tutorial003.py ... [ 41%]
tests/test_tutorial/test_first_steps/test_tutorial004.py ...... [ 42%]
tests/test_tutorial/test_first_steps/test_tutorial005.py ...... [ 42%]
tests/test_tutorial/test_first_steps/test_tutorial006.py ...... [ 43%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial001.py .. [ 43%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial002.py ..... [ 44%]
tests/test_tutorial/test_multiple_values/test_arguments_with_multiple_values/test_tutorial002_an.py ..... [ 44%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial001.py .... [ 45%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial001_an.py .... [ 45%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial002.py .... [ 46%]
tests/test_tutorial/test_multiple_values/test_multiple_options/test_tutorial002_an.py .... [ 46%]
tests/test_tutorial/test_multiple_values/test_options_with_multiple_values/test_tutorial001.py ..... [ 47%]
tests/test_tutorial/test_multiple_values/test_options_with_multiple_values/test_tutorial001_an.py ..... [ 47%]
tests/test_tutorial/test_options/test_callback/test_tutorial001.py ... [ 48%]
tests/test_tutorial/test_options/test_callback/test_tutorial001_an.py ... [ 48%]
tests/test_tutorial/test_options/test_callback/test_tutorial003.py .... [ 48%]
tests/test_tutorial/test_options/test_callback/test_tutorial003_an.py .... [ 49%]
tests/test_tutorial/test_options/test_callback/test_tutorial004.py .... [ 49%]
tests/test_tutorial/test_options/test_callback/test_tutorial004_an.py .... [ 50%]
tests/test_tutorial/test_options/test_help/test_tutorial001.py ..... [ 50%]
tests/test_tutorial/test_options/test_help/test_tutorial001_an.py ..... [ 51%]
tests/test_tutorial/test_options/test_help/test_tutorial002.py .... [ 51%]
tests/test_tutorial/test_options/test_help/test_tutorial002_an.py .... [ 52%]
tests/test_tutorial/test_options/test_help/test_tutorial003.py ... [ 52%]
tests/test_tutorial/test_options/test_help/test_tutorial003_an.py ... [ 52%]
tests/test_tutorial/test_options/test_name/test_tutorial001.py .... [ 53%]
tests/test_tutorial/test_options/test_name/test_tutorial001_an.py .... [ 53%]
tests/test_tutorial/test_options/test_name/test_tutorial002.py .... [ 54%]
tests/test_tutorial/test_options/test_name/test_tutorial002_an.py .... [ 54%]
tests/test_tutorial/test_options/test_name/test_tutorial003.py ... [ 55%]
tests/test_tutorial/test_options/test_name/test_tutorial003_an.py ... [ 55%]
tests/test_tutorial/test_options/test_name/test_tutorial004.py .... [ 55%]
tests/test_tutorial/test_options/test_name/test_tutorial004_an.py .... [ 56%]
tests/test_tutorial/test_options/test_name/test_tutorial005.py ...... [ 56%]
tests/test_tutorial/test_options/test_name/test_tutorial005_an.py ...... [ 57%]
tests/test_tutorial/test_options/test_prompt/test_tutorial001.py .... [ 58%]
tests/test_tutorial/test_options/test_prompt/test_tutorial001_an.py .... [ 58%]
tests/test_tutorial/test_options/test_prompt/test_tutorial002.py .... [ 58%]
tests/test_tutorial/test_options/test_prompt/test_tutorial002_an.py .... [ 59%]
tests/test_tutorial/test_options/test_prompt/test_tutorial003.py ..... [ 59%]
tests/test_tutorial/test_options/test_prompt/test_tutorial003_an.py ..... [ 60%]
tests/test_tutorial/test_options/test_required/test_tutorial001.py ..... [ 61%]
tests/test_tutorial/test_options/test_required/test_tutorial001_an.py ..... [ 61%]
tests/test_tutorial/test_options/test_version/test_tutorial003.py ..... [ 62%]
tests/test_tutorial/test_options/test_version/test_tutorial003_an.py ..... [ 62%]
tests/test_tutorial/test_options_autocompletion/test_tutorial002.py ... [ 63%]
tests/test_tutorial/test_options_autocompletion/test_tutorial002_an.py ... [ 63%]
tests/test_tutorial/test_options_autocompletion/test_tutorial003.py ... [ 63%]
tests/test_tutorial/test_options_autocompletion/test_tutorial003_an.py ... [ 64%]
tests/test_tutorial/test_options_autocompletion/test_tutorial004.py ... [ 64%]
tests/test_tutorial/test_options_autocompletion/test_tutorial004_an.py ... [ 64%]
tests/test_tutorial/test_options_autocompletion/test_tutorial007.py ... [ 65%]
tests/test_tutorial/test_options_autocompletion/test_tutorial007_an.py ... [ 65%]
tests/test_tutorial/test_options_autocompletion/test_tutorial008.py ... [ 65%]
tests/test_tutorial/test_options_autocompletion/test_tutorial008_an.py ... [ 66%]
tests/test_tutorial/test_options_autocompletion/test_tutorial009.py ... [ 66%]
tests/test_tutorial/test_options_autocompletion/test_tutorial009_an.py ... [ 66%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial001.py ..... [ 67%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial001_an.py ..... [ 67%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial002.py ....... [ 68%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial002_an.py ....... [ 69%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial003.py .... [ 69%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial003_an.py .... [ 70%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial004.py ..... [ 70%]
tests/test_tutorial/test_parameter_types/test_bool/test_tutorial004_an.py ..... [ 71%]
tests/test_tutorial/test_parameter_types/test_custom_types/test_tutorial001.py .... [ 71%]
tests/test_tutorial/test_parameter_types/test_custom_types/test_tutorial001_an.py .... [ 72%]
tests/test_tutorial/test_parameter_types/test_custom_types/test_tutorial002.py .... [ 72%]
tests/test_tutorial/test_parameter_types/test_custom_types/test_tutorial002_an.py .... [ 73%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial001.py .... [ 73%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial002.py ... [ 73%]
tests/test_tutorial/test_parameter_types/test_datetime/test_tutorial002_an.py ... [ 74%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial001.py ..... [ 74%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial002.py ... [ 75%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial002_an.py ... [ 75%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial003.py ..... [ 76%]
tests/test_tutorial/test_parameter_types/test_enum/test_tutorial003_an.py ..... [ 76%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial001.py .. [ 76%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial001_an.py .. [ 77%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial002.py .. [ 77%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial002_an.py .. [ 77%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial003.py .. [ 77%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial003_an.py .. [ 77%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial004.py .. [ 78%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial004_an.py .. [ 78%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial005.py .. [ 78%]
tests/test_tutorial/test_parameter_types/test_file/test_tutorial005_an.py .. [ 78%]
tests/test_tutorial/test_parameter_types/test_index/test_tutorial001.py .... [ 79%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial001.py ........ [ 80%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial001_an.py ........ [ 81%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial002.py ... [ 81%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial002_an.py ... [ 81%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial003.py ....... [ 82%]
tests/test_tutorial/test_parameter_types/test_number/test_tutorial003_an.py ....... [ 83%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial001.py ..... [ 83%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial001_an.py ..... [ 84%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial002.py .... [ 84%]
tests/test_tutorial/test_parameter_types/test_path/test_tutorial002_an.py .... [ 85%]
tests/test_tutorial/test_parameter_types/test_uuid/test_tutorial001.py ... [ 85%]
tests/test_tutorial/test_prompt/test_tutorial001.py .. [ 85%]
tests/test_tutorial/test_prompt/test_tutorial002.py ... [ 86%]
tests/test_tutorial/test_prompt/test_tutorial003.py ... [ 86%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial001.py .. [ 86%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial002.py .. [ 86%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial003.py ... [ 87%]
tests/test_tutorial/test_subcommands/test_callback_override/test_tutorial004.py ... [ 87%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial001.py .... [ 88%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial002.py .... [ 88%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial003.py .... [ 88%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial004.py .... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial005.py .... [ 89%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial006.py .... [ 90%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial007.py .... [ 90%]
tests/test_tutorial/test_subcommands/test_name_help/test_tutorial008.py .... [ 91%]
tests/test_tutorial/test_subcommands/test_tutorial001.py ......... [ 92%]
tests/test_tutorial/test_subcommands/test_tutorial002.py ......... [ 93%]
tests/test_tutorial/test_subcommands/test_tutorial003.py ................ [ 94%]
tests/test_tutorial/test_terminating/test_tutorial001.py .... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial002.py ... [ 95%]
tests/test_tutorial/test_terminating/test_tutorial003.py ..... [ 96%]
tests/test_tutorial/test_testing/test_app01.py ... [ 96%]
tests/test_tutorial/test_testing/test_app02.py ... [ 96%]
tests/test_tutorial/test_testing/test_app02_an.py ... [ 97%]
tests/test_tutorial/test_testing/test_app03.py ... [ 97%]
tests/test_tutorial/test_using_click/test_tutorial003.py ..... [ 98%]
tests/test_tutorial/test_using_click/test_tutorial004.py ..... [ 98%]
tests/test_type_conversion.py ............ [100%]
========================================================================================= FAILURES ==========================================================================================
___________________________________________________________________________________ test_show_completion ____________________________________________________________________________________
def test_show_completion():
result = subprocess.run(
[
"bash",
"-c",
f"{sys.executable} -m coverage run {mod.__file__} --show-completion",
],
capture_output=True,
encoding="utf-8",
env={**os.environ, "SHELL": "/bin/bash", "_TYPER_COMPLETE_TESTING": "True"},
)
> assert "_TUTORIAL001.PY_COMPLETE=complete_bash" in result.stdout
E AssertionError: assert '_TUTORIAL001.PY_COMPLETE=complete_bash' in ''
E + where '' = CompletedProcess(args=['bash', '-c', '/usr/bin/python3 -m coverage run /home/tkloczko/rpmbuild/BUILD/typer-0.11.0/docs_src/commands/index/tutorial001.py --show-completion'], returncode=1, stdout='', stderr='Shell sh not supported.\n').stdout
tests/test_completion/test_completion.py:20: AssertionError
__________________________________________________________________________________ test_install_completion __________________________________________________________________________________
def test_install_completion():
bash_completion_path: Path = Path.home() / ".bashrc"
text = ""
if bash_completion_path.is_file(): # pragma: no cover
text = bash_completion_path.read_text()
result = subprocess.run(
[
"bash",
"-c",
f"{sys.executable} -m coverage run {mod.__file__} --install-completion",
],
capture_output=True,
encoding="utf-8",
env={**os.environ, "SHELL": "/bin/bash", "_TYPER_COMPLETE_TESTING": "True"},
)
new_text = bash_completion_path.read_text()
> bash_completion_path.write_text(text)
tests/test_completion/test_completion.py:39:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/usr/lib64/python3.9/pathlib.py:1285: in write_text
with self.open(mode='w', encoding=encoding, errors=errors) as f:
/usr/lib64/python3.9/pathlib.py:1252: in open
return io.open(self, mode, buffering, encoding, errors, newline,
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = PosixPath('/home/tkloczko/.bashrc'), name = '/home/tkloczko/.bashrc', flags = 524865, mode = 438
def _opener(self, name, flags, mode=0o666):
# A stub for the opener argument to built-in open()
> return self._accessor.open(self, flags, mode)
E PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
/usr/lib64/python3.9/pathlib.py:1120: PermissionError
_______________________________________________________________________________ test_completion_install_bash ________________________________________________________________________________
def test_completion_install_bash():
bash_completion_path: Path = Path.home() / ".bashrc"
text = ""
if bash_completion_path.is_file():
text = bash_completion_path.read_text()
result = subprocess.run(
[
sys.executable,
"-m",
"coverage",
"run",
mod.__file__,
"--install-completion",
"bash",
],
capture_output=True,
encoding="utf-8",
env={
**os.environ,
"_TYPER_COMPLETE_TESTING": "True",
"_TYPER_COMPLETE_TEST_DISABLE_SHELL_DETECTION": "True",
},
)
new_text = bash_completion_path.read_text()
> bash_completion_path.write_text(text)
tests/test_completion/test_completion_install.py:56:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/usr/lib64/python3.9/pathlib.py:1285: in write_text
with self.open(mode='w', encoding=encoding, errors=errors) as f:
/usr/lib64/python3.9/pathlib.py:1252: in open
return io.open(self, mode, buffering, encoding, errors, newline,
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = PosixPath('/home/tkloczko/.bashrc'), name = '/home/tkloczko/.bashrc', flags = 524865, mode = 438
def _opener(self, name, flags, mode=0o666):
# A stub for the opener argument to built-in open()
> return self._accessor.open(self, flags, mode)
E PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
/usr/lib64/python3.9/pathlib.py:1120: PermissionError
================================================================================== short test summary info ==================================================================================
SKIPPED [1] tests/test_annotated.py:26: requires python3.10+
FAILED tests/test_completion/test_completion.py::test_show_completion - AssertionError: assert '_TUTORIAL001.PY_COMPLETE=complete_bash' in ''
FAILED tests/test_completion/test_completion.py::test_install_completion - PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
FAILED tests/test_completion/test_completion_install.py::test_completion_install_bash - PermissionError: [Errno 13] Permission denied: '/home/tkloczko/.bashrc'
=================================================================== 3 failed, 897 passed, 1 skipped in 123.20s (0:02:03) ==================================================================== |
Hey @kloczek, apologies for the late follow-up. We've been discussing this here and it sounds like Tiangolo's proposal would fix your issue, right?
|
Do you wan me to test that? 🤔 |
Once we've got a solution ready you could, yea :-) |
First Check
Commit to Help
Example Code
Description
I'm packaging your module as the rpm package. So I'm using the typical PEP517 based build, install and test cycle used on building packages from non-root account.
python3 -sBm build -w --no-isolation
build
with--no-isolation
I'm using during all processes only locally installed modulesLooks like ltwo unist are tring to modify my ~/.bashrc
Here is pytest output:
Wanted Solution
pytest shopuld be working and test suite should not be fidling in user ~/,bashrc
Wanted Code
Alternatives
No response
Operating System
Linux
Operating System Details
No response
Typer Version
0.5.0
Python Version
3.8.13
Additional Context
Not applicable
The text was updated successfully, but these errors were encountered: