2023-04-14 12:40:34 +00:00
|
|
|
package output
|
2023-03-21 15:25:18 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/jobs"
|
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
|
|
|
NotebookOutput jobs.NotebookOutput
|
|
|
|
DbtOutput jobs.DbtOutput
|
|
|
|
SqlOutput jobs.SqlOutput
|
|
|
|
LogsOutput struct {
|
2023-03-21 17:38:11 +00:00
|
|
|
Logs string `json:"logs"`
|
|
|
|
LogsTruncated bool `json:"logs_truncated"`
|
2023-03-21 15:25:18 +00:00
|
|
|
}
|
2024-12-12 09:28:42 +00:00
|
|
|
)
|
2023-03-21 15:25:18 +00:00
|
|
|
|
2024-12-05 15:37:24 +00:00
|
|
|
func structToString(val any) (string, error) {
|
2023-03-21 15:25:18 +00:00
|
|
|
b, err := json.MarshalIndent(val, "", " ")
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
return string(b), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (out *NotebookOutput) String() (string, error) {
|
|
|
|
if out.Truncated {
|
2025-01-07 10:49:23 +00:00
|
|
|
return out.Result + "\n[truncated...]\n", nil
|
2023-03-21 15:25:18 +00:00
|
|
|
}
|
|
|
|
return out.Result, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (out *DbtOutput) String() (string, error) {
|
|
|
|
outputString, err := structToString(out)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
|
|
|
|
// We add this prefix to make this output non machine readable.
|
|
|
|
// JSON is used because it's a convenient representation.
|
|
|
|
// If user needs machine parsable output, they can use the --output json
|
|
|
|
// flag
|
2025-01-07 10:49:23 +00:00
|
|
|
return "Dbt Task Output:\n" + outputString, nil
|
2023-03-21 15:25:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (out *SqlOutput) String() (string, error) {
|
|
|
|
outputString, err := structToString(out)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
|
|
|
|
// We add this prefix to make this output non machine readable.
|
|
|
|
// JSON is used because it's a convenient representation.
|
|
|
|
// If user needs machine parsable output, they can use the --output json
|
|
|
|
// flag
|
2025-01-07 10:49:23 +00:00
|
|
|
return "SQL Task Output:\n" + outputString, nil
|
2023-03-21 15:25:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (out *LogsOutput) String() (string, error) {
|
|
|
|
if out.LogsTruncated {
|
2025-01-07 10:49:23 +00:00
|
|
|
return out.Logs + "\n[truncated...]\n", nil
|
2023-03-21 15:25:18 +00:00
|
|
|
}
|
|
|
|
return out.Logs, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func toRunOutput(output *jobs.RunOutput) RunOutput {
|
|
|
|
switch {
|
|
|
|
case output.NotebookOutput != nil:
|
|
|
|
result := NotebookOutput(*output.NotebookOutput)
|
|
|
|
return &result
|
|
|
|
case output.DbtOutput != nil:
|
|
|
|
result := DbtOutput(*output.DbtOutput)
|
|
|
|
return &result
|
|
|
|
|
|
|
|
case output.SqlOutput != nil:
|
|
|
|
result := SqlOutput(*output.SqlOutput)
|
|
|
|
return &result
|
|
|
|
// Corresponds to JAR, python script and python wheel tasks
|
|
|
|
case output.Logs != "":
|
|
|
|
result := LogsOutput{
|
|
|
|
Logs: output.Logs,
|
|
|
|
LogsTruncated: output.LogsTruncated,
|
|
|
|
}
|
|
|
|
return &result
|
|
|
|
default:
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|