mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-11 17:12:51 +00:00
Check if required setters are set
This commit is contained in:
@@ -21,6 +21,8 @@ type setter struct {
|
|||||||
Value string `yaml:"value,omitempty" json:"value,omitempty"`
|
Value string `yaml:"value,omitempty" json:"value,omitempty"`
|
||||||
ListValues []string `yaml:"listValues,omitempty" json:"listValues,omitempty"`
|
ListValues []string `yaml:"listValues,omitempty" json:"listValues,omitempty"`
|
||||||
EnumValues map[string]string `yaml:"enumValues,omitempty" json:"enumValues,omitempty"`
|
EnumValues map[string]string `yaml:"enumValues,omitempty" json:"enumValues,omitempty"`
|
||||||
|
Required bool `yaml:"required,omitempty" json:"required,omitempty"`
|
||||||
|
IsSet bool `yaml:"isSet,omitempty" json:"isSet,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type substitution struct {
|
type substitution struct {
|
||||||
|
|||||||
31
kyaml/setters2/util.go
Normal file
31
kyaml/setters2/util.go
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
// Copyright 2019 The Kubernetes Authors.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package setters2
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"sigs.k8s.io/kustomize/kyaml/errors"
|
||||||
|
"sigs.k8s.io/kustomize/kyaml/fieldmeta"
|
||||||
|
"sigs.k8s.io/kustomize/kyaml/openapi"
|
||||||
|
)
|
||||||
|
|
||||||
|
// CheckRequiredSettersSet iterates through all the setter definitions in openAPI
|
||||||
|
// schema and returns error if any of the setter has required field true and isSet false
|
||||||
|
func CheckRequiredSettersSet() error {
|
||||||
|
for key := range openapi.Schema().Definitions {
|
||||||
|
if strings.Contains(key, fieldmeta.SetterDefinitionPrefix) {
|
||||||
|
val := openapi.Schema().Definitions[key]
|
||||||
|
defExt, err := GetExtFromSchema(&val) // parse the extension out of the openAPI
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrap(err)
|
||||||
|
}
|
||||||
|
if defExt.Setter.Required && !defExt.Setter.IsSet {
|
||||||
|
return errors.Errorf("setter %s is required but not set, "+
|
||||||
|
"please set it to new value and try again", strings.TrimPrefix(key, fieldmeta.SetterDefinitionPrefix))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
172
kyaml/setters2/util_test.go
Normal file
172
kyaml/setters2/util_test.go
Normal file
@@ -0,0 +1,172 @@
|
|||||||
|
// Copyright 2019 The Kubernetes Authors.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package setters2
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
"sigs.k8s.io/kustomize/kyaml/openapi"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestCheckRequiredSettersSet(t *testing.T) {
|
||||||
|
var tests = []struct {
|
||||||
|
name string
|
||||||
|
inputOpenAPIfile string
|
||||||
|
expectedError bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "no required, no isSet",
|
||||||
|
inputOpenAPIfile: `
|
||||||
|
apiVersion: v1alpha1
|
||||||
|
kind: OpenAPIfile
|
||||||
|
openAPI:
|
||||||
|
definitions:
|
||||||
|
io.k8s.cli.setters.gcloud.project.projectNumber:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: gcloud.project.projectNumber
|
||||||
|
value: "123"
|
||||||
|
setBy: me
|
||||||
|
io.k8s.cli.setters.replicas:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: replicas
|
||||||
|
value: "3"
|
||||||
|
setBy: me
|
||||||
|
`,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "required true, no isSet",
|
||||||
|
inputOpenAPIfile: `
|
||||||
|
apiVersion: v1alpha1
|
||||||
|
kind: Example
|
||||||
|
openAPI:
|
||||||
|
definitions:
|
||||||
|
io.k8s.cli.setters.replicas:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: replicas
|
||||||
|
value: "3"
|
||||||
|
setBy: me
|
||||||
|
required: true
|
||||||
|
`,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "required true, isSet true",
|
||||||
|
inputOpenAPIfile: `
|
||||||
|
apiVersion: v1alpha1
|
||||||
|
kind: Example
|
||||||
|
openAPI:
|
||||||
|
definitions:
|
||||||
|
io.k8s.cli.setters.replicas:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: replicas
|
||||||
|
value: "3"
|
||||||
|
setBy: me
|
||||||
|
required: true
|
||||||
|
isSet: true
|
||||||
|
`,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
name: "required false, isSet true",
|
||||||
|
inputOpenAPIfile: `
|
||||||
|
apiVersion: v1alpha1
|
||||||
|
kind: OpenAPIfile
|
||||||
|
openAPI:
|
||||||
|
definitions:
|
||||||
|
io.k8s.cli.setters.gcloud.project.projectNumber:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: gcloud.project.projectNumber
|
||||||
|
value: "123"
|
||||||
|
setBy: me
|
||||||
|
io.k8s.cli.setters.replicas:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: replicas
|
||||||
|
value: "3"
|
||||||
|
setBy: me
|
||||||
|
required: false
|
||||||
|
isSet: true
|
||||||
|
`,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
name: "required true, isSet false",
|
||||||
|
inputOpenAPIfile: `
|
||||||
|
apiVersion: v1alpha1
|
||||||
|
kind: OpenAPIfile
|
||||||
|
openAPI:
|
||||||
|
definitions:
|
||||||
|
io.k8s.cli.setters.gcloud.project.projectNumber:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: gcloud.project.projectNumber
|
||||||
|
value: "123"
|
||||||
|
setBy: me
|
||||||
|
io.k8s.cli.setters.replicas:
|
||||||
|
description: hello world
|
||||||
|
x-k8s-cli:
|
||||||
|
setter:
|
||||||
|
name: replicas
|
||||||
|
value: "3"
|
||||||
|
setBy: me
|
||||||
|
required: true
|
||||||
|
isSet: false
|
||||||
|
`,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
name: "no openAPI",
|
||||||
|
inputOpenAPIfile: ``,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for i := range tests {
|
||||||
|
test := tests[i]
|
||||||
|
t.Run(test.name, func(t *testing.T) {
|
||||||
|
openapi.ResetOpenAPI()
|
||||||
|
defer openapi.ResetOpenAPI()
|
||||||
|
dir, err := ioutil.TempDir("", "")
|
||||||
|
assert.NoError(t, err)
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
err = ioutil.WriteFile(filepath.Join(dir, "Krmfile"), []byte(test.inputOpenAPIfile), 0600)
|
||||||
|
if !assert.NoError(t, err) {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
err = openapi.AddSchemaFromFile(filepath.Join(dir, "Krmfile"))
|
||||||
|
if err != nil {
|
||||||
|
// do nothing if openAPI file or schema doesn't exist, CheckRequiredSettersSet()
|
||||||
|
// should not throw any error
|
||||||
|
fmt.Println("Unable to load schema from file, continuing...")
|
||||||
|
}
|
||||||
|
err = CheckRequiredSettersSet()
|
||||||
|
if test.expectedError && !assert.Error(t, err) {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
if !test.expectedError && !assert.NoError(t, err) {
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,3 +1,6 @@
|
|||||||
|
// Copyright 2019 The Kubernetes Authors.
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
// Code generated by "stringer -type=smpDirective -linecomment"; DO NOT EDIT.
|
// Code generated by "stringer -type=smpDirective -linecomment"; DO NOT EDIT.
|
||||||
|
|
||||||
package merge2
|
package merge2
|
||||||
|
|||||||
Reference in New Issue
Block a user