|
20 | 20 | from opentelemetry._logs import NoOpLoggerProvider, SeverityNumber |
21 | 21 | from opentelemetry._logs import get_logger as APIGetLogger |
22 | 22 | from opentelemetry.attributes import BoundedAttributes |
| 23 | +from opentelemetry.context.context import Context |
23 | 24 | from opentelemetry.sdk import trace |
24 | 25 | from opentelemetry.sdk._logs import ( |
25 | 26 | LogData, |
@@ -268,21 +269,33 @@ def __str__(self): |
268 | 269 |
|
269 | 270 | def test_log_record_trace_correlation(self): |
270 | 271 | processor, logger = set_up_test_logging(logging.WARNING) |
| 272 | + mock_context = Context() |
271 | 273 |
|
272 | 274 | tracer = trace.TracerProvider().get_tracer(__name__) |
273 | 275 | with tracer.start_as_current_span("test") as span: |
274 | | - with self.assertLogs(level=logging.CRITICAL): |
275 | | - logger.critical("Critical message within span") |
276 | | - |
277 | | - log_record = processor.get_log_record(0) |
278 | | - |
279 | | - self.assertEqual(log_record.body, "Critical message within span") |
280 | | - self.assertEqual(log_record.severity_text, "CRITICAL") |
281 | | - self.assertEqual(log_record.severity_number, SeverityNumber.FATAL) |
282 | | - span_context = span.get_span_context() |
283 | | - self.assertEqual(log_record.trace_id, span_context.trace_id) |
284 | | - self.assertEqual(log_record.span_id, span_context.span_id) |
285 | | - self.assertEqual(log_record.trace_flags, span_context.trace_flags) |
| 276 | + with patch( |
| 277 | + "opentelemetry.sdk._logs._internal.get_current", |
| 278 | + return_value=mock_context, |
| 279 | + ): |
| 280 | + with self.assertLogs(level=logging.CRITICAL): |
| 281 | + logger.critical("Critical message within span") |
| 282 | + |
| 283 | + log_record = processor.get_log_record(0) |
| 284 | + |
| 285 | + self.assertEqual( |
| 286 | + log_record.body, "Critical message within span" |
| 287 | + ) |
| 288 | + self.assertEqual(log_record.severity_text, "CRITICAL") |
| 289 | + self.assertEqual( |
| 290 | + log_record.severity_number, SeverityNumber.FATAL |
| 291 | + ) |
| 292 | + self.assertEqual(log_record.context, mock_context) |
| 293 | + span_context = span.get_span_context() |
| 294 | + self.assertEqual(log_record.trace_id, span_context.trace_id) |
| 295 | + self.assertEqual(log_record.span_id, span_context.span_id) |
| 296 | + self.assertEqual( |
| 297 | + log_record.trace_flags, span_context.trace_flags |
| 298 | + ) |
286 | 299 |
|
287 | 300 | def test_warning_without_formatter(self): |
288 | 301 | processor, logger = set_up_test_logging(logging.WARNING) |
|
0 commit comments