Skip to content

Commit

Permalink
Merge pull request #4361 from natasha41575/EditAddGenerator
Browse files Browse the repository at this point in the history
add kustomize edit add generator command
  • Loading branch information
k8s-ci-robot authored Jan 5, 2022
2 parents 59c8268 + 92197fd commit 37668d8
Show file tree
Hide file tree
Showing 5 changed files with 165 additions and 17 deletions.
72 changes: 72 additions & 0 deletions kustomize/commands/edit/add/addgenerator.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
// Copyright 2022 The Kubernetes Authors.
// SPDX-License-Identifier: Apache-2.0

package add

import (
"errors"
"log"

"github.com/spf13/cobra"
"sigs.k8s.io/kustomize/kustomize/v4/commands/internal/kustfile"
"sigs.k8s.io/kustomize/kustomize/v4/commands/internal/util"
"sigs.k8s.io/kustomize/kyaml/filesys"
)

type addGeneratorOptions struct {
generatorFilePaths []string
}

// newCmdAddGenerator adds the name of a file containing a generator
// configuration to the kustomization file.
func newCmdAddGenerator(fSys filesys.FileSystem) *cobra.Command {
var o addGeneratorOptions
cmd := &cobra.Command{
Use: "generator",
Short: "Add the name of a file containing a generator configuration to the kustomization file.",
Example: `
add generator {filepath}`,
RunE: func(cmd *cobra.Command, args []string) error {
err := o.Validate(fSys, args)
if err != nil {
return err
}
return o.RunAddGenerator(fSys)
},
}
return cmd
}

// Validate validates add generator command.
func (o *addGeneratorOptions) Validate(fSys filesys.FileSystem, args []string) error {
// TODO: Add validation for the format of the generator.
if len(args) == 0 {
return errors.New("must specify a yaml file which contains a generator plugin resource")
}
var err error
o.generatorFilePaths, err = util.GlobPatterns(fSys, args)
return err
}

// RunAddGenerator runs add generator command (do real work).
func (o *addGeneratorOptions) RunAddGenerator(fSys filesys.FileSystem) error {
if len(o.generatorFilePaths) == 0 {
return nil
}
mf, err := kustfile.NewKustomizationFile(fSys)
if err != nil {
return err
}
m, err := mf.Read()
if err != nil {
return err
}
for _, t := range o.generatorFilePaths {
if kustfile.StringInSlice(t, m.Generators) {
log.Printf("generator %s already in kustomization file", t)
continue
}
m.Generators = append(m.Generators, t)
}
return mf.Write(m)
}
82 changes: 82 additions & 0 deletions kustomize/commands/edit/add/addgenerator_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
// Copyright 2019 The Kubernetes Authors.
// SPDX-License-Identifier: Apache-2.0

package add

import (
"testing"

"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"sigs.k8s.io/kustomize/kustomize/v4/commands/internal/kustfile"
testutils_test "sigs.k8s.io/kustomize/kustomize/v4/commands/internal/testutils"
"sigs.k8s.io/kustomize/kyaml/filesys"
)

const (
generatorFileName = "myWonderfulGenerator.yaml"
generatorFileContent = `
Lorem ipsum dolor sit amet, consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
`
)

func TestAddGeneratorHappyPath(t *testing.T) {
fSys := filesys.MakeEmptyDirInMemory()
err := fSys.WriteFile(generatorFileName, []byte(generatorFileContent))
require.NoError(t, err)
err = fSys.WriteFile(generatorFileName+"another", []byte(generatorFileContent))
require.NoError(t, err)
testutils_test.WriteTestKustomization(fSys)

cmd := newCmdAddGenerator(fSys)
args := []string{generatorFileName + "*"}
assert.NoError(t, cmd.RunE(cmd, args))
content, err := testutils_test.ReadTestKustomization(fSys)
assert.NoError(t, err)
assert.Contains(t, string(content), generatorFileName)
assert.Contains(t, string(content), generatorFileName+"another")
}

