Skip to content

Commit

Permalink
feat: add resource.Builder
Browse files Browse the repository at this point in the history
  • Loading branch information
siyul-park committed Nov 21, 2023
1 parent 3b997b8 commit 4a244c4
Show file tree
Hide file tree
Showing 3 changed files with 133 additions and 1 deletion.
83 changes: 83 additions & 0 deletions cmd/resource/builder.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
package resource

import (
"io"
"io/fs"

"github.com/siyul-park/uniflow/pkg/scheme"
)

type (
Builder struct {
scheme *scheme.Scheme
namespace string
fsys fs.FS
filename string
}
)

func NewBuilder() *Builder {
return &Builder{}
}

func (b *Builder) Scheme(scheme *scheme.Scheme) *Builder {
b.scheme = scheme
return b
}

func (b *Builder) Namespace(namespace string) *Builder {
b.namespace = namespace
return b
}

func (b *Builder) FS(fsys fs.FS) *Builder {
b.fsys = fsys
return b
}

func (b *Builder) Filename(filename string) *Builder {
b.filename = filename
return b
}

func (b *Builder) Build() ([]scheme.Spec, error) {
if b.fsys == nil || b.filename == "" {
return nil, nil
}
file, err := b.fsys.Open(b.filename)
if err != nil {
return nil, err
}
defer file.Close()

data, err := io.ReadAll(file)
if err != nil {
return nil, err
}

var raws []map[string]any
if err := UnmarshalYAMLOrJSON(data, &raws); err != nil {
var e map[string]any
if err := UnmarshalYAMLOrJSON(data, &e); err != nil {
return nil, err
} else {
raws = []map[string]any{e}
}
}

codec := NewSpecCodec(SpecCodecOptions{
Scheme: b.scheme,
Namespace: b.namespace,
})

var specs []scheme.Spec
for _, raw := range raws {
if spec, err := codec.Decode(raw); err != nil {
return nil, err
} else {
specs = append(specs, spec)
}
}

return specs, nil
}
50 changes: 50 additions & 0 deletions cmd/resource/builder_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
package resource

import (
"encoding/json"
"testing"
"testing/fstest"

"github.com/go-faker/faker/v4"
"github.com/oklog/ulid/v2"
"github.com/siyul-park/uniflow/pkg/node"
"github.com/siyul-park/uniflow/pkg/scheme"
"github.com/stretchr/testify/assert"
)

func TestBuilder_Build(t *testing.T) {
s := scheme.New()
fsys := make(fstest.MapFS)

filename := "spec.json"
kind := faker.Word()

spec := &scheme.SpecMeta{
ID: ulid.Make(),
Kind: kind,
Namespace: scheme.NamespaceDefault,
}

codec := scheme.CodecFunc(func(spec scheme.Spec) (node.Node, error) {
return node.NewOneToOneNode(node.OneToOneNodeConfig{ID: spec.GetID()}), nil
})

s.AddKnownType(kind, &scheme.SpecMeta{})
s.AddCodec(kind, codec)

data, _ := json.Marshal(spec)

fsys[filename] = &fstest.MapFile{
Data: data,
}

builder := NewBuilder().
Scheme(s).
Namespace(scheme.NamespaceDefault).
FS(fsys).
Filename(filename)

specs, err := builder.Build()
assert.NoError(t, err)
assert.Len(t, specs, 1)
}
1 change: 0 additions & 1 deletion pkg/scheme/unstructured.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import (
)

type (

// Unstructured is an Spec that is not marshaled for structuring.
Unstructured struct {
doc *primitive.Map
Expand Down

0 comments on commit 4a244c4

Please sign in to comment.