Coverage for tests / test_tutorial / test_progressbar / test_tutorial004.py: 100%
31 statements
« prev ^ index » next coverage.py v7.13.1, created at 2026-02-09 12:36 +0000
« prev ^ index » next coverage.py v7.13.1, created at 2026-02-09 12:36 +0000
1import subprocess 1adebfgch
2import sys 1adebfgch
3from unittest.mock import patch 1adebfgch
5from typer.testing import CliRunner 1adebfgch
7import docs_src.progressbar.tutorial004_py39 as mod 1adebfgch
8from tests.utils import normalize_rich_output 1adebfgch
10app = mod.app 1adebfgch
12runner = CliRunner() 1adebfgch
15def test_cli(): # Checking only final state of progress bar 1adebfgch
16 consumed = [] 1adebfgch
18 def fake_iterate_user_ids(): 1adebfgch
19 for i in range(100): 1adebfgch
20 consumed.append(i) 1adebfgch
21 yield i 1adebfgch
23 with ( 1abc
24 patch("time.sleep") as mock_sleep,
25 patch(
26 "docs_src.progressbar.tutorial004_py39.iterate_user_ids",
27 side_effect=fake_iterate_user_ids,
28 ),
29 ):
30 result = runner.invoke(app) 1adebfgch
32 # Replace all Rich formatting with `*` characters
33 normalized_output = normalize_rich_output(result.output) 1adebfgch
35 assert result.exit_code == 0 1adebfgch
36 assert len(consumed) == 100 1adebfgch
37 assert mock_sleep.call_count == 100 1adebfgch
38 assert "Processed 100 user IDs." in normalized_output 1adebfgch
41def test_cli_no_mock_generator(): 1adebfgch
42 with ( 1abc
43 patch("time.sleep") as mock_sleep,
44 ):
45 result = runner.invoke(app) 1adebfgch
47 # Replace all Rich formatting with `*` characters
48 normalized_output = normalize_rich_output(result.output) 1adebfgch
50 assert result.exit_code == 0 1adebfgch
51 assert mock_sleep.call_count == 100 1adebfgch
52 assert "Processed 100 user IDs." in normalized_output 1adebfgch
55def test_script(): 1adebfgch
56 result = subprocess.run( 1adebfgch
57 [sys.executable, "-m", "coverage", "run", mod.__file__, "--help"],
58 capture_output=True,
59 encoding="utf-8",
60 )
61 assert "Usage" in result.stdout 1adebfgch