Skip to content

Commit

Permalink
Add tests
Browse files Browse the repository at this point in the history
  • Loading branch information
guineveresaenger committed Jul 19, 2018
1 parent 1e38240 commit 20fd433
Show file tree
Hide file tree
Showing 5 changed files with 228 additions and 18 deletions.
8 changes: 4 additions & 4 deletions pkg/commands/addannotation.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ package commands
import (
"errors"
"fmt"
"strings"
"regexp"
"strings"

"github.com/spf13/cobra"

Expand Down Expand Up @@ -64,9 +64,9 @@ func (o *addAnnotationOptions) Validate(args []string) error {
if len(args) > 1 {
return errors.New("annotations must be comma-separated, with no spaces. See help text for example.")
}
inputs := strings.Split(args[0],",")
inputs := strings.Split(args[0], ",")
for _, input := range inputs {
ok, err := regexp.MatchString(`\A([a-zA-Z0-9_.-]+):([a-zA-Z0-9_.-]+)\z`, input)
ok, err := regexp.MatchString(`\A([a-zA-Z0-9_.-]+):([a-zA-Z0-9_.-]+)\z`, input)
if err != nil {
return err
}
Expand Down Expand Up @@ -95,7 +95,7 @@ func (o *addAnnotationOptions) RunAddAnnotation(fsys fs.FileSystem) error {
return err
}

if m.CommonAnnotations == nil{
if m.CommonAnnotations == nil {
m.CommonAnnotations = make(map[string]string)
}
annotations := strings.Split(o.annotations, ",")
Expand Down
111 changes: 110 additions & 1 deletion pkg/commands/addannotation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,113 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

package commands
package commands

import (
"testing"

"strings"

"github.com/kubernetes-sigs/kustomize/pkg/constants"
"github.com/kubernetes-sigs/kustomize/pkg/fs"
)

func TestAnnotationsValid(t *testing.T) {
var testcases = []struct {
input string
valid bool
name string
}{
{
input: "owls:great,unicorns:magical",
valid: true,
name: "Adds two annotations",
},
{
input: "owls:great",
valid: false,
name: "Annotation keys must be unique",
},
{
input: "otters:cute",
valid: true,
name: "Adds single annotation",
},
{
input: "dogs,cats",
valid: false,
name: "Does not contain colon",
},
{
input: ":noKey",
valid: false,
name: "Missing key",
},
{
input: "noValue:",
valid: false,
name: "Missing value",
},
}
fakeFS := fs.MakeFakeFS()
fakeFS.WriteFile(constants.KustomizationFileName, []byte(kustomizationContent))
cmd := newCmdAddAnnotation(fakeFS)

for _, tc := range testcases {
annotations := strings.Split(tc.input, ",")
//run command with test input
args := []string{tc.input}
err := cmd.RunE(cmd, args)

if err != nil && tc.valid {
t.Errorf("for test case %s, unexpected cmd error: %v", tc.name, err)
}
if err == nil && !tc.valid {
t.Errorf("unexpected error: expected invalid annotation format error for test case %v", tc.name)
}
if err == nil && (tc.name == "Annotation keys must be unique") {
t.Errorf("unexpected error: for test case %s, expected already there problem", tc.name)
}

content, readErr := fakeFS.ReadFile(constants.KustomizationFileName)
if readErr != nil {
t.Errorf("unexpected read error: %v", readErr)
}
//check if valid input was added to commonAnnotations
for _, annotation := range annotations {
key := strings.Split(annotation, ":")[0]
if !strings.Contains(string(content), key) && tc.valid {
t.Errorf("unexpected error: for test case %s, expected key to be in file.", tc.name)
}
}

}

}

func TestAddAnnotationNoArgs(t *testing.T) {
fakeFS := fs.MakeFakeFS()

cmd := newCmdAddAnnotation(fakeFS)
err := cmd.Execute()
if err == nil {
t.Errorf("expected an error but error is %v", err)
}
if err != nil && err.Error() != "must specify an annotation" {
t.Errorf("incorrect error: %v", err.Error())
}
}

func TestAddAnnotationMultipleArgs(t *testing.T) {
fakeFS := fs.MakeFakeFS()
fakeFS.WriteFile(constants.KustomizationFileName, []byte(kustomizationContent))
cmd := newCmdAddAnnotation(fakeFS)
args := []string{"this:input", "has:spaces"}
err := cmd.RunE(cmd, args)
if err == nil {
t.Errorf("expected an error but error is %v", err)
}
if err != nil && err.Error() != "annotations must be comma-separated, with no spaces. See help text for example." {
t.Errorf("incorrect error: %v", err.Error())
}
}
13 changes: 4 additions & 9 deletions pkg/commands/addlabel.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,9 @@ limitations under the License.
package commands

import (
"regexp"
"errors"
"fmt"
"regexp"
"strings"

"github.com/spf13/cobra"
Expand Down Expand Up @@ -57,21 +57,16 @@ func newCmdAddLabel(fsys fs.FileSystem) *cobra.Command {
}

// Validate validates addLabel command.
// TODO: make sure label is of correct format key:value
func (o *addLabelOptions) Validate(args []string) error {
for _, arg := range args {
fmt.Println(arg + "****")
}

if len(args) < 1 {
return errors.New("must specify a label")
}
if len(args) > 1 {
return errors.New("labels must be comma-separated, with no spaces. See help text for example.")
}
inputs := strings.Split(args[0],",")
inputs := strings.Split(args[0], ",")
for _, input := range inputs {
ok, err := regexp.MatchString(`\A([a-zA-Z0-9_.-]+):([a-zA-Z0-9_.-]+)\z`, input)
ok, err := regexp.MatchString(`\A([a-zA-Z0-9_.-]+):([a-zA-Z0-9_.-]+)\z`, input)
if err != nil {
return err
}
Expand Down Expand Up @@ -102,7 +97,7 @@ func (o *addLabelOptions) RunAddLabel(fsys fs.FileSystem) error {
return err
}

if m.CommonLabels == nil{
if m.CommonLabels == nil {
m.CommonLabels = make(map[string]string)
}

Expand Down
111 changes: 110 additions & 1 deletion pkg/commands/addlabel_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,113 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

package commands
package commands

import (
"testing"

"strings"

"github.com/kubernetes-sigs/kustomize/pkg/constants"
"github.com/kubernetes-sigs/kustomize/pkg/fs"
)

func TestLabelsValid(t *testing.T) {
var testcases = []struct {
input string
valid bool
name string
}{
{
input: "owls:great,unicorns:magical",
valid: true,
name: "Adds two labels",
},
{
input: "owls:great",
valid: false,
name: "Label keys must be unique",
},
{
input: "otters:cute",
valid: true,
name: "Adds single label",
},
{
input: "dogs,cats",
valid: false,
name: "Does not contain colon",
},
{
input: ":noKey",
valid: false,
name: "Missing key",
},
{
input: "noValue:",
valid: false,
name: "Missing value",
},
}
fakeFS := fs.MakeFakeFS()
fakeFS.WriteFile(constants.KustomizationFileName, []byte(kustomizationContent))
cmd := newCmdAddLabel(fakeFS)

for _, tc := range testcases {
labels := strings.Split(tc.input, ",")
//run command with test input
args := []string{tc.input}
err := cmd.RunE(cmd, args)

if err != nil && tc.valid {
t.Errorf("for test case %s, unexpected cmd error: %v", tc.name, err)
}
if err == nil && !tc.valid {
t.Errorf("unexpected error: expected invalid annotation format error for test case %v", tc.name)
}
if err == nil && (tc.name == "Label keys must be unique") {
t.Errorf("unexpected error: for test case %s, expected already there problem", tc.name)
}

content, readErr := fakeFS.ReadFile(constants.KustomizationFileName)
if readErr != nil {
t.Errorf("unexpected read error: %v", readErr)
}
//check if valid input was added to commonLabels
for _, label := range labels {
key := strings.Split(label, ":")[0]
if !strings.Contains(string(content), key) && tc.valid {
t.Errorf("unexpected error: for test case %s, expected key to be in file.", tc.name)
}
}

}

}

func TestAddLabelNoArgs(t *testing.T) {
fakeFS := fs.MakeFakeFS()

cmd := newCmdAddLabel(fakeFS)
err := cmd.Execute()
if err == nil {
t.Errorf("expected an error but error is: %v", err)
}
if err != nil && err.Error() != "must specify a label" {
t.Errorf("incorrect error: %v", err.Error())
}
}

func TestAddLabelMultipleArgs(t *testing.T) {
fakeFS := fs.MakeFakeFS()
fakeFS.WriteFile(constants.KustomizationFileName, []byte(kustomizationContent))
cmd := newCmdAddLabel(fakeFS)
args := []string{"this:input", "has:spaces"}
err := cmd.RunE(cmd, args)
if err == nil {
t.Errorf("expected an error but error is: %v", err)
}
if err != nil && err.Error() != "labels must be comma-separated, with no spaces. See help text for example." {
t.Errorf("incorrect error: %v", err.Error())
}
}
3 changes: 0 additions & 3 deletions pkg/commands/commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,15 +96,12 @@ func newCmdAdd(fsys fs.FileSystem) *cobra.Command {
# Adds one or more base directories to the kustomization
kustomize edit add base <filepath>
kustomize edit add base <filepath1>,<filepath2>,<filepath3>
<<<<<<< HEAD
=======
# Adds one or more commonLabels to the kustomization
kustomize edit add label {labelKey1:labelValue1},{labelKey2:labelValue2}
# Adds one or more commonAnnotations to the kustomization
kustomize edit add annotation {annotationKey1:annotationValue1},{annotationKey2:annotationValue2}
>>>>>>> Implements labels and annotations as subcommands of edit
`,
Args: cobra.MinimumNArgs(1),
}
Expand Down

0 comments on commit 20fd433

Please sign in to comment.