|
30 | 30 | ) |
31 | 31 | from opentelemetry.semconv._incubating.attributes import code_attributes |
32 | 32 | from opentelemetry.semconv.attributes import exception_attributes |
33 | | -from opentelemetry.trace import INVALID_SPAN_CONTEXT |
| 33 | +from opentelemetry.trace import ( |
| 34 | + INVALID_SPAN_CONTEXT, |
| 35 | + set_span_in_context, |
| 36 | +) |
34 | 37 |
|
35 | 38 |
|
36 | 39 | class TestLoggingHandler(unittest.TestCase): |
@@ -92,19 +95,26 @@ def test_log_flush_noop(self): |
92 | 95 |
|
93 | 96 | def test_log_record_no_span_context(self): |
94 | 97 | processor, logger = set_up_test_logging(logging.WARNING) |
| 98 | + mock_context = Context() |
95 | 99 |
|
96 | | - # Assert emit gets called for warning message |
97 | | - with self.assertLogs(level=logging.WARNING): |
98 | | - logger.warning("Warning message") |
| 100 | + with patch( |
| 101 | + "opentelemetry.sdk._logs._internal.get_current", |
| 102 | + return_value=mock_context, |
| 103 | + ): |
| 104 | + # Assert emit gets called for warning message |
| 105 | + with self.assertLogs(level=logging.WARNING): |
| 106 | + logger.warning("Warning message") |
99 | 107 |
|
100 | | - log_record = processor.get_log_record(0) |
| 108 | + log_record = processor.get_log_record(0) |
101 | 109 |
|
102 | | - self.assertIsNotNone(log_record) |
103 | | - self.assertEqual(log_record.trace_id, INVALID_SPAN_CONTEXT.trace_id) |
104 | | - self.assertEqual(log_record.span_id, INVALID_SPAN_CONTEXT.span_id) |
105 | | - self.assertEqual( |
106 | | - log_record.trace_flags, INVALID_SPAN_CONTEXT.trace_flags |
107 | | - ) |
| 110 | + self.assertIsNotNone(log_record) |
| 111 | + self.assertEqual( |
| 112 | + log_record.trace_id, INVALID_SPAN_CONTEXT.trace_id |
| 113 | + ) |
| 114 | + self.assertEqual(log_record.span_id, INVALID_SPAN_CONTEXT.span_id) |
| 115 | + self.assertEqual( |
| 116 | + log_record.trace_flags, INVALID_SPAN_CONTEXT.trace_flags |
| 117 | + ) |
108 | 118 |
|
109 | 119 | def test_log_record_observed_timestamp(self): |
110 | 120 | processor, logger = set_up_test_logging(logging.WARNING) |
@@ -269,7 +279,38 @@ def __str__(self): |
269 | 279 |
|
270 | 280 | def test_log_record_trace_correlation(self): |
271 | 281 | processor, logger = set_up_test_logging(logging.WARNING) |
272 | | - mock_context = Context() |
| 282 | + |
| 283 | + tracer = trace.TracerProvider().get_tracer(__name__) |
| 284 | + with tracer.start_as_current_span("test") as span: |
| 285 | + mock_context = set_span_in_context(span) |
| 286 | + |
| 287 | + with patch( |
| 288 | + "opentelemetry.sdk._logs._internal.get_current", |
| 289 | + return_value=mock_context, |
| 290 | + ): |
| 291 | + with self.assertLogs(level=logging.CRITICAL): |
| 292 | + logger.critical("Critical message within span") |
| 293 | + |
| 294 | + log_record = processor.get_log_record(0) |
| 295 | + |
| 296 | + self.assertEqual( |
| 297 | + log_record.body, "Critical message within span" |
| 298 | + ) |
| 299 | + self.assertEqual(log_record.severity_text, "CRITICAL") |
| 300 | + self.assertEqual( |
| 301 | + log_record.severity_number, SeverityNumber.FATAL |
| 302 | + ) |
| 303 | + self.assertEqual(log_record.context, mock_context) |
| 304 | + span_context = span.get_span_context() |
| 305 | + self.assertEqual(log_record.trace_id, span_context.trace_id) |
| 306 | + self.assertEqual(log_record.span_id, span_context.span_id) |
| 307 | + self.assertEqual( |
| 308 | + log_record.trace_flags, span_context.trace_flags |
| 309 | + ) |
| 310 | + |
| 311 | + def test_log_record_trace_correlation_backwards_compatibility(self): |
| 312 | + processor, logger = set_up_test_logging(logging.WARNING) |
| 313 | + mock_context = Context() # no span in context |
273 | 314 |
|
274 | 315 | tracer = trace.TracerProvider().get_tracer(__name__) |
275 | 316 | with tracer.start_as_current_span("test") as span: |
|
0 commit comments