mirror of
https://github.com/coder/coder.git
synced 2026-06-02 20:48:20 +00:00
chore: distinct operations for provisioner's 'parse', 'init', 'plan', 'apply', 'graph' (#21064)
Provisioner steps broken into smaller granular actions. Changes: - `ExtractArchive` moved to `init` request (was in `configure`) - Writing `tfstate` moved to `plan` (was in `configure`) - Moved most plan/apply outputs to `GraphComplete`
This commit is contained in:
@@ -0,0 +1,113 @@
|
||||
package runner
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"context"
|
||||
"time"
|
||||
|
||||
"cdr.dev/slog"
|
||||
"github.com/coder/coder/v2/coderd/tracing"
|
||||
"github.com/coder/coder/v2/provisionerd/proto"
|
||||
sdkproto "github.com/coder/coder/v2/provisionersdk/proto"
|
||||
)
|
||||
|
||||
//nolint:revive
|
||||
func (r *Runner) init(ctx context.Context, omitModules bool, templateArchive []byte) (*sdkproto.InitComplete, *proto.FailedJob) {
|
||||
ctx, span := r.startTrace(ctx, tracing.FuncName())
|
||||
defer span.End()
|
||||
|
||||
err := r.session.Send(&sdkproto.Request{Type: &sdkproto.Request_Init{Init: &sdkproto.InitRequest{
|
||||
TemplateSourceArchive: templateArchive,
|
||||
OmitModuleFiles: omitModules,
|
||||
}}})
|
||||
if err != nil {
|
||||
return nil, r.failedJobf("send init request: %v", err)
|
||||
}
|
||||
|
||||
nevermind := make(chan struct{})
|
||||
defer close(nevermind)
|
||||
go func() {
|
||||
select {
|
||||
case <-nevermind:
|
||||
return
|
||||
case <-r.notStopped.Done():
|
||||
return
|
||||
case <-r.notCanceled.Done():
|
||||
_ = r.session.Send(&sdkproto.Request{
|
||||
Type: &sdkproto.Request_Cancel{
|
||||
Cancel: &sdkproto.CancelRequest{},
|
||||
},
|
||||
})
|
||||
}
|
||||
}()
|
||||
|
||||
var moduleFilesUpload *sdkproto.DataBuilder
|
||||
for {
|
||||
msg, err := r.session.Recv()
|
||||
if err != nil {
|
||||
return nil, r.failedJobf("receive init response: %v", err)
|
||||
}
|
||||
switch msgType := msg.Type.(type) {
|
||||
case *sdkproto.Response_Log:
|
||||
r.logProvisionerJobLog(context.Background(), msgType.Log.Level, "terraform initialization",
|
||||
slog.F("level", msgType.Log.Level),
|
||||
slog.F("output", msgType.Log.Output),
|
||||
)
|
||||
|
||||
r.queueLog(ctx, &proto.Log{
|
||||
Source: proto.LogSource_PROVISIONER,
|
||||
Level: msgType.Log.Level,
|
||||
CreatedAt: time.Now().UnixMilli(),
|
||||
Output: msgType.Log.Output,
|
||||
Stage: "Initializing Terraform Directory",
|
||||
})
|
||||
case *sdkproto.Response_DataUpload:
|
||||
if omitModules {
|
||||
return nil, r.failedJobf("received unexpected module files data upload when omitModules is true")
|
||||
}
|
||||
c := msgType.DataUpload
|
||||
if c.UploadType != sdkproto.DataUploadType_UPLOAD_TYPE_MODULE_FILES {
|
||||
return nil, r.failedJobf("invalid data upload type: %q", c.UploadType)
|
||||
}
|
||||
|
||||
if moduleFilesUpload != nil {
|
||||
return nil, r.failedJobf("multiple module data uploads received, only expect 1")
|
||||
}
|
||||
|
||||
moduleFilesUpload, err = sdkproto.NewDataBuilder(c)
|
||||
if err != nil {
|
||||
return nil, r.failedJobf("create data builder: %s", err.Error())
|
||||
}
|
||||
case *sdkproto.Response_ChunkPiece:
|
||||
if omitModules {
|
||||
return nil, r.failedJobf("received unexpected module files data upload when omitModules is true")
|
||||
}
|
||||
c := msgType.ChunkPiece
|
||||
if moduleFilesUpload == nil {
|
||||
return nil, r.failedJobf("received chunk piece before module files data upload")
|
||||
}
|
||||
|
||||
_, err := moduleFilesUpload.Add(c)
|
||||
if err != nil {
|
||||
return nil, r.failedJobf("module files, add chunk piece: %s", err.Error())
|
||||
}
|
||||
case *sdkproto.Response_Init:
|
||||
if moduleFilesUpload != nil {
|
||||
// If files were uploaded in multiple chunks, put them back together.
|
||||
moduleFilesData, err := moduleFilesUpload.Complete()
|
||||
if err != nil {
|
||||
return nil, r.failedJobf("complete module files data upload: %s", err.Error())
|
||||
}
|
||||
|
||||
if !bytes.Equal(msgType.Init.ModuleFilesHash, moduleFilesUpload.Hash) {
|
||||
return nil, r.failedJobf("module files hash mismatch, uploaded: %x, expected: %x", moduleFilesUpload.Hash, msgType.Init.ModuleFilesHash)
|
||||
}
|
||||
msgType.Init.ModuleFiles = moduleFilesData
|
||||
}
|
||||
|
||||
return msgType.Init, nil
|
||||
default:
|
||||
return nil, r.failedJobf("unexpected init response type %T", msg.Type)
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user