Coverage for tests / test_tutorial / test_progressbar / test_tutorial001.py: 100%
28 statements
« prev ^ index » next coverage.py v7.13.1, created at 2026-03-26 21:46 +0000
« prev ^ index » next coverage.py v7.13.1, created at 2026-03-26 21:46 +0000
1import subprocess 1abcdefg
2import sys 1abcdefg
3from unittest.mock import patch 1abcdefg
5import typer 1abcdefg
6from typer.testing import CliRunner 1abcdefg
8import docs_src.progressbar.tutorial001_py310 as mod 1abcdefg
9from tests.utils import normalize_rich_output 1abcdefg
11app = mod.app 1abcdefg
13runner = CliRunner() 1abcdefg
16def test_cli_one_step(): 1abcdefg
17 with patch("time.sleep") as sleep_mock: 1abcdefg
18 sleep_mock.side_effect = typer.Exit() # Exit on first `time.sleep()` call 1abcdefg
19 result = runner.invoke(app) 1abcdefg
21 # Replace all Rich formatting with `*` characters
22 normalized_output = normalize_rich_output(result.output) 1abcdefg
24 assert result.exit_code == 0 1abcdefg
25 assert "Processing... 0%" in normalized_output 1abcdefg
28def test_cli(): 1abcdefg
29 with patch("time.sleep") as mock_sleep: 1abcdefg
30 result = runner.invoke(app) 1abcdefg
32 # Replace all Rich formatting with `*` characters
33 normalized_output = normalize_rich_output(result.output) 1abcdefg
35 assert result.exit_code == 0 1abcdefg
36 assert mock_sleep.call_count == 100 1abcdefg
37 assert "Processing..." in normalized_output 1abcdefg
38 assert "100%" in normalized_output 1abcdefg
39 assert "Processed 100 things." in normalized_output 1abcdefg
42def test_script(): 1abcdefg
43 result = subprocess.run( 1abcdefg
44 [sys.executable, "-m", "coverage", "run", mod.__file__, "--help"],
45 capture_output=True,
46 encoding="utf-8",
47 )
48 assert "Usage" in result.stdout 1abcdefg