Skip to content

Commit

Permalink
feat(cargo): allow configuration of Validate to check allow list for …
Browse files Browse the repository at this point in the history
…release_source types

Co-authored-by: Ajita Jain <[email protected]>
  • Loading branch information
crhntr and jajita committed Aug 9, 2024
1 parent 466b4d5 commit fdea504
Show file tree
Hide file tree
Showing 4 changed files with 131 additions and 11 deletions.
11 changes: 1 addition & 10 deletions internal/commands/validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package commands

import (
"fmt"
"slices"
"strings"

"github.com/go-git/go-billy/v5"
Expand Down Expand Up @@ -40,15 +39,7 @@ func (v Validate) Execute(args []string) error {
return fmt.Errorf("failed to load kilnfiles: %w", err)
}

if len(v.Options.ReleaseSourceTypeAllowList) > 0 {
for _, s := range kf.ReleaseSources {
if !slices.Contains(v.Options.ReleaseSourceTypeAllowList, s.Type) {
return fmt.Errorf("release source type not allowed: %s", s.Type)
}
}
}

errs := cargo.Validate(kf, lock)
errs := cargo.Validate(kf, lock, cargo.ValidateResourceTypeAllowList(v.Options.ReleaseSourceTypeAllowList...))
if len(errs) > 0 {
return errorList(errs)
}
Expand Down
66 changes: 66 additions & 0 deletions internal/commands/validate_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
package commands_test

import (
"io"

. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"

"github.com/go-git/go-billy/v5"
"github.com/go-git/go-billy/v5/memfs"

"github.com/pivotal-cf/kiln/internal/commands"
)

var _ = Describe("validate", func() {
var (
validate commands.Validate
directory billy.Filesystem
)

BeforeEach(func() {
directory = memfs.New()
})

JustBeforeEach(func() {
validate = commands.NewValidate(directory)
})

When("the kilnfile has two release_sources", func() {
BeforeEach(func() {
f, err := directory.Create("Kilnfile")
Expect(err).NotTo(HaveOccurred())
_, _ = io.WriteString(f, `---
release_sources:
- type: "bosh.io"
- type: "github"
`)
_ = f.Close()
})

BeforeEach(func() {
f, err := directory.Create("Kilnfile.lock")
Expect(err).NotTo(HaveOccurred())
_ = f.Close()
})

When("both types are in the allow list", func() {
It("it does fail", func() {
err := validate.Execute([]string{
"--allow-release-source-type=bosh.io",
"--allow-release-source-type=github",
})
Expect(err).NotTo(HaveOccurred())
})
})
When("both one of the types is not in the allow list", func() {
It("it does fail", func() {
err := validate.Execute([]string{
"--allow-release-source-type=bosh.io",
})
Expect(err).To(MatchError(ContainSubstring("release source type not allowed: github")))
})
})
})

})
34 changes: 33 additions & 1 deletion pkg/cargo/validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,41 @@ import (
"github.com/Masterminds/semver/v3"
)

func Validate(spec Kilnfile, lock KilnfileLock) []error {
type ValidationOptions struct {
resourceTypeAllowList []string
}

func ValidateResourceTypeAllowList(allowList ...string) ValidationOptions {
return ValidationOptions{}.SetValidateResourceTypeAllowList(allowList)
}

func (o ValidationOptions) SetValidateResourceTypeAllowList(allowList []string) ValidationOptions {
o.resourceTypeAllowList = allowList
return o
}

func mergeOptions(options []ValidationOptions) ValidationOptions {
var opt ValidationOptions
for _, o := range options {
if o.resourceTypeAllowList != nil {
opt.resourceTypeAllowList = o.resourceTypeAllowList
}
}
return opt
}

func Validate(spec Kilnfile, lock KilnfileLock, options ...ValidationOptions) []error {
opt := mergeOptions(options)
var result []error

if len(opt.resourceTypeAllowList) > 0 {
for _, s := range spec.ReleaseSources {
if !slices.Contains(opt.resourceTypeAllowList, s.Type) {
result = append(result, fmt.Errorf("release source type not allowed: %s", s.Type))
}
}
}

for index, componentSpec := range spec.Releases {
if componentSpec.Name == "" {
result = append(result, fmt.Errorf("release at index %d missing name in spec", index))
Expand Down
31 changes: 31 additions & 0 deletions pkg/cargo/validate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ import (
"testing"

. "github.com/onsi/gomega"

"github.com/stretchr/testify/assert"
)

const (
Expand Down Expand Up @@ -296,3 +298,32 @@ func TestValidate_checkComponentVersionsAndConstraint(t *testing.T) {
))
})
}

func TestValidateWithOptions(t *testing.T) {
t.Run("resource type allow list", func(t *testing.T) {
t.Run("when the types are permitted", func(t *testing.T) {
kf := Kilnfile{
ReleaseSources: []ReleaseSourceConfig{
{Type: "farm"},
{Type: "orchard"},
},
}
kl := KilnfileLock{}
errs := Validate(kf, kl, ValidateResourceTypeAllowList("orchard", "farm"))
assert.Zero(t, errs)
})
t.Run("when one of the types is not in the allow list", func(t *testing.T) {
kf := Kilnfile{
ReleaseSources: []ReleaseSourceConfig{
{Type: "farm"},
{Type: "orchard"},
},
}
kl := KilnfileLock{}
errs := Validate(kf, kl, ValidateResourceTypeAllowList("orchard"))
if assert.Len(t, errs, 1) {
assert.ErrorContains(t, errs[0], "release source type not allowed: farm")
}
})
})
}

0 comments on commit fdea504

Please sign in to comment.