From 7e2d65d142de151b9e70b62f86e043431d2d8bc2 Mon Sep 17 00:00:00 2001 From: Franck M Date: Sat, 31 Dec 2022 15:57:08 +0100 Subject: [PATCH] Fix incompatibility with perf_hooks accross nodejs versions (#515) --- CHANGELOG.md | 2 ++ lib/metrics/gc.js | 11 +++++++---- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a48e0e91..40de2fa5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,6 +11,8 @@ project adheres to [Semantic Versioning](http://semver.org/). ### Changed +- Increase compatibility with external build system such as `rollup` by making perf_hooks optional in gc.js + ### Added ## [14.1.0] - 2022-08-23 diff --git a/lib/metrics/gc.js b/lib/metrics/gc.js index 75b8f4bc..0d2e2839 100644 --- a/lib/metrics/gc.js +++ b/lib/metrics/gc.js @@ -14,10 +14,13 @@ const NODEJS_GC_DURATION_SECONDS = 'nodejs_gc_duration_seconds'; const DEFAULT_GC_DURATION_BUCKETS = [0.001, 0.01, 0.1, 1, 2, 5]; const kinds = []; -kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_MAJOR] = 'major'; -kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_MINOR] = 'minor'; -kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_INCREMENTAL] = 'incremental'; -kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_WEAKCB] = 'weakcb'; + +if (perf_hooks && perf_hooks.constants) { + kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_MAJOR] = 'major'; + kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_MINOR] = 'minor'; + kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_INCREMENTAL] = 'incremental'; + kinds[perf_hooks.constants.NODE_PERFORMANCE_GC_WEAKCB] = 'weakcb'; +} module.exports = (registry, config = {}) => { if (!perf_hooks) {