Skip to content

Commit

Permalink
refactor(exporter-prometheus): promisify prometheus tests
Browse files Browse the repository at this point in the history
  • Loading branch information
legendecas committed Jan 19, 2024
1 parent 43e598e commit 369f429
Show file tree
Hide file tree
Showing 4 changed files with 158 additions and 254 deletions.
8 changes: 4 additions & 4 deletions doc/metrics.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ const {
getNodeAutoInstrumentations,
} = require("@opentelemetry/auto-instrumentations-node");

const prometheusExporter = new PrometheusExporter({ startServer: true });
const prometheusExporter = new PrometheusExporter();

const sdk = new opentelemetry.NodeSDK({
// Optional - If omitted, the metrics SDK will not be initialized
Expand Down Expand Up @@ -147,7 +147,7 @@ const {
getNodeAutoInstrumentations,
} = require("@opentelemetry/auto-instrumentations-node");

const prometheusExporter = new PrometheusExporter({ startServer: true });
const prometheusExporter = new PrometheusExporter();

const sdk = new opentelemetry.NodeSDK({
// Optional - If omitted, the metrics SDK will not be initialized
Expand Down Expand Up @@ -499,8 +499,8 @@ to use the Prometheus exporter `PrometheusExporter` which is included in the
const { PrometheusExporter } = require('@opentelemetry/exporter-prometheus');
const { MeterProvider } = require('@opentelemetry/sdk-metrics');

// Add your port and startServer to the Prometheus options
const options = { port: 9464, startServer: true };
// Add your port to the Prometheus options
const options = { port: 9464 };
const exporter = new PrometheusExporter(options);

// Creates MeterProvider and installs the exporter as a MetricReader
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export class PrometheusExporter extends MetricReader {
private readonly _prefix?: string;
private readonly _appendTimestamp: boolean;
private _serializer: PrometheusSerializer;
private _startServerPromise: Promise<void> | undefined;

// This will be required when histogram is implemented. Leaving here so it is not forgotten
// Histogram cannot have a attribute named 'le'
Expand Down Expand Up @@ -95,7 +96,8 @@ export class PrometheusExporter extends MetricReader {
callback(err);
});
} else if (callback) {
callback();
// Do not invoke callback immediately to avoid zalgo problem.
queueMicrotask(callback);
}
}

Expand Down Expand Up @@ -142,7 +144,7 @@ export class PrometheusExporter extends MetricReader {
* Starts the Prometheus export server
*/
startServer(): Promise<void> {
return new Promise((resolve, reject) => {
this._startServerPromise ??= new Promise((resolve, reject) => {
this._server.once('error', reject);
this._server.listen(
{
Expand All @@ -157,6 +159,8 @@ export class PrometheusExporter extends MetricReader {
}
);
});

return this._startServerPromise;
}

/**
Expand Down
Loading

0 comments on commit 369f429

Please sign in to comment.