Merge pull request #1225 from jlongtine/engine-writefile

engine.#Writefile
This commit is contained in:
Joel Longtine 2021-12-15 13:30:07 -07:00 committed by GitHub
commit e8843b918e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 176 additions and 0 deletions

View File

@ -99,3 +99,13 @@ _No input._
### engine.#Service Outputs
_No output._
## engine.#WriteFile
### engine.#WriteFile Inputs
_No input._
### engine.#WriteFile Outputs
_No output._

89
plan/task/writefile.go Normal file
View File

@ -0,0 +1,89 @@
package task
import (
"context"
"fmt"
"io/fs"
"cuelang.org/go/cue"
"github.com/moby/buildkit/client/llb"
"go.dagger.io/dagger/compiler"
"go.dagger.io/dagger/plancontext"
"go.dagger.io/dagger/solver"
)
func init() {
Register("WriteFile", func() Task { return &writeFileTask{} })
}
type writeFileTask struct {
}
func (t *writeFileTask) Run(ctx context.Context, pctx *plancontext.Context, s solver.Solver, v *compiler.Value) (*compiler.Value, error) {
var contents []byte
var err error
path, err := v.Lookup("path").String()
if err != nil {
return nil, err
}
switch kind := v.Lookup("contents").Kind(); kind {
// TODO: support bytes?
// case cue.BytesKind:
// contents, err = v.Lookup("contents").Bytes()
case cue.StringKind:
var str string
str, err = v.Lookup("contents").String()
if err == nil {
contents = []byte(str)
}
case cue.BottomKind:
err = fmt.Errorf("%s: WriteFile contents is not set", path)
default:
err = fmt.Errorf("%s: unhandled data type in WriteFile: %s", path, kind)
}
if err != nil {
return nil, err
}
mode, err := v.Lookup("mode").Int64()
if err != nil {
return nil, err
}
input, err := pctx.FS.FromValue(v.Lookup("input"))
if err != nil {
return nil, err
}
inputState, err := input.Result().ToState()
if err != nil {
return nil, err
}
outputState := inputState.File(
llb.Mkfile(path, fs.FileMode(mode), contents),
withCustomName(v, "WriteFile %s", path),
)
result, err := s.Solve(ctx, outputState, pctx.Platform.Get())
if err != nil {
return nil, err
}
fs := pctx.FS.New(result)
output := compiler.NewValue()
if err := output.FillPath(cue.ParsePath("output"), fs.MarshalCUE()); err != nil {
return nil, err
}
return output, nil
}

View File

@ -8,3 +8,13 @@ package engine
contents: string
output: #FS
}
#WriteFile: {
_type: "WriteFile"
input: #FS
path: string
contents: string
mode: int
output: #FS
}

View File

@ -13,3 +13,14 @@ setup() {
cd "$TESTDIR"/tasks/readfile
dagger --europa up
}
@test "task: #WriteFile" {
cd "$TESTDIR"/tasks/writefile
dagger --europa up ./writefile.cue
}
@test "task: #WriteFile failure: different contents" {
cd "$TESTDIR"/tasks/writefile
run dagger --europa up ./writefile_failure_diff_contents.cue
assert_failure
}

View File

@ -0,0 +1 @@
module: ""

View File

@ -0,0 +1,3 @@
# generated by dagger
alpha.dagger.io
dagger.lock

View File

@ -0,0 +1,26 @@
package main
import (
"alpha.dagger.io/europa/dagger/engine"
)
engine.#Plan & {
actions: {
pull: engine.#Pull & {
source: "alpine:3.15.0@sha256:e7d88de73db3d3fd9b2d63aa7f447a10fd0220b7cbf39803c803f2af9ba256b3"
}
write: engine.#WriteFile & {
input: pull.output
path: "/testing"
contents: "1,2,3"
mode: 700
}
readfile: engine.#ReadFile & {
input: write.output
path: "/testing"
} & {
// assert result
contents: "1,2,3"
}
}
}

View File

@ -0,0 +1,26 @@
package main
import (
"alpha.dagger.io/europa/dagger/engine"
)
engine.#Plan & {
actions: {
pull: engine.#Pull & {
source: "alpine:3.15.0@sha256:e7d88de73db3d3fd9b2d63aa7f447a10fd0220b7cbf39803c803f2af9ba256b3"
}
write: engine.#WriteFile & {
input: pull.output
path: "/testing"
contents: "1,2,3,4"
mode: 700
}
readfile: engine.#ReadFile & {
input: write.output
path: "/testing"
} & {
// assert result
contents: "1,2,3"
}
}
}