Skip to content
This repository has been archived by the owner on May 3, 2022. It is now read-only.

Commit

Permalink
Sync Duffle with cnab-go and spec changes
Browse files Browse the repository at this point in the history
Signed-off-by: Radu M <root@radu.sh>
  • Loading branch information
Radu M committed Aug 6, 2019
1 parent 45b8e91 commit 367ce6b
Show file tree
Hide file tree
Showing 9 changed files with 62 additions and 52 deletions.
11 changes: 4 additions & 7 deletions cmd/duffle/install.go
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,7 @@ func (i *installCmd) run() error {
c.Bundle = bun
// calculateParamValues determines if values can be changed in later actions, but we don't have
// previous values so install passes nil.
c.Parameters, err = calculateParamValues(bun, i.valuesFile, i.setParams, i.setFiles, nil)
c.Parameters, err = calculateParamValues(bun, i.valuesFile, i.setParams, i.setFiles)
if err != nil {
return err
}
Expand Down Expand Up @@ -229,10 +229,7 @@ func parseValues(file string) (map[string]interface{}, error) {
return vals, nil
}

func calculateParamValues(bun *bundle.Bundle, valuesFile string, setParams, setFilePaths []string, prevVals map[string]interface{}) (map[string]interface{}, error) {
if prevVals == nil {
prevVals = map[string]interface{}{}
}
func calculateParamValues(bun *bundle.Bundle, valuesFile string, setParams, setFilePaths []string) (map[string]interface{}, error) {
vals := map[string]interface{}{}
if valuesFile != "" {
var err error
Expand All @@ -258,7 +255,7 @@ func calculateParamValues(bun *bundle.Bundle, valuesFile string, setParams, setF
}

// Check that this is a known param
if _, ok := bun.Parameters.Fields[parts[0]]; !ok {
if _, ok := bun.Parameters[parts[0]]; !ok {
return vals, fmt.Errorf("bundle does not have a parameter named %q", parts[0])
}

Expand All @@ -272,5 +269,5 @@ func calculateParamValues(bun *bundle.Bundle, valuesFile string, setParams, setF
vals[parts[0]] = string(content)
}

return bundle.ValuesOrDefaults(vals, prevVals, bun)
return bundle.ValuesOrDefaults(vals, bun)
}
2 changes: 1 addition & 1 deletion cmd/duffle/run.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ Credentials and parameters may be passed to the bundle during a target action.

// Override parameters only if some are set.
if valuesFile != "" || len(setParams) > 0 {
c.Parameters, err = calculateParamValues(c.Bundle, valuesFile, setParams, setFiles, c.Parameters)
c.Parameters, err = calculateParamValues(c.Bundle, valuesFile, setParams, setFiles)
if err != nil {
return err
}
Expand Down
2 changes: 1 addition & 1 deletion cmd/duffle/uninstall.go
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ func (un *uninstallCmd) run() error {
if claim.Bundle == nil {
return errors.New("parameters can only be set if a bundle is provided")
}
params, err := calculateParamValues(claim.Bundle, un.valuesFile, un.setParams, []string{}, claim.Parameters)
params, err := calculateParamValues(claim.Bundle, un.valuesFile, un.setParams, []string{})
if err != nil {
return err
}
Expand Down
2 changes: 1 addition & 1 deletion cmd/duffle/upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ func (up *upgradeCmd) run() error {

// Override parameters only if some are set.
if up.valuesFile != "" || len(up.setParams) > 0 {
claim.Parameters, err = calculateParamValues(claim.Bundle, up.valuesFile, up.setParams, up.setFiles, claim.Parameters)
claim.Parameters, err = calculateParamValues(claim.Bundle, up.valuesFile, up.setParams, up.setFiles)
if err != nil {
return err
}
Expand Down
28 changes: 15 additions & 13 deletions pkg/builder/builder.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,19 +67,21 @@ func (b *Builder) PrepareBuild(bldr *Builder, mfst *manifest.Manifest, appDir st
}

bf := &bundle.Bundle{
Actions: ctx.Manifest.Actions,
Credentials: ctx.Manifest.Credentials,
Custom: ctx.Manifest.Custom,
Definitions: ctx.Manifest.Definitions,
Description: ctx.Manifest.Description,
Images: ctx.Manifest.Images,
Keywords: ctx.Manifest.Keywords,
Maintainers: ctx.Manifest.Maintainers,
Name: ctx.Manifest.Name,
Outputs: ctx.Manifest.Outputs,
Parameters: ctx.Manifest.Parameters,
SchemaVersion: ctx.Manifest.SchemaVersion,
Version: ctx.Manifest.Version,
Actions: ctx.Manifest.Actions,
Credentials: ctx.Manifest.Credentials,
Custom: ctx.Manifest.Custom,
Definitions: ctx.Manifest.Definitions,
Description: ctx.Manifest.Description,
Images: ctx.Manifest.Images,
Keywords: ctx.Manifest.Keywords,
License: ctx.Manifest.License,
Maintainers: ctx.Manifest.Maintainers,
Name: ctx.Manifest.Name,
Outputs: ctx.Manifest.Outputs,
Parameters: ctx.Manifest.Parameters,
RequiredExtensions: ctx.Manifest.RequiredExtensions,
SchemaVersion: ctx.Manifest.SchemaVersion,
Version: ctx.Manifest.Version,
}

for _, imb := range imageBuilders {
Expand Down
27 changes: 19 additions & 8 deletions pkg/builder/builder_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -55,9 +55,8 @@ func TestPrepareBuild(t *testing.T) {
outputs := &bundle.OutputsDefinition{
Fields: map[string]bundle.OutputDefinition{"output1": {}},
}
params := &bundle.ParametersDefinition{
Fields: map[string]bundle.ParameterDefinition{"param1": {}},
}
params := map[string]bundle.Parameter{"param1": {}}

mfst := &manifest.Manifest{
Actions: map[string]bundle.Action{"act1": {}},
Credentials: map[string]bundle.Credential{"cred1": {}},
Expand All @@ -79,11 +78,13 @@ func TestPrepareBuild(t *testing.T) {
URL: "https://test.com",
},
},
Name: "foo",
Outputs: outputs,
Parameters: params,
SchemaVersion: "v1.0.0",
Version: "0.1.0",
Name: "foo",
Outputs: outputs,
Parameters: params,
SchemaVersion: "v1.0.0",
Version: "0.1.0",
License: "MIT",
RequiredExtensions: []string{"ext1", "ext2"},
}

components := []imagebuilder.ImageBuilder{
Expand Down Expand Up @@ -175,6 +176,16 @@ func TestPrepareBuild(t *testing.T) {
}
checksPerformed++

if b.License != mfst.License {
t.Errorf("expected licnse %v, got %v", mfst.License, b.License)
}
checksPerformed++

if !reflect.DeepEqual(b.RequiredExtensions, mfst.RequiredExtensions) {
t.Errorf("expected credentials to be %+v but was %+v", mfst.RequiredExtensions, b.RequiredExtensions)
}
checksPerformed++

// Ensure that all the fields have been checked. If the structures need to diverge in the future, this test should be modified.
mfstFields := getFields(manifest.Manifest{})
if len(mfstFields) != checksPerformed {
Expand Down
30 changes: 16 additions & 14 deletions pkg/duffle/manifest/manifest.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,20 +12,22 @@ import (

// Manifest represents a duffle manifest.
type Manifest struct {
Name string `json:"name"`
Version string `json:"version"`
SchemaVersion string `json:"schemaVersion"`
Description string `json:"description,omitempty"`
Keywords []string `json:"keywords,omitempty"`
Maintainers []bundle.Maintainer `json:"maintainers,omitempty"`
InvocationImages map[string]*InvocationImage `json:"invocationImages,omitempty"`
Images map[string]bundle.Image `json:"images,omitempty"`
Actions map[string]bundle.Action `json:"actions,omitempty"`
Parameters *bundle.ParametersDefinition `json:"parameters,omitempty"`
Credentials map[string]bundle.Credential `json:"credentials,omitempty"`
Definitions definition.Definitions `json:"definitions,omitempty"`
Outputs *bundle.OutputsDefinition `json:"outputs,omitempty"`
Custom map[string]interface{} `json:"custom,omitempty"`
Name string `json:"name"`
Version string `json:"version"`
SchemaVersion string `json:"schemaVersion"`
Description string `json:"description,omitempty"`
Keywords []string `json:"keywords,omitempty"`
Maintainers []bundle.Maintainer `json:"maintainers,omitempty"`
InvocationImages map[string]*InvocationImage `json:"invocationImages,omitempty"`
Images map[string]bundle.Image `json:"images,omitempty"`
Actions map[string]bundle.Action `json:"actions,omitempty"`
Parameters map[string]bundle.Parameter `json:"parameters,omitempty"`
Credentials map[string]bundle.Credential `json:"credentials,omitempty"`
Definitions definition.Definitions `json:"definitions,omitempty"`
Outputs *bundle.OutputsDefinition `json:"outputs,omitempty"`
Custom map[string]interface{} `json:"custom,omitempty"`
License string `json:"license,omitempty"`
RequiredExtensions []string `json:"requiredExtensions,omitempty"`
}

// InvocationImage represents an invocation image component of a CNAB bundle
Expand Down
6 changes: 3 additions & 3 deletions pkg/duffle/manifest/manifest_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,11 @@ func TestLoad(t *testing.T) {
t.Errorf("exp docker but was \"%v\"", img.ImageType)
}

if len(m.Parameters.Fields) != 1 {
t.Fatalf("expected 1 parameter but got %d", len(m.Parameters.Fields))
if len(m.Parameters) != 1 {
t.Fatalf("expected 1 parameter but got %d", len(m.Parameters))
}

_, ok := m.Parameters.Fields["foo"]
_, ok := m.Parameters["foo"]
if !ok {
t.Errorf("expected a parameter named foo but got %v", m.Parameters)
}
Expand Down
6 changes: 2 additions & 4 deletions pkg/duffle/manifest/testdata/duffle.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,8 @@
}
},
"parameters": {
"fields": {
"foo": {
"definition": "foo"
}
"foo": {
"definition": "foo"
}
},
"credentials": {
Expand Down

0 comments on commit 367ce6b

Please sign in to comment.