|
6 | 6 | import pytest |
7 | 7 | from escalite.escalite import Escalite |
8 | 8 | from escalite.utils.constants import ALERT_ID |
| 9 | +from contextlib import nullcontext as does_not_raise |
9 | 10 |
|
10 | 11 |
|
11 | 12 | class TestEscalite: |
@@ -66,33 +67,87 @@ def test_add_to_log(self): |
66 | 67 | assert entry["message"] == "Test message" |
67 | 68 | assert logs["log_level"] == "info" |
68 | 69 |
|
69 | | - def test_set_log_level(self): |
| 70 | + def test_add_to_log_raises_error_if_not_started(self): |
| 71 | + from escalite.escalite import _request_logs |
| 72 | + |
| 73 | + _request_logs.set(None) |
| 74 | + with pytest.raises(RuntimeError): |
| 75 | + Escalite.add_to_log("test_key", "test_value") |
| 76 | + |
| 77 | + def test_update_log_level(self): |
70 | 78 | Escalite.start_logging() |
71 | | - Escalite.set_log_level("debug", force=True) |
| 79 | + Escalite.update_log_level("debug", force=True) |
72 | 80 | assert Escalite.get_log_level() == "debug" |
73 | 81 |
|
74 | | - Escalite.set_log_level("error", tag="api_logs") |
| 82 | + Escalite.update_log_level("error", tag="api_logs") |
75 | 83 | assert Escalite.get_log_level(tag="api_logs") == "error" |
76 | 84 |
|
77 | 85 | Escalite.end_logging() |
78 | 86 |
|
79 | | - def test_set_log_level_does_not_change_if_a_downgrade(self): |
| 87 | + def test_update_log_level_does_not_change_if_no_logging_started(self): |
| 88 | + from escalite.escalite import _request_logs |
| 89 | + |
| 90 | + _request_logs.set(None) |
| 91 | + Escalite.update_log_level("debug") |
| 92 | + # Should remain 'info' since no logging has started |
| 93 | + assert Escalite.get_log_level() == "info" |
| 94 | + |
| 95 | + def test_update_log_level_does_not_change_if_a_downgrade(self): |
80 | 96 | Escalite.start_logging() |
81 | | - Escalite.set_log_level("debug") |
| 97 | + Escalite.update_log_level("debug") |
82 | 98 | # Should remain 'info' since 'debug' is a lower level and force is False |
83 | 99 | assert Escalite.get_log_level() == "info" |
84 | 100 |
|
85 | | - def test_set_log_level_updates_if_force(self): |
| 101 | + def test_update_log_level_updates_if_force(self): |
86 | 102 | Escalite.start_logging() |
87 | | - Escalite.set_log_level("debug", force=True) |
| 103 | + Escalite.update_log_level("debug", force=True) |
88 | 104 | assert Escalite.get_log_level() == "debug" |
89 | 105 |
|
90 | | - Escalite.set_log_level("critical") |
91 | | - Escalite.set_log_level("info", force=True) |
| 106 | + Escalite.update_log_level("critical") |
| 107 | + Escalite.update_log_level("info", force=True) |
| 108 | + assert Escalite.get_log_level() == "info" |
| 109 | + |
| 110 | + Escalite.end_logging() |
| 111 | + |
| 112 | + def test_get_log_level_returns_info_if_no_logs_are_set(self): |
| 113 | + from escalite.escalite import _request_logs |
| 114 | + |
| 115 | + _request_logs.set(None) |
92 | 116 | assert Escalite.get_log_level() == "info" |
93 | 117 |
|
| 118 | + def test_retrieves_log_by_key_when_key_exists(self): |
| 119 | + Escalite.start_logging() |
| 120 | + Escalite.add_to_log("key1", "value1") |
| 121 | + result = Escalite.get_log_by_key("key1") |
| 122 | + assert result["value"] == "value1" |
| 123 | + Escalite.end_logging() |
| 124 | + |
| 125 | + def test_retrieves_log_by_key_with_tag_when_key_exists(self): |
| 126 | + Escalite.start_logging() |
| 127 | + Escalite.add_to_log("key1", "value1", tag="API_LOGS") |
| 128 | + result = Escalite.get_log_by_key("key1", tag="API_LOGS") |
| 129 | + assert result["value"] == "value1" |
| 130 | + Escalite.end_logging() |
| 131 | + |
| 132 | + def test_returns_none_when_key_does_not_exist(self): |
| 133 | + Escalite.start_logging() |
| 134 | + result = Escalite.get_log_by_key("nonexistent_key") |
| 135 | + assert result is None |
| 136 | + Escalite.end_logging() |
| 137 | + |
| 138 | + def test_returns_none_when_key_does_not_exist_with_tag(self): |
| 139 | + Escalite.start_logging() |
| 140 | + result = Escalite.get_log_by_key("nonexistent_key", tag="API_LOGS") |
| 141 | + assert result is None |
94 | 142 | Escalite.end_logging() |
95 | 143 |
|
| 144 | + def test_does_not_raise_error_when_logging_not_started(self): |
| 145 | + from escalite.escalite import _request_logs |
| 146 | + |
| 147 | + _request_logs.set(None) |
| 148 | + with does_not_raise(): |
| 149 | + Escalite.get_log_by_key("key1") |
| 150 | + |
96 | 151 | def test_add_to_log_with_extras(self): |
97 | 152 | Escalite.start_logging() |
98 | 153 | Escalite.add_to_log( |
|
0 commit comments