2022-12-15 14:12:47 +00:00
|
|
|
package run
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/databricks/bricks/bundle"
|
|
|
|
"github.com/databricks/bricks/bundle/config/resources"
|
|
|
|
"github.com/databricks/databricks-sdk-go/service/pipelines"
|
|
|
|
)
|
|
|
|
|
|
|
|
type pipelineRunner struct {
|
|
|
|
key
|
|
|
|
|
|
|
|
bundle *bundle.Bundle
|
|
|
|
pipeline *resources.Pipeline
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *pipelineRunner) Run(ctx context.Context) error {
|
|
|
|
var prefix = fmt.Sprintf("[INFO] [%s]", r.Key())
|
|
|
|
var pipelineID = r.pipeline.ID
|
|
|
|
|
|
|
|
w := r.bundle.WorkspaceClient()
|
2022-12-22 08:46:17 +00:00
|
|
|
_, err := w.Pipelines.GetByPipelineId(ctx, pipelineID)
|
2022-12-15 14:12:47 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Printf("[WARN] Cannot get pipeline: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
res, err := w.Pipelines.StartUpdate(ctx, pipelines.StartUpdate{
|
|
|
|
PipelineId: pipelineID,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
updateID := res.UpdateId
|
|
|
|
|
|
|
|
// Log the pipeline update URL as soon as it is available.
|
|
|
|
url := fmt.Sprintf("%s/#joblist/pipelines/%s/updates/%s", w.Config.Host, pipelineID, updateID)
|
|
|
|
log.Printf("%s Update available at %s", prefix, url)
|
|
|
|
|
|
|
|
// Poll update for completion and post status.
|
|
|
|
// Note: there is no "StartUpdateAndWait" wrapper for this API.
|
|
|
|
var prevState *pipelines.UpdateInfoState
|
|
|
|
for {
|
|
|
|
update, err := w.Pipelines.GetUpdateByPipelineIdAndUpdateId(ctx, pipelineID, updateID)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Log only if the current state is different from the previous state.
|
|
|
|
state := update.Update.State
|
|
|
|
if prevState == nil || *prevState != state {
|
|
|
|
log.Printf("%s Update status: %s", prefix, state)
|
|
|
|
prevState = &state
|
|
|
|
}
|
|
|
|
|
|
|
|
if state == pipelines.UpdateInfoStateCanceled {
|
|
|
|
log.Printf("%s Update was cancelled!", prefix)
|
|
|
|
return fmt.Errorf("update cancelled")
|
|
|
|
}
|
|
|
|
if state == pipelines.UpdateInfoStateFailed {
|
|
|
|
log.Printf("%s Update has failed!", prefix)
|
|
|
|
return fmt.Errorf("update failed")
|
|
|
|
}
|
|
|
|
if state == pipelines.UpdateInfoStateCompleted {
|
|
|
|
log.Printf("%s Update has completed successfully!", prefix)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
time.Sleep(time.Second)
|
|
|
|
}
|
|
|
|
}
|