Skip to content

Latest commit

 

History

History
60 lines (39 loc) · 2.43 KB

README.md

File metadata and controls

60 lines (39 loc) · 2.43 KB

Testbed suite for the OpenTracing API

Testbed suite designed to test API changes.

Build and test.

make testbed

Depending on whether Python 2 or 3 is being used, the asyncio tests will be automatically disabled.

Alternatively, due to the organization of the suite, it's possible to run directly the tests using py.test:

    py.test -s testbed/test_multiple_callbacks/test_threads.py

Tested frameworks

Currently the examples cover threading, tornado, gevent and asyncio (which requires Python 3). Each example uses their respective ScopeManager instance from opentracing.scope_managers, along with their related requirements and limitations.

threading, asyncio and gevent

No automatic Span propagation between parent and children tasks is provided, and thus the Span need to be manually passed down the chain.

tornado

TornadoScopeManager uses a variation of tornado.stack_context.StackContext to both store and automatically propagate the context from parent coroutines to their children.

Currently, yielding over multiple children is not supported, as the context is effectively shared, and switching from coroutine to coroutine messes up the current active Span.

List of patterns

Adding new patterns

A new pattern is composed of a directory under testbed with the test_ prefix, and containing the files for each platform, also with the test_ prefix:

testbed/
  test_new_pattern/
    test_threads.py
    test_tornado.py
    test_asyncio.py
    test_gevent.py

Supporting all the platforms is optional, and a warning will be displayed when doing make testbed in such case.

Flake8 support

Currently flake8 does not support the Python 3 await/async syntax, and does not offer a way to ignore such syntax.