Describe your environment
Resource Detector only get 5 seconds by default to run. However, instead of ending the process after 5 seconds, a blank "Exception()" is creating resulting in the follow warning:
Exception in detector <opentelemetry.resource.detector.<RESOURCE DETECTOR CLASS> object at 0x000002B955D43D60>, ignoring
Note that the Exception string is blank resulting in 2 whitespaces: Exception__in...
This blank exception is causing confusion among Azure customers. And perhaps more importantly, the process still hangs.
Steps to reproduce
- Create a resource detector that sleeps for more than 5 seconds (try 10-20):
from opentelemetry.sdk.resources import Resource, ResourceDetector
from time import sleep
class SleepingResourceDetector(ResourceDetector):
# pylint: disable=no-self-use
def detect(self) -> "Resource":
sleep(20)
attributes = {}
return Resource(attributes)
- Set resource detector entry point in pyproject.toml
[project.entry-points.opentelemetry_resource_detector]
sleeping = "opentelemetry.resource.detector.sleeping:SleepingResourceDetector"
- Install package to install entry point
- Point sdk to resource detector:
export OTEL_EXPERIMENTAL_RESOURCE_DETECTORS=sleeping
- Create a Resource:
Resource.create() This will eventually call get_aggregated_resources
What is the expected behavior?
The "concurrent future" setup should gracefully exit the process and not print out a confusing blank warning.
What is the actual behavior?
Process hangs and confusing warning message with blank error.
Additional context
Add any other context about the problem here.
Describe your environment
Resource Detector only get 5 seconds by default to run. However, instead of ending the process after 5 seconds, a blank "Exception()" is creating resulting in the follow warning:
Exception in detector <opentelemetry.resource.detector.<RESOURCE DETECTOR CLASS> object at 0x000002B955D43D60>, ignoringNote that the Exception string is blank resulting in 2 whitespaces:
Exception__in...This blank exception is causing confusion among Azure customers. And perhaps more importantly, the process still hangs.
Steps to reproduce
export OTEL_EXPERIMENTAL_RESOURCE_DETECTORS=sleepingResource.create()This will eventually call get_aggregated_resourcesWhat is the expected behavior?
The "concurrent future" setup should gracefully exit the process and not print out a confusing blank warning.
What is the actual behavior?
Process hangs and confusing warning message with blank error.
Additional context
Add any other context about the problem here.