Add tests for types
This commit is contained in:
parent
4ecaabdd1d
commit
811b880f0f
2 changed files with 108 additions and 0 deletions
|
@ -48,6 +48,11 @@ func (t Target) String() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Target) Set(s string) error {
|
func (t *Target) Set(s string) error {
|
||||||
|
tmp := Target(s)
|
||||||
|
if _, err := tmp.Selector(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
val := (*string)(t)
|
val := (*string)(t)
|
||||||
*val = s
|
*val = s
|
||||||
return nil
|
return nil
|
||||||
|
|
103
reaper/types_test.go
Normal file
103
reaper/types_test.go
Normal file
|
@ -0,0 +1,103 @@
|
||||||
|
package reaper_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/maxatome/go-testdeep/td"
|
||||||
|
|
||||||
|
"github.com/baez90/kreaper/reaper"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestParseTarget(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
in string
|
||||||
|
wantErr bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "Empty target",
|
||||||
|
in: "",
|
||||||
|
wantErr: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Missing value",
|
||||||
|
in: "app",
|
||||||
|
wantErr: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid separator",
|
||||||
|
in: "app: prometheus",
|
||||||
|
wantErr: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Simple target",
|
||||||
|
in: "app=prometheus",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "full qualified target",
|
||||||
|
in: "app.kubernetes.io/name=prometheus",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid domain - too many path segments",
|
||||||
|
in: "app.kubernetes.io/name/detailed=prometheus",
|
||||||
|
wantErr: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
tt := tt
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
_, err := reaper.ParseTarget(tt.in)
|
||||||
|
if (err != nil) != tt.wantErr {
|
||||||
|
t.Errorf("ParseTarget() error = %v, wantErr %v", err, tt.wantErr)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTargetFlag(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
args []string
|
||||||
|
want reaper.Target
|
||||||
|
wantErr bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "Empty args",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Valid target",
|
||||||
|
args: []string{"-target", "app.kubernetes.io/name=prometheus"},
|
||||||
|
want: "app.kubernetes.io/name=prometheus",
|
||||||
|
wantErr: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid target",
|
||||||
|
args: []string{"-target", "app.kubernetes.io/name/detailed=prometheus"},
|
||||||
|
want: "",
|
||||||
|
wantErr: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
tt := tt
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
var target reaper.Target
|
||||||
|
flagSet := flag.NewFlagSet(t.Name(), flag.ContinueOnError)
|
||||||
|
flagSet.Var(&target, "target", "")
|
||||||
|
if err := flagSet.Parse(tt.args); err != nil {
|
||||||
|
if !tt.wantErr {
|
||||||
|
t.Errorf("Failed to parse arguments: %v", err)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
td.Cmp(t, target, tt.want)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Reference in a new issue