|
5 | 5 |
|
6 | 6 |
|
7 | 7 | class TestUtils: |
8 | | - def test_update_extension_header_no_initial_headers(self): |
9 | | - extensions = ['test_extension_1', 'test_extension_2'] |
10 | | - |
11 | | - http_kwargs = {} |
12 | | - result_kwargs = update_extension_header(http_kwargs, extensions) |
13 | | - header_value = result_kwargs['headers'][HTTP_EXTENSION_HEADER] |
14 | | - actual_extensions_list = [e.strip() for e in header_value.split(',')] |
15 | | - actual_extensions = set(actual_extensions_list) |
16 | | - |
17 | | - expected_extensions = { |
18 | | - 'test_extension_1', |
19 | | - 'test_extension_2', |
20 | | - } |
21 | | - assert len(actual_extensions_list) == 2 |
22 | | - assert actual_extensions == expected_extensions |
23 | | - |
24 | 8 | @pytest.mark.parametrize( |
25 | | - 'existing_header, expected_count', |
| 9 | + 'extensions, existing_header, expected_extensions, expected_count', |
26 | 10 | [ |
27 | | - ('test_extension_1, test_extension_2', 3), |
28 | | - ('test_extension_1,test_extension_2', 3), |
29 | | - ('test_extension_1', 3), |
| 11 | + ( |
| 12 | + ['test_extension_1', 'test_extension_2'], |
| 13 | + '', |
| 14 | + { |
| 15 | + 'test_extension_1', |
| 16 | + 'test_extension_2', |
| 17 | + }, |
| 18 | + 2, |
| 19 | + ), |
| 20 | + ( |
| 21 | + ['test_extension_1', 'test_extension_2'], |
| 22 | + 'test_extension_2, test_extension_3', |
| 23 | + { |
| 24 | + 'test_extension_1', |
| 25 | + 'test_extension_2', |
| 26 | + 'test_extension_3', |
| 27 | + }, |
| 28 | + 3, |
| 29 | + ), |
| 30 | + ( |
| 31 | + ['test_extension_1', 'test_extension_2'], |
| 32 | + 'test_extension_3', |
| 33 | + { |
| 34 | + 'test_extension_1', |
| 35 | + 'test_extension_2', |
| 36 | + 'test_extension_3', |
| 37 | + }, |
| 38 | + 3, |
| 39 | + ), |
30 | 40 | ], |
31 | 41 | ) |
32 | 42 | def test_update_extension_header_merge_with_existing_extensions( |
33 | 43 | self, |
| 44 | + extensions: list[str], |
34 | 45 | existing_header: str, |
| 46 | + expected_extensions: set[str], |
35 | 47 | expected_count: int, |
36 | 48 | ): |
37 | | - extensions = ['test_extension_2', 'test_extension_3'] |
38 | 49 | http_kwargs = {'headers': {HTTP_EXTENSION_HEADER: existing_header}} |
39 | 50 | result_kwargs = update_extension_header(http_kwargs, extensions) |
40 | 51 |
|
41 | 52 | header_value = result_kwargs['headers'][HTTP_EXTENSION_HEADER] |
42 | 53 | actual_extensions_list = [e.strip() for e in header_value.split(',')] |
43 | 54 | actual_extensions = set(actual_extensions_list) |
44 | 55 |
|
45 | | - expected_extensions = { |
46 | | - 'test_extension_1', |
47 | | - 'test_extension_2', |
48 | | - 'test_extension_3', |
49 | | - } |
50 | 56 | assert len(actual_extensions_list) == expected_count |
51 | 57 | assert actual_extensions == expected_extensions |
52 | 58 |
|
53 | 59 | def test_update_extension_header_with_other_headers(self): |
54 | | - extensions = ['test_extension_1'] |
| 60 | + extensions = ['test_extension'] |
55 | 61 | http_kwargs = {'headers': {'X_Other': 'Test'}} |
56 | 62 | result_kwargs = update_extension_header(http_kwargs, extensions) |
57 | 63 | headers = result_kwargs.get('headers', {}) |
58 | 64 | assert HTTP_EXTENSION_HEADER in headers |
59 | | - assert headers[HTTP_EXTENSION_HEADER] == 'test_extension_1' |
| 65 | + assert headers[HTTP_EXTENSION_HEADER] == 'test_extension' |
60 | 66 | assert headers['X_Other'] == 'Test' |
61 | 67 |
|
62 | | - def test_update_extension_header_with_existing_other_headers(self): |
63 | | - extensions = ['test_extension_1'] |
64 | | - http_kwargs = {'headers': {'X_Other': 'Test'}} |
65 | | - result_kwargs = update_extension_header(http_kwargs, extensions) |
66 | | - assert ( |
67 | | - result_kwargs['headers'][HTTP_EXTENSION_HEADER] |
68 | | - == 'test_extension_1' |
69 | | - ) |
70 | | - assert result_kwargs['headers']['X_Other'] == 'Test' |
71 | | - |
72 | 68 | def test_update_extension_header_no_extensions(self): |
73 | 69 | http_kwargs = {'headers': {'X_Other': 'Test'}} |
74 | 70 | result_kwargs = update_extension_header(http_kwargs, None) |
|
0 commit comments