Refactor and optimize function to set all setters

This commit is contained in:
Phillip Wittrock
2020-04-01 11:27:59 -07:00
parent d5d908610d
commit 6a3eaf8ba0
3 changed files with 49 additions and 40 deletions

View File

@@ -23,6 +23,9 @@ type Set struct {
// Count is the number of fields that were updated by calling Filter // Count is the number of fields that were updated by calling Filter
Count int Count int
// SetAll if set to true will set all setters regardless of name
SetAll bool
} }
// Filter implements Set as a yaml.Filter // Filter implements Set as a yaml.Filter
@@ -30,13 +33,19 @@ func (s *Set) Filter(object *yaml.RNode) (*yaml.RNode, error) {
return object, accept(s, object) return object, accept(s, object)
} }
// isMatch returns true if the setter with name should have the field
// value set
func (s *Set) isMatch(name string) bool {
return s.SetAll || s.Name == name
}
// visitSequence will perform setters for sequences // visitSequence will perform setters for sequences
func (s *Set) visitSequence(object *yaml.RNode, p string, schema *openapi.ResourceSchema) error { func (s *Set) visitSequence(object *yaml.RNode, p string, schema *openapi.ResourceSchema) error {
ext, err := getExtFromComment(schema) ext, err := getExtFromComment(schema)
if err != nil { if err != nil {
return err return err
} }
if ext == nil || ext.Setter == nil || ext.Setter.Name != s.Name || if ext == nil || ext.Setter == nil || !s.isMatch(ext.Setter.Name) ||
len(ext.Setter.ListValues) == 0 { len(ext.Setter.ListValues) == 0 {
// setter was not invoked for this sequence // setter was not invoked for this sequence
return nil return nil
@@ -125,7 +134,7 @@ func (s *Set) substitute(field *yaml.RNode, ext *cliExtension, _ *spec.Schema) (
p = strings.ReplaceAll(p, v.Marker, subSetter.Setter.Value) p = strings.ReplaceAll(p, v.Marker, subSetter.Setter.Value)
} }
if subSetter.Setter.Name == s.Name { if s.isMatch(subSetter.Setter.Name) {
// the substitution depends on the specified setter // the substitution depends on the specified setter
nameMatch = true nameMatch = true
} }
@@ -148,7 +157,7 @@ func (s *Set) substitute(field *yaml.RNode, ext *cliExtension, _ *spec.Schema) (
// set applies the value from ext to field if its name matches s.Name // set applies the value from ext to field if its name matches s.Name
func (s *Set) set(field *yaml.RNode, ext *cliExtension, sch *spec.Schema) bool { func (s *Set) set(field *yaml.RNode, ext *cliExtension, sch *spec.Schema) bool {
// check full setter // check full setter
if ext.Setter == nil || ext.Setter.Name != s.Name { if ext.Setter == nil || !s.isMatch(ext.Setter.Name) {
return false return false
} }

View File

@@ -69,34 +69,30 @@ func (fs FieldSetter) Set(openAPIPath, resourcesPath string) (int, error) {
return s.Count, err return s.Count, err
} }
// SetAllSetterDefinitions reads all the Setter Definitions from OpenAPI in source // SetAllSetterDefinitions reads all the Setter Definitions from the OpenAPI
// package and sets all setter values in destination packages with out updating // file and sets all values in the provided directories.
// destination packages openAPI files func SetAllSetterDefinitions(openAPIPath string, dirs ...string) error {
func SetAllSetterDefinitions(sourcePkgPath, sourcePkgOpenAPIPath string, destDirs ...string) error { if err := openapi.AddSchemaFromFile(openAPIPath); err != nil {
// get all the setter definitions from package
l := setters2.List{}
err := l.List(sourcePkgOpenAPIPath, sourcePkgPath)
if err != nil {
return err return err
} }
// for each setter definition set the setter values in destination packages for _, dir := range dirs {
//TODO(pmarupaka): optimize to perform all the setters in single pass instead of N passes rw := &kio.LocalPackageReadWriter{
for _, sd := range l.Setters { PackagePath: dir,
for _, destDir := range destDirs { // set output won't include resources from files which
fs := FieldSetter{ //weren't modified. make sure we don't delete them.
Name: sd.Name, NoDeleteFiles: true,
Value: sd.Value, }
ListValues: sd.ListValues,
Description: sd.Description, // apply all of the setters to the directory
SetBy: sd.SetBy, err := kio.Pipeline{
} Inputs: []kio.Reader{rw},
// pass sourcePkgOpenAPIPath remains unchanged due to set but should be passed as // Set all of the setters
// a place holder Filters: []kio.Filter{setters2.SetAll(&setters2.Set{SetAll: true})},
_, err = fs.Set(sourcePkgOpenAPIPath, destDir) Outputs: []kio.Writer{rw},
if err != nil { }.Execute()
return err if err != nil {
} return err
} }
} }
return nil return nil

View File

@@ -52,17 +52,17 @@ spec:
srcDir, err := ioutil.TempDir("", "") srcDir, err := ioutil.TempDir("", "")
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
destDir1, err := ioutil.TempDir("", "") destDir1, err := ioutil.TempDir("", "")
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
destDir2, err := ioutil.TempDir("", "") destDir2, err := ioutil.TempDir("", "")
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
defer os.RemoveAll(srcDir) defer os.RemoveAll(srcDir)
@@ -71,32 +71,36 @@ spec:
err = ioutil.WriteFile(srcDir+"/OpenAPIFile", []byte(srcOpenAPIFile), 0600) err = ioutil.WriteFile(srcDir+"/OpenAPIFile", []byte(srcOpenAPIFile), 0600)
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
err = ioutil.WriteFile(destDir1+"/destFile.yaml", []byte(destFile1), 0600) err = ioutil.WriteFile(destDir1+"/destFile.yaml", []byte(destFile1), 0600)
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
err = ioutil.WriteFile(destDir2+"/destFile.yaml", []byte(destFile2), 0600) err = ioutil.WriteFile(destDir2+"/destFile.yaml", []byte(destFile2), 0600)
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
err = SetAllSetterDefinitions(srcDir, srcDir+"/OpenAPIFile", destDir1, destDir2) err = SetAllSetterDefinitions(srcDir+"/OpenAPIFile", destDir1, destDir2)
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
} }
actualdestFile1, err := ioutil.ReadFile(destDir1 + "/destFile.yaml") actualdestFile1, err := ioutil.ReadFile(destDir1 + "/destFile.yaml")
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
}
if !assert.Equal(t, strings.Trim(string(actualdestFile1), "\n"), expectedDestFile) {
t.FailNow()
} }
assert.Equal(t, strings.Trim(string(actualdestFile1), "\n"), expectedDestFile)
actualdestFile2, err := ioutil.ReadFile(destDir2 + "/destFile.yaml") actualdestFile2, err := ioutil.ReadFile(destDir2 + "/destFile.yaml")
if !assert.NoError(t, err) { if !assert.NoError(t, err) {
t.Fail() t.FailNow()
}
if !assert.Equal(t, strings.Trim(string(actualdestFile2), "\n"), expectedDestFile) {
t.FailNow()
} }
assert.Equal(t, strings.Trim(string(actualdestFile2), "\n"), expectedDestFile)
} }