Skip to content

Commit

Permalink
Allow users to pass any content to LHTaskException
Browse files Browse the repository at this point in the history
  • Loading branch information
Snarr committed Dec 19, 2024
1 parent 3807fad commit 1f13204
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 4 deletions.
8 changes: 5 additions & 3 deletions sdk-go/littlehorse/lh_errors.go
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
package littlehorse

import "github.com/littlehorse-enterprises/littlehorse/sdk-go/lhproto"

type LHTaskException struct {
Name string
Message string
Content *lhproto.VariableValue
Content interface{}
}

func (e *LHTaskException) Error() string {
return e.Message
}
14 changes: 13 additions & 1 deletion sdk-go/littlehorse/task_worker_internal.go
Original file line number Diff line number Diff line change
Expand Up @@ -431,11 +431,23 @@ func (m *serverConnectionManager) doTaskHelper(task *lhproto.ScheduledTask) *lhp
if errorReflect.Interface() != nil {
// Check if the error is an LHTaskException
if lhtErr, ok := errorReflect.Interface().(*LHTaskException); ok {
taskErrVarVal, err := InterfaceToVarVal(lhtErr.Content)

if err != nil {
msg := "Failed to serialize task error content: " + err.Error()

taskErrVarVal = &lhproto.VariableValue{
Value: &lhproto.VariableValue_Str{
Str: msg,
},
}
}

taskResult.Result = &lhproto.ReportTaskRun_Exception{
Exception: &lhproto.LHTaskException{
Name: lhtErr.Name,
Message: lhtErr.Message,
Content: lhtErr.Content,
Content: taskErrVarVal,
},
}
} else {
Expand Down

0 comments on commit 1f13204

Please sign in to comment.