diff --git a/api/lib/opentelemetry/context.rb b/api/lib/opentelemetry/context.rb index 42f12d3d7d..185cad310c 100644 --- a/api/lib/opentelemetry/context.rb +++ b/api/lib/opentelemetry/context.rb @@ -28,8 +28,8 @@ def create_key(name) # Returns current context, which is never nil # # @return [Context] - def current - stack.last || ROOT + def current(thread = nil) + stack(thread).last || ROOT end # Associates a Context with the caller's current Fiber. Every call to @@ -123,8 +123,8 @@ def empty private - def stack - Thread.current[STACK_KEY] ||= [] + def stack(thread = nil) + (thread || Thread.current)[STACK_KEY] ||= [] end end diff --git a/api/test/opentelemetry/context_test.rb b/api/test/opentelemetry/context_test.rb index a25bf2281a..965d015e5b 100644 --- a/api/test/opentelemetry/context_test.rb +++ b/api/test/opentelemetry/context_test.rb @@ -333,5 +333,25 @@ _(Context.current[bar_key]).must_be_nil end end + + it 'allows accessing the current context for another thread' do + another_thread_context = Queue.new + + another_thread = Thread.new do + ctx = Context.empty.set_value(foo_key, 'bar') + Context.with_current(ctx) do + another_thread_context << Context.current + sleep + end + end + + ctx = another_thread_context.pop + + _(Context.current(another_thread)).must_equal(ctx) + _(Context.current).wont_equal(ctx) + + another_thread.kill + another_thread.join + end end end