This is a internal utils package used across the contrib packages. No guarantees are given to uses outside of open-telemetry/opentelemetry-js-contrib repository.
Compatible with OpenTelemetry JS API and SDK 1.0+
.
This package exports a mocha root hook plugin, which implements common boilerplate code a developer probably needs for writing instrumentation unit tests in node.
This package:
- Initializes and registers a global trace provider for tests.
- Registers a global memory exporter which can be referenced in test to access span.
- Make sure there is only a single instance of an instrumentation class that is used across different
.spec.ts
files so patching is consistent, deterministic and idiomatic. - Reset the memory exporter before each test, so spans do not leak from one test to another.
- Optionally - export the test traces to Jaeger for convenience while debugging and developing.
By using this package, testing instrumentation code can be shorter, and good practices for writing tests are more easily applied.
Since root hook plugin are used, this package is compatible to mocha v8.0.0 and above.
- Add dev dependency on this package:
npm install @opentelemetry/test-utils --save-dev
require
this package in mocha invocation:
As command line argument option to mocha:
"scripts": {
"test": "mocha --require @opentelemetry/test-utils",
"test:jaeger": "OTEL_EXPORTER_JAEGER_AGENT_HOST=localhost mocha --require @opentelemetry/test-utils",
},
``
Or by using config file / package.json config:
```js
"mocha": {
"require": [ "@opentelemetry/test-utils" ]
}
- In your
.spec
file, importregisterInstrumentationTesting
andgetTestSpans
functions and use them to create instrumentation class instance and make assertions in the test:
import { getTestSpans, registerInstrumentationTesting } from '@opentelemetry/test-utils';
const instrumentation = registerInstrumentationTesting(new MyAwesomeInstrumentation());
it('some test', () => {
// your code that generate spans for this test
const spans: ReadableSpan[] = getTestSpans();
// your code doing assertions with the spans array
});
That's it - supper short and easy.
- For more information on OpenTelemetry, visit: https://opentelemetry.io/
- For more about OpenTelemetry JavaScript: https://github.com/open-telemetry/opentelemetry-js
- For help or feedback on this project, join us in GitHub Discussions
Apache 2.0 - See LICENSE for more information.