From bb95cf874c40077f26322cc4ac6987106352760b Mon Sep 17 00:00:00 2001 From: spalger Date: Thu, 27 Oct 2016 13:48:36 -0700 Subject: [PATCH] [es/versionCheck] prevent spamming logs with compatibility warnings --- .../lib/__tests__/check_es_version.js | 38 ++++++++++++++++++- .../elasticsearch/lib/check_es_version.js | 25 +++++++----- 2 files changed, 52 insertions(+), 11 deletions(-) diff --git a/src/core_plugins/elasticsearch/lib/__tests__/check_es_version.js b/src/core_plugins/elasticsearch/lib/__tests__/check_es_version.js index ffe96632d11b..5c57204e9595 100644 --- a/src/core_plugins/elasticsearch/lib/__tests__/check_es_version.js +++ b/src/core_plugins/elasticsearch/lib/__tests__/check_es_version.js @@ -17,7 +17,7 @@ describe('plugins/elasticsearch', () => { beforeEach(function () { server = { - log: _.noop, + log: sinon.stub(), // This is required or else we get a SetupError. config: () => ({ get: sinon.stub(), @@ -95,5 +95,41 @@ describe('plugins/elasticsearch', () => { expect(e).to.be.a(SetupError); } }); + + it('warns if a node is only off by a patch version', async () => { + setNodes('5.1.1'); + await checkEsVersion(server, KIBANA_VERSION); + sinon.assert.callCount(server.log, 2); + expect(server.log.getCall(0).args[0]).to.contain('debug'); + expect(server.log.getCall(1).args[0]).to.contain('warning'); + }); + + it('only warns once per node list', async () => { + setNodes('5.1.1'); + + await checkEsVersion(server, KIBANA_VERSION); + sinon.assert.callCount(server.log, 2); + expect(server.log.getCall(0).args[0]).to.contain('debug'); + expect(server.log.getCall(1).args[0]).to.contain('warning'); + + await checkEsVersion(server, KIBANA_VERSION); + sinon.assert.callCount(server.log, 3); + expect(server.log.getCall(2).args[0]).to.contain('debug'); + }); + + it('warns again if the node list changes', async () => { + setNodes('5.1.1'); + + await checkEsVersion(server, KIBANA_VERSION); + sinon.assert.callCount(server.log, 2); + expect(server.log.getCall(0).args[0]).to.contain('debug'); + expect(server.log.getCall(1).args[0]).to.contain('warning'); + + setNodes('5.1.2'); + await checkEsVersion(server, KIBANA_VERSION); + sinon.assert.callCount(server.log, 4); + expect(server.log.getCall(2).args[0]).to.contain('debug'); + expect(server.log.getCall(3).args[0]).to.contain('warning'); + }); }); }); diff --git a/src/core_plugins/elasticsearch/lib/check_es_version.js b/src/core_plugins/elasticsearch/lib/check_es_version.js index 66eb58f1b569..2fbe8886d48f 100644 --- a/src/core_plugins/elasticsearch/lib/check_es_version.js +++ b/src/core_plugins/elasticsearch/lib/check_es_version.js @@ -9,6 +9,8 @@ import semver from 'semver'; import isEsCompatibleWithKibana from './is_es_compatible_with_kibana'; import SetupError from './setup_error'; +const lastWarnedAboutNodes = new WeakMap(); + module.exports = function checkEsVersion(server, kibanaVersion) { server.log(['plugin', 'debug'], 'Checking Elasticsearch version'); @@ -50,16 +52,19 @@ module.exports = function checkEsVersion(server, kibanaVersion) { ip: node.ip, })); - server.log(['warning'], { - tmpl: ( - 'You\'re running Kibana <%= kibanaVersion %> with some newer versions of ' + - 'Elasticsearch. Update Kibana to the latest version to prevent compatibility issues: ' + - '<%= getHumanizedNodeNames(nodes).join(", ") %>' - ), - kibanaVersion, - getHumanizedNodeNames, - nodes: simplifiedNodes, - }); + const warningNodeNames = getHumanizedNodeNames(simplifiedNodes).join(', '); + if (lastWarnedAboutNodes.get(server) !== warningNodeNames) { + lastWarnedAboutNodes.set(server, warningNodeNames); + server.log(['warning'], { + tmpl: ( + `You're running Kibana ${kibanaVersion} with some newer versions of ` + + 'Elasticsearch. Update Kibana to the latest version to prevent compatibility issues: ' + + warningNodeNames + ), + kibanaVersion, + nodes: simplifiedNodes, + }); + } } if (incompatibleNodes.length) {