From a2473713666079db55e76f5ea62608deba0943e1 Mon Sep 17 00:00:00 2001 From: mindon Date: Mon, 21 Nov 2022 13:47:35 +0800 Subject: [PATCH] fix Result lack of key issue --- server.go | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/server.go b/server.go index 77761e8..3590a35 100644 --- a/server.go +++ b/server.go @@ -239,10 +239,14 @@ func (p TaskStateProber) Changed(out map[string]interface{}) { } func (p TaskStateProber) Result(state base.TaskState, raw *base.TaskInfo) (key string, data interface{}) { - if state == base.TaskStateCompleted { - data = *newTaskInfo(raw.Message, raw.State, raw.NextProcessAt, raw.Result) - return - } + defer func() { + if len(key) == 0 { + key = "task" + } + if data == nil { + data = *newTaskInfo(raw.Message, raw.State, raw.NextProcessAt, raw.Result) + } + }() probers := p.Probers if len(probers) == 0 { @@ -259,9 +263,7 @@ func (p TaskStateProber) Result(state base.TaskState, raw *base.TaskInfo) (key s switch key { case "next": data = raw.NextProcessAt - case "task": - data = *newTaskInfo(raw.Message, raw.State, raw.NextProcessAt, raw.Result) - default: + case "result": if len(raw.Result) > 0 { data = raw.Result }