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

1import subprocess 1abcdefg

2import sys 1abcdefg

3from unittest.mock import patch 1abcdefg

4 

5import typer 1abcdefg

6from typer.testing import CliRunner 1abcdefg

7 

8import docs_src.progressbar.tutorial001_py310 as mod 1abcdefg

9from tests.utils import normalize_rich_output 1abcdefg

10 

11app = mod.app 1abcdefg

12 

13runner = CliRunner() 1abcdefg

14 

15 

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

20 

21 # Replace all Rich formatting with `*` characters 

22 normalized_output = normalize_rich_output(result.output) 1abcdefg

23 

24 assert result.exit_code == 0 1abcdefg

25 assert "Processing... 0%" in normalized_output 1abcdefg

26 

27 

28def test_cli(): 1abcdefg

29 with patch("time.sleep") as mock_sleep: 1abcdefg

30 result = runner.invoke(app) 1abcdefg

31 

32 # Replace all Rich formatting with `*` characters 

33 normalized_output = normalize_rich_output(result.output) 1abcdefg

34 

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

40 

41 

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