From 2a82b8be9425585b1ab5d82e296a88f63fd4da33 Mon Sep 17 00:00:00 2001 From: Stephen Belanger Date: Tue, 4 Jun 2019 18:47:07 -0700 Subject: [PATCH] feat: allow manual instrumentation with instrument: false Fixes #858 --- docs/configuration.asciidoc | 2 +- lib/instrumentation/index.js | 4 +--- test/_mock_http_client.js | 2 +- test/config.js | 22 ++++++++++++++++++++++ 4 files changed, 25 insertions(+), 5 deletions(-) diff --git a/docs/configuration.asciidoc b/docs/configuration.asciidoc index 9cd5001fcb1..1472db9f029 100644 --- a/docs/configuration.asciidoc +++ b/docs/configuration.asciidoc @@ -117,7 +117,7 @@ You must use the query bar to filter for a specific environment in versions prio * *Default:* `true` * *Env:* `ELASTIC_APM_INSTRUMENT` -A boolean specifying if the agent should collect performance metrics for the app. +A boolean specifying if the agent should automatically apply instrumentation to supported modules when they are loaded. Note that both `active` and `instrument` needs to be `true` for instrumentation to be running. diff --git a/lib/instrumentation/index.js b/lib/instrumentation/index.js index acbe95aa1dc..63d05fbb728 100644 --- a/lib/instrumentation/index.js +++ b/lib/instrumentation/index.js @@ -104,9 +104,7 @@ Instrumentation.prototype.clearPatches = function (name) { Instrumentation.modules = Object.freeze(MODULES) Instrumentation.prototype.start = function () { - if (!this._agent._conf.instrument) return if (this._started) return - this._started = true if (this._agent._conf.asyncHooks && semver.gte(process.version, '8.2.0')) { @@ -138,7 +136,7 @@ Instrumentation.prototype._startHook = function () { this._agent.logger.debug('adding hook to Node.js module loader') this._hook = hook(this._patches.keys, function (exports, name, basedir) { - var enabled = !disabled.has(name) + var enabled = self._agent._conf.instrument && !disabled.has(name) var pkg, version if (basedir) { diff --git a/test/_mock_http_client.js b/test/_mock_http_client.js index 77a5a56ea9f..3366549942f 100644 --- a/test/_mock_http_client.js +++ b/test/_mock_http_client.js @@ -50,7 +50,7 @@ module.exports = function (expected, done) { if (timer) clearTimeout(timer) timer = setTimeout(function () { done(client._writes) - }, 100) + }, 200) } } diff --git a/test/config.js b/test/config.js index 603d9a49b1c..52764e0ec74 100644 --- a/test/config.js +++ b/test/config.js @@ -790,6 +790,28 @@ test('globalLabels should be received by transport', function (t) { }) }) +test('instrument: false allows manual instrumentation', function (t) { + var trans + var opts = { + metricsInterval: 0, + instrument: false + } + + var server = APMServer(opts, { expect: 'transaction' }) + .on('listening', function () { + trans = this.agent.startTransaction('trans') + trans.end() + }) + .on('data-transaction', (data) => { + assertEncodedTransaction(t, trans, data) + t.end() + }) + + t.on('end', function () { + server.destroy() + }) +}) + function assertEncodedTransaction (t, trans, result) { t.comment('transaction') t.equal(result.id, trans.id, 'id matches')