From 1df0ec8ff522f70086cef8627a657a04027a4091 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mike=20C=C3=B4t=C3=A9?= Date: Tue, 3 Oct 2023 09:15:08 -0400 Subject: [PATCH] Revert "[Task Manager] Force validation on all tasks using state (#164574)" This reverts commit d86eebd6c1e7dd8b084bba91566fdd9298293b0e. --- .../task_manager/server/task_validator.test.ts | 8 ++++++-- .../task_manager/server/task_validator.ts | 17 ++++++++++------- 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/x-pack/plugins/task_manager/server/task_validator.test.ts b/x-pack/plugins/task_manager/server/task_validator.test.ts index 08c18591e468e..52822adf6f49f 100644 --- a/x-pack/plugins/task_manager/server/task_validator.test.ts +++ b/x-pack/plugins/task_manager/server/task_validator.test.ts @@ -64,7 +64,9 @@ describe('TaskValidator', () => { expect(result).toEqual(task); }); - it(`should fail to validate the state schema when the task type doesn't have stateSchemaByVersion defined`, () => { + // TODO: Remove skip once all task types have defined their state schema. + // https://github.com/elastic/kibana/issues/159347 + it.skip(`should fail to validate the state schema when the task type doesn't have stateSchemaByVersion defined`, () => { const definitions = new TaskTypeDictionary(mockLogger()); definitions.registerTaskDefinitions({ foo: fooTaskDefinition, @@ -320,7 +322,9 @@ describe('TaskValidator', () => { expect(result).toEqual(task); }); - it(`should fail to validate the state schema when the task type doesn't have stateSchemaByVersion defined`, () => { + // TODO: Remove skip once all task types have defined their state schema. + // https://github.com/elastic/kibana/issues/159347 + it.skip(`should fail to validate the state schema when the task type doesn't have stateSchemaByVersion defined`, () => { const definitions = new TaskTypeDictionary(mockLogger()); definitions.registerTaskDefinitions({ foo: fooTaskDefinition, diff --git a/x-pack/plugins/task_manager/server/task_validator.ts b/x-pack/plugins/task_manager/server/task_validator.ts index 900af04cd1207..61d9a903dd5b4 100644 --- a/x-pack/plugins/task_manager/server/task_validator.ts +++ b/x-pack/plugins/task_manager/server/task_validator.ts @@ -5,7 +5,7 @@ * 2.0. */ -import { max, memoize, isEmpty } from 'lodash'; +import { max, memoize } from 'lodash'; import type { Logger } from '@kbn/core/server'; import type { ObjectType } from '@kbn/config-schema'; import { TaskTypeDictionary } from './task_type_dictionary'; @@ -64,13 +64,14 @@ export class TaskValidator { const taskTypeDef = this.definitions.get(task.taskType); const latestStateSchema = this.cachedGetLatestStateSchema(taskTypeDef); - let state = task.state; - - // Skip validating tasks that don't use state - if (!latestStateSchema && isEmpty(state)) { + // TODO: Remove once all task types have defined their state schema. + // https://github.com/elastic/kibana/issues/159347 + // Otherwise, failures on read / write would occur. (don't forget to unskip test) + if (!latestStateSchema) { return task; } + let state = task.state; try { state = this.getValidatedStateSchema( this.migrateTaskState(task.state, task.stateVersion, taskTypeDef, latestStateSchema), @@ -110,8 +111,10 @@ export class TaskValidator { const taskTypeDef = this.definitions.get(task.taskType); const latestStateSchema = this.cachedGetLatestStateSchema(taskTypeDef); - // Skip validating tasks that don't use state - if (!latestStateSchema && isEmpty(task.state)) { + // TODO: Remove once all task types have defined their state schema. + // https://github.com/elastic/kibana/issues/159347 + // Otherwise, failures on read / write would occur. (don't forget to unskip test) + if (!latestStateSchema) { return task; }