func TestAddGeneratorAlreadyThere(t *testing.T) {
fSys := filesys.MakeEmptyDirInMemory()
err := fSys.WriteFile(generatorFileName, []byte(generatorFileName))
require.NoError(t, err)
testutils_test.WriteTestKustomization(fSys)

cmd := newCmdAddGenerator(fSys)
args := []string{generatorFileName}
assert.NoError(t, cmd.RunE(cmd, args))

// adding an existing generator shouldn't return an error
assert.NoError(t, cmd.RunE(cmd, args))

// There can be only one. May it be the...
mf, err := kustfile.NewKustomizationFile(fSys)
assert.NoError(t, err)
m, err := mf.Read()
assert.NoError(t, err)
assert.Equal(t, 1, len(m.Generators))
assert.Equal(t, generatorFileName, m.Generators[0])
}

func TestAddGeneratorNoArgs(t *testing.T) {
fSys := filesys.MakeFsInMemory()

cmd := newCmdAddGenerator(fSys)
err := cmd.Execute()
assert.EqualError(t, err, "must specify a yaml file which contains a generator plugin resource")
}

func TestAddGeneratorMissingKustomizationYAML(t *testing.T) {
fSys := filesys.MakeEmptyDirInMemory()
err := fSys.WriteFile(generatorFileName, []byte(generatorFileContent))
require.NoError(t, err)
err = fSys.WriteFile(generatorFileName+"another", []byte(generatorFileContent))
require.NoError(t, err)

cmd := newCmdAddGenerator(fSys)
args := []string{generatorFileName + "*"}
err = cmd.RunE(cmd, args)
assert.EqualError(t, err, "Missing kustomization file 'kustomization.yaml'.\n")
}
25 changes: 9 additions & 16 deletions kustomize/commands/edit/add/addtransformer.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,13 @@ type addTransformerOptions struct {
// configuration to the kustomization file.
func newCmdAddTransformer(fSys filesys.FileSystem) *cobra.Command {
var o addTransformerOptions

cmd := &cobra.Command{
Use: "transformer",
Short: "Add the name of a file containing a transformer configuration to the kustomization file.",
Example: `
add transformer {filepath}`,
RunE: func(cmd *cobra.Command, args []string) error {
err := o.Validate(args)
err := o.Validate(fSys, args)
if err != nil {
return err
}
Expand All @@ -39,41 +38,35 @@ func newCmdAddTransformer(fSys filesys.FileSystem) *cobra.Command {
}

// Validate validates add transformer command.
func (o *addTransformerOptions) Validate(args []string) error {
func (o *addTransformerOptions) Validate(fSys filesys.FileSystem, args []string) error {
// TODO: Add validation for the format of the transformer.
if len(args) == 0 {
return errors.New("must specify a transformer file")
return errors.New("must specify a yaml file which contains a transformer plugin resource")
}
o.transformerFilePaths = args
return nil
var err error
o.transformerFilePaths, err = util.GlobPatterns(fSys, args)
return err
}

// RunAddTransformer runs add transformer command (do real work).
func (o *addTransformerOptions) RunAddTransformer(fSys filesys.FileSystem) error {
transformers, err := util.GlobPatterns(fSys, o.transformerFilePaths)
if err != nil {
return err
}
if len(transformers) == 0 {
if len(o.transformerFilePaths) == 0 {
return nil
}

mf, err := kustfile.NewKustomizationFile(fSys)
if err != nil {
return err
}

m, err := mf.Read()
if err != nil {
return err
}

for _, t := range transformers {
for _, t := range o.transformerFilePaths {
if kustfile.StringInSlice(t, m.Transformers) {
log.Printf("transformer %s already in kustomization file", t)
continue
}
m.Transformers = append(m.Transformers, t)
}

return mf.Write(m)
}
2 changes: 1 addition & 1 deletion kustomize/commands/edit/add/addtransformer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ func TestAddTransformerNoArgs(t *testing.T) {

cmd := newCmdAddTransformer(fSys)
err := cmd.Execute()
assert.EqualError(t, err, "must specify a transformer file")
assert.EqualError(t, err, "must specify a yaml file which contains a transformer plugin resource")
}

func TestAddTransformerMissingKustomizationYAML(t *testing.T) {
Expand Down
1 change: 1 addition & 0 deletions kustomize/commands/edit/add/all.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ func NewCmdAdd(
newCmdAddLabel(fSys, ldr.Validator().MakeLabelValidator()),
newCmdAddAnnotation(fSys, ldr.Validator().MakeAnnotationValidator()),
newCmdAddTransformer(fSys),
newCmdAddGenerator(fSys),
)
return c
}

0 comments on commit 37668d8

Please sign in to comment.