|
1 | 1 | import logging |
2 | 2 | import pytest |
| 3 | +import mock |
3 | 4 |
|
4 | | -from google.api_core.client_logging import setup_logging |
| 5 | +from google.api_core.client_logging import ( |
| 6 | + setup_logging, |
| 7 | + parse_logging_scopes, |
| 8 | + initialize_logging, |
| 9 | +) |
5 | 10 |
|
6 | | -# TODO: We should not be testing against the "google" logger |
7 | | -# and should mock `base_logger` instead. |
8 | 11 |
|
9 | 12 | def reset_logger(scope): |
10 | 13 | logger = logging.getLogger(scope) |
11 | 14 | logger.handlers = [] |
12 | 15 | logger.setLevel(logging.NOTSET) |
13 | 16 | logger.propagate = True |
14 | | - |
| 17 | + |
| 18 | + |
15 | 19 | def test_setup_logging_w_no_scopes(): |
16 | | - setup_logging() |
17 | | - base_logger = logging.getLogger("google") |
18 | | - assert base_logger.handlers == [] |
19 | | - assert base_logger.propagate == False |
20 | | - assert base_logger.level == logging.NOTSET |
| 20 | + with mock.patch("google.api_core.client_logging._BASE_LOGGER_NAME", "foo"): |
| 21 | + setup_logging() |
| 22 | + base_logger = logging.getLogger("foo") |
| 23 | + assert base_logger.handlers == [] |
| 24 | + assert base_logger.propagate == False |
| 25 | + assert base_logger.level == logging.NOTSET |
21 | 26 |
|
22 | 27 | reset_logger("google") |
23 | 28 |
|
24 | 29 |
|
25 | 30 | def test_setup_logging_w_base_scope(): |
26 | | - setup_logging("google") |
27 | | - base_logger = logging.getLogger("google") |
| 31 | + with mock.patch("google.api_core.client_logging._BASE_LOGGER_NAME", "foo"): |
| 32 | + setup_logging("foo") |
| 33 | + base_logger = logging.getLogger("foo") |
28 | 34 | assert isinstance(base_logger.handlers[0], logging.StreamHandler) |
29 | 35 | assert base_logger.propagate == False |
30 | 36 | assert base_logger.level == logging.DEBUG |
31 | 37 |
|
32 | 38 | reset_logger("google") |
33 | 39 |
|
| 40 | + |
34 | 41 | def test_setup_logging_w_module_scope(): |
35 | | - setup_logging("google.foo") |
36 | | - |
37 | | - base_logger = logging.getLogger("google") |
| 42 | + with mock.patch("google.api_core.client_logging._BASE_LOGGER_NAME", "foo"): |
| 43 | + setup_logging("foo.bar") |
| 44 | + |
| 45 | + base_logger = logging.getLogger("foo") |
38 | 46 | assert base_logger.handlers == [] |
39 | 47 | assert base_logger.propagate == False |
40 | 48 | assert base_logger.level == logging.NOTSET |
41 | 49 |
|
42 | | - module_logger = logging.getLogger("google.foo") |
| 50 | + module_logger = logging.getLogger("foo.bar") |
43 | 51 | assert isinstance(module_logger.handlers[0], logging.StreamHandler) |
44 | 52 | assert module_logger.propagate == False |
45 | 53 | assert module_logger.level == logging.DEBUG |
46 | 54 |
|
47 | | - |
48 | 55 | reset_logger("google") |
49 | 56 | reset_logger("google.foo") |
50 | 57 |
|
| 58 | + |
51 | 59 | def test_setup_logging_w_incorrect_scope(): |
52 | | - setup_logging("foo") |
53 | | - |
54 | | - base_logger = logging.getLogger("google") |
| 60 | + with mock.patch("google.api_core.client_logging._BASE_LOGGER_NAME", "foo"): |
| 61 | + setup_logging("abc") |
| 62 | + |
| 63 | + base_logger = logging.getLogger("foo") |
55 | 64 | assert base_logger.handlers == [] |
56 | 65 | assert base_logger.propagate == False |
57 | 66 | assert base_logger.level == logging.NOTSET |
58 | 67 |
|
59 | 68 | # TODO(https://github.com/googleapis/python-api-core/issues/759): update test once we add logic to ignore an incorrect scope. |
60 | | - logger = logging.getLogger("foo") |
| 69 | + logger = logging.getLogger("abc") |
61 | 70 | assert isinstance(logger.handlers[0], logging.StreamHandler) |
62 | 71 | assert logger.propagate == False |
63 | 72 | assert logger.level == logging.DEBUG |
64 | 73 |
|
65 | 74 | reset_logger("google") |
66 | 75 | reset_logger("foo") |
| 76 | + |
| 77 | + |
| 78 | +def test_initialize_logging(): |
| 79 | + |
| 80 | + with mock.patch("os.getenv", return_value="foo.bar"): |
| 81 | + with mock.patch("google.api_core.client_logging._BASE_LOGGER_NAME", "foo"): |
| 82 | + initialize_logging() |
| 83 | + |
| 84 | + base_logger = logging.getLogger("foo") |
| 85 | + assert base_logger.handlers == [] |
| 86 | + assert base_logger.propagate == False |
| 87 | + assert base_logger.level == logging.NOTSET |
| 88 | + |
| 89 | + module_logger = logging.getLogger("foo.bar") |
| 90 | + assert isinstance(module_logger.handlers[0], logging.StreamHandler) |
| 91 | + assert module_logger.propagate == False |
| 92 | + assert module_logger.level == logging.DEBUG |
| 93 | + |
| 94 | + reset_logger("google") |
| 95 | + reset_logger("google.foo") |
0 commit comments