npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@opentelemetry/contrib-test-utils

v0.45.0

Published

Test utilities for opentelemetry components

Downloads

21,475

Readme

Test Utils for OpenTelemetry contrib packages

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+.

Instrumentation Testing

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.

Supported Version

Since root hook plugin are used, this package is compatible to mocha v7.2.0 and above.

Usage

  1. Add dev dependency on this package:
npm install @opentelemetry/contrib-test-utils --save-dev
  1. require this package in mocha invocation:

As command line argument option to mocha:

    "scripts": {
        "test": "mocha --require @opentelemetry/contrib-test-utils",
        "test:jaeger": "OTEL_EXPORTER_JAEGER_AGENT_HOST=localhost mocha --require @opentelemetry/contrib-test-utils",
    },
``

Or by using config file / package.json config:
```js
    "mocha": {
        "require": [ "@opentelemetry/contrib-test-utils" ]
    }
  1. In your .spec file, import registerInstrumentationTesting and getTestSpans functions and use them to create instrumentation class instance and make assertions in the test:
import { getTestSpans, registerInstrumentationTesting } from '@opentelemetry/contrib-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.

Semantic Conventions

This package uses @opentelemetry/semantic-conventions version 1.22+, which implements Semantic Convention Version 1.7.0

Useful links

License

Apache 2.0 - See LICENSE for more information.