From 9e8722039e95e3755ee5a2969ec7c72004b25573 Mon Sep 17 00:00:00 2001 From: Rudolf Meijering Date: Wed, 26 Jan 2022 12:48:29 +0100 Subject: [PATCH] Log deprecations originating from Kibana on debug level (#123660) (#123799) * Log deprecations originating from Kibana on debug level * Surface debug level deprecation logs on CI * Review feedback (cherry picked from commit c64c7664449b959dbd2361aaea4e44a4a0cf2d5a) --- .../client/log_query_and_deprecation.test.ts | 23 ++++++++----------- .../client/log_query_and_deprecation.ts | 9 +++----- .../7.7.2_xpack_100k.test.ts | 1 + .../7_13_0_failed_action_tasks.test.ts | 1 + .../7_13_0_transform_failures.test.ts | 1 + .../7_13_0_unknown_types.test.ts | 1 + .../batch_size_bytes.test.ts | 1 + ...ze_bytes_exceeds_es_content_length.test.ts | 1 + .../collects_corrupt_docs.test.ts | 1 + .../corrupt_outdated_docs.test.ts | 1 + .../migration_from_older_v1.test.ts | 1 + .../migration_from_same_v1.test.ts | 1 + .../multiple_es_nodes.test.ts | 1 + .../multiple_kibana_nodes.test.ts | 1 + .../integration_tests/outdated_docs.test.ts | 1 + .../integration_tests/rewriting_id.test.ts | 1 + src/core/test_helpers/kbn_server.ts | 19 +++++++++++++++ test/common/config.js | 1 + 18 files changed, 47 insertions(+), 19 deletions(-) diff --git a/src/core/server/elasticsearch/client/log_query_and_deprecation.test.ts b/src/core/server/elasticsearch/client/log_query_and_deprecation.test.ts index a29391ef5d537..bf5f8e7fcde1a 100644 --- a/src/core/server/elasticsearch/client/log_query_and_deprecation.test.ts +++ b/src/core/server/elasticsearch/client/log_query_and_deprecation.test.ts @@ -540,14 +540,13 @@ describe('instrumentQueryAndDeprecationLogger', () => { }); client.diagnostic.emit('response', new errors.ResponseError(response), response); - // One debug log entry from 'elasticsearch.query' context - expect(loggingSystemMock.collect(logger).debug.length).toEqual(1); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch( + // Test debug[1] since theree is one log entry from 'elasticsearch.query' context + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch( 'Elasticsearch deprecation: 299 Elasticsearch-8.1.0 "GET /_path is deprecated"' ); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch('Origin:kibana'); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch(/Stack trace:\n.*at/); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch( + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch('Origin:kibana'); + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch(/Stack trace:\n.*at/); + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch( /Query:\n.*400\n.*GET \/_path\?hello\=dolly \[illegal_argument_exception\]: request \[\/_path\] contains unrecognized parameter: \[name\]/ ); }); @@ -573,7 +572,6 @@ describe('instrumentQueryAndDeprecationLogger', () => { }); client.diagnostic.emit('response', null, response); - expect(loggingSystemMock.collect(logger).info).toEqual([]); // Test debug[1] since theree is one log entry from 'elasticsearch.query' context expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch( 'Elasticsearch deprecation: 299 Elasticsearch-8.1.0 "GET /_path is deprecated"' @@ -608,14 +606,13 @@ describe('instrumentQueryAndDeprecationLogger', () => { }); client.diagnostic.emit('response', null, response); - // One debug log entry from 'elasticsearch.query' context - expect(loggingSystemMock.collect(logger).debug.length).toEqual(1); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch( + // Test debug[1] since theree is one log entry from 'elasticsearch.query' context + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch( 'Elasticsearch deprecation: 299 Elasticsearch-8.1.0 "GET /_path is deprecated"' ); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch('Origin:kibana'); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch(/Stack trace:\n.*at/); - expect(loggingSystemMock.collect(logger).info[0][0]).toMatch( + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch('Origin:kibana'); + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch(/Stack trace:\n.*at/); + expect(loggingSystemMock.collect(logger).debug[1][0]).toMatch( /Query:\n.*200\n.*GET \/_path\?hello\=dolly/ ); }); diff --git a/src/core/server/elasticsearch/client/log_query_and_deprecation.ts b/src/core/server/elasticsearch/client/log_query_and_deprecation.ts index b017fce0e342d..e371f9f25ad81 100644 --- a/src/core/server/elasticsearch/client/log_query_and_deprecation.ts +++ b/src/core/server/elasticsearch/client/log_query_and_deprecation.ts @@ -139,12 +139,9 @@ export const instrumentEsQueryAndDeprecationLogger = ({ // Strip the first 5 stack trace lines as these are irrelavent to finding the call site const stackTrace = new Error().stack?.split('\n').slice(5).join('\n'); - const deprecationMsg = `Elasticsearch deprecation: ${event.warnings}\nOrigin:${requestOrigin}\nStack trace:\n${stackTrace}\nQuery:\n${queryMsg}`; - if (requestOrigin === 'kibana') { - deprecationLogger.info(deprecationMsg); - } else { - deprecationLogger.debug(deprecationMsg); - } + deprecationLogger.debug( + `Elasticsearch deprecation: ${event.warnings}\nOrigin:${requestOrigin}\nStack trace:\n${stackTrace}\nQuery:\n${queryMsg}` + ); } } }); diff --git a/src/core/server/saved_objects/migrations/integration_tests/7.7.2_xpack_100k.test.ts b/src/core/server/saved_objects/migrations/integration_tests/7.7.2_xpack_100k.test.ts index 139cd298d28ed..79a49b2518092 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/7.7.2_xpack_100k.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/7.7.2_xpack_100k.test.ts @@ -63,6 +63,7 @@ describe('migration from 7.7.2-xpack with 100k objects', () => { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_failed_action_tasks.test.ts b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_failed_action_tasks.test.ts index 479b1e78e1b72..48bcdd6e5eaca 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_failed_action_tasks.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_failed_action_tasks.test.ts @@ -128,6 +128,7 @@ function createRoot() { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_transform_failures.test.ts b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_transform_failures.test.ts index c8e17a64a3fa3..e24cfe0d90c27 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_transform_failures.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_transform_failures.test.ts @@ -170,6 +170,7 @@ function createRoot() { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_unknown_types.test.ts b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_unknown_types.test.ts index 0791b0db30c93..496b57e23abea 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/7_13_0_unknown_types.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/7_13_0_unknown_types.test.ts @@ -125,6 +125,7 @@ function createRoot() { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes.test.ts b/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes.test.ts index f263efbb26be0..90f8aafa23122 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes.test.ts @@ -154,6 +154,7 @@ function createRoot(options: { maxBatchSizeBytes?: number }) { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes_exceeds_es_content_length.test.ts b/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes_exceeds_es_content_length.test.ts index 3c6a8005505b7..3fbe508b4c365 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes_exceeds_es_content_length.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/batch_size_bytes_exceeds_es_content_length.test.ts @@ -106,6 +106,7 @@ function createRoot(options: { maxBatchSizeBytes?: number }) { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/collects_corrupt_docs.test.ts b/src/core/server/saved_objects/migrations/integration_tests/collects_corrupt_docs.test.ts index e5f0206b091fd..67bff2e4e1513 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/collects_corrupt_docs.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/collects_corrupt_docs.test.ts @@ -165,6 +165,7 @@ function createRoot() { { name: 'root', appenders: ['file'], + level: 'info', }, ], }, diff --git a/src/core/server/saved_objects/migrations/integration_tests/corrupt_outdated_docs.test.ts b/src/core/server/saved_objects/migrations/integration_tests/corrupt_outdated_docs.test.ts index 348cbe88cd8a7..39676a7ad7f9b 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/corrupt_outdated_docs.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/corrupt_outdated_docs.test.ts @@ -169,6 +169,7 @@ function createRoot() { { name: 'root', appenders: ['file'], + level: 'info', }, ], }, diff --git a/src/core/server/saved_objects/migrations/integration_tests/migration_from_older_v1.test.ts b/src/core/server/saved_objects/migrations/integration_tests/migration_from_older_v1.test.ts index c341463b78910..8c71cf3a29ef5 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/migration_from_older_v1.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/migration_from_older_v1.test.ts @@ -94,6 +94,7 @@ describe('migrating from 7.3.0-xpack which used v1 migrations', () => { { name: 'root', appenders: ['file'], + level: 'info', }, ], }, diff --git a/src/core/server/saved_objects/migrations/integration_tests/migration_from_same_v1.test.ts b/src/core/server/saved_objects/migrations/integration_tests/migration_from_same_v1.test.ts index 34d1317755c14..1fa739768e412 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/migration_from_same_v1.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/migration_from_same_v1.test.ts @@ -94,6 +94,7 @@ describe('migrating from the same Kibana version that used v1 migrations', () => { name: 'root', appenders: ['file'], + level: 'info', }, ], }, diff --git a/src/core/server/saved_objects/migrations/integration_tests/multiple_es_nodes.test.ts b/src/core/server/saved_objects/migrations/integration_tests/multiple_es_nodes.test.ts index fabc9222b6858..ae8ae6bcc3084 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/multiple_es_nodes.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/multiple_es_nodes.test.ts @@ -83,6 +83,7 @@ function createRoot({ logFileName, hosts }: RootConfig) { { name: 'root', appenders: ['file'], + level: 'info', }, ], }, diff --git a/src/core/server/saved_objects/migrations/integration_tests/multiple_kibana_nodes.test.ts b/src/core/server/saved_objects/migrations/integration_tests/multiple_kibana_nodes.test.ts index 5d0d662a5360b..9830d3bf954cc 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/multiple_kibana_nodes.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/multiple_kibana_nodes.test.ts @@ -83,6 +83,7 @@ async function createRoot({ logFileName }: CreateRootConfig) { { name: 'root', appenders: ['file'], + level: 'info', }, { name: 'savedobjects-service', diff --git a/src/core/server/saved_objects/migrations/integration_tests/outdated_docs.test.ts b/src/core/server/saved_objects/migrations/integration_tests/outdated_docs.test.ts index 506f42cb2e402..4b73b757cfb15 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/outdated_docs.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/outdated_docs.test.ts @@ -109,6 +109,7 @@ function createRoot() { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/server/saved_objects/migrations/integration_tests/rewriting_id.test.ts b/src/core/server/saved_objects/migrations/integration_tests/rewriting_id.test.ts index 2fd1ce9b6b14b..79e55ef5beeed 100644 --- a/src/core/server/saved_objects/migrations/integration_tests/rewriting_id.test.ts +++ b/src/core/server/saved_objects/migrations/integration_tests/rewriting_id.test.ts @@ -76,6 +76,7 @@ function createRoot() { loggers: [ { name: 'root', + level: 'info', appenders: ['file'], }, ], diff --git a/src/core/test_helpers/kbn_server.ts b/src/core/test_helpers/kbn_server.ts index a47ea14ba5a68..a63a8d406db40 100644 --- a/src/core/test_helpers/kbn_server.ts +++ b/src/core/test_helpers/kbn_server.ts @@ -109,6 +109,25 @@ export function createRootWithCorePlugins(settings = {}, cliArgs: Partial