From 9d404bc2b0dd06cb9831e7e37e453c5036b1419d Mon Sep 17 00:00:00 2001 From: chris48s Date: Fri, 12 Mar 2021 19:38:11 +0000 Subject: [PATCH] use got to push influx metrics (#6257) --- core/server/influx-metrics.js | 18 +++++++----------- core/server/influx-metrics.spec.js | 2 +- 2 files changed, 8 insertions(+), 12 deletions(-) diff --git a/core/server/influx-metrics.js b/core/server/influx-metrics.js index 62240fc86fa08..2d87cc56d5af9 100644 --- a/core/server/influx-metrics.js +++ b/core/server/influx-metrics.js @@ -1,8 +1,6 @@ 'use strict' const os = require('os') -const { promisify } = require('util') -const { post } = require('request') -const postAsync = promisify(post) +const got = require('got') const generateInstanceId = require('./instance-id-generator') const { promClientJsonToInfluxV2 } = require('./metrics/format-converters') const log = require('./log') @@ -15,21 +13,19 @@ module.exports = class InfluxMetrics { } async sendMetrics() { - const auth = { - user: this._config.username, - pass: this._config.password, - } const request = { - uri: this._config.url, + url: this._config.url, headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, body: await this.metrics(), timeout: this._config.timeoutMillseconds, - auth, + username: this._config.username, + password: this._config.password, + throwHttpErrors: false, } let response try { - response = await postAsync(request) + response = await got.post(request) } catch (error) { log.error( new Error(`Cannot push metrics. Cause: ${error.name}: ${error.message}`) @@ -38,7 +34,7 @@ module.exports = class InfluxMetrics { if (response && response.statusCode >= 300) { log.error( new Error( - `Cannot push metrics. ${response.request.href} responded with status code ${response.statusCode}` + `Cannot push metrics. ${request.url} responded with status code ${response.statusCode}` ) ) } diff --git a/core/server/influx-metrics.spec.js b/core/server/influx-metrics.spec.js index 4972cdd3ad376..4b91b055230bc 100644 --- a/core/server/influx-metrics.spec.js +++ b/core/server/influx-metrics.spec.js @@ -150,7 +150,7 @@ describe('Influx metrics', function () { .and( sinon.match.has( 'message', - 'Cannot push metrics. Cause: NetConnectNotAllowedError: Nock: Disallowed net connect for "shields-metrics.io:80/metrics"' + 'Cannot push metrics. Cause: RequestError: Nock: Disallowed net connect for "shields-metrics.io:80/metrics"' ) ) )