2018-12-03 16:07:08 +00:00
|
|
|
package testing
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"context"
|
|
|
|
"sort"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/google/go-cmp/cmp"
|
|
|
|
"github.com/influxdata/platform"
|
|
|
|
)
|
|
|
|
|
|
|
|
var labelCmpOptions = cmp.Options{
|
|
|
|
cmp.Comparer(func(x, y []byte) bool {
|
|
|
|
return bytes.Equal(x, y)
|
|
|
|
}),
|
|
|
|
cmp.Transformer("Sort", func(in []*platform.Label) []*platform.Label {
|
|
|
|
out := append([]*platform.Label(nil), in...) // Copy input to avoid mutating it
|
|
|
|
sort.Slice(out, func(i, j int) bool {
|
2018-12-04 21:22:11 +00:00
|
|
|
if out[i].Name != out[j].Name {
|
|
|
|
return out[i].Name < out[j].Name
|
|
|
|
}
|
|
|
|
return out[i].ResourceID.String() < out[j].ResourceID.String()
|
2018-12-03 16:07:08 +00:00
|
|
|
})
|
|
|
|
return out
|
|
|
|
}),
|
|
|
|
}
|
|
|
|
|
|
|
|
type LabelFields struct {
|
|
|
|
Labels []*platform.Label
|
|
|
|
}
|
|
|
|
|
|
|
|
type labelServiceF func(
|
2018-12-18 07:59:04 +00:00
|
|
|
init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
2018-12-03 16:07:08 +00:00
|
|
|
t *testing.T,
|
|
|
|
)
|
|
|
|
|
|
|
|
// LabelService tests all the service functions.
|
|
|
|
func LabelService(
|
2018-12-18 07:59:04 +00:00
|
|
|
init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
2018-12-03 16:07:08 +00:00
|
|
|
t *testing.T,
|
|
|
|
) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fn labelServiceF
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "CreateLabel",
|
|
|
|
fn: CreateLabel,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "FindLabels",
|
|
|
|
fn: FindLabels,
|
|
|
|
},
|
2018-12-20 20:18:03 +00:00
|
|
|
// {
|
|
|
|
// name: "UpdateLabel",
|
|
|
|
// fn: UpdateLabel,
|
|
|
|
// },
|
2018-12-03 16:07:08 +00:00
|
|
|
{
|
|
|
|
name: "DeleteLabel",
|
|
|
|
fn: DeleteLabel,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
tt.fn(init, t)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func CreateLabel(
|
2018-12-18 07:59:04 +00:00
|
|
|
init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
2018-12-03 16:07:08 +00:00
|
|
|
t *testing.T,
|
|
|
|
) {
|
|
|
|
type args struct {
|
|
|
|
label *platform.Label
|
|
|
|
}
|
|
|
|
type wants struct {
|
|
|
|
err error
|
|
|
|
labels []*platform.Label
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields LabelFields
|
|
|
|
args args
|
|
|
|
wants wants
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "basic create label",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
label: &platform.Label{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "duplicate labels fail",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
label: &platform.Label{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
2018-12-18 07:59:04 +00:00
|
|
|
err: &platform.Error{
|
|
|
|
Code: platform.EConflict,
|
|
|
|
Op: platform.OpCreateLabel,
|
|
|
|
Msg: "label Tag1 already exists",
|
|
|
|
},
|
2018-12-03 16:07:08 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2018-12-18 07:59:04 +00:00
|
|
|
s, opPrefix, done := init(tt.fields, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
defer done()
|
|
|
|
ctx := context.Background()
|
|
|
|
err := s.CreateLabel(ctx, tt.args.label)
|
2018-12-18 07:59:04 +00:00
|
|
|
diffPlatformErrors(tt.name, err, tt.wants.err, opPrefix, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
|
|
|
|
defer s.DeleteLabel(ctx, *tt.args.label)
|
|
|
|
|
|
|
|
labels, err := s.FindLabels(ctx, platform.LabelFilter{})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to retrieve labels: %v", err)
|
|
|
|
}
|
2018-12-04 21:22:11 +00:00
|
|
|
if diff := cmp.Diff(labels, tt.wants.labels, labelCmpOptions...); diff != "" {
|
2018-12-03 16:07:08 +00:00
|
|
|
t.Errorf("labels are different -got/+want\ndiff %s", diff)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func FindLabels(
|
2018-12-18 07:59:04 +00:00
|
|
|
init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
2018-12-03 16:07:08 +00:00
|
|
|
t *testing.T,
|
|
|
|
) {
|
|
|
|
type args struct {
|
|
|
|
filter platform.LabelFilter
|
|
|
|
}
|
|
|
|
type wants struct {
|
|
|
|
err error
|
|
|
|
labels []*platform.Label
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields LabelFields
|
|
|
|
args args
|
|
|
|
wants wants
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "basic find labels",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
filter: platform.LabelFilter{},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "find labels filtering",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketTwoID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
filter: platform.LabelFilter{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2018-12-18 07:59:04 +00:00
|
|
|
s, opPrefix, done := init(tt.fields, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
defer done()
|
|
|
|
ctx := context.TODO()
|
|
|
|
labels, err := s.FindLabels(ctx, tt.args.filter)
|
2018-12-18 07:59:04 +00:00
|
|
|
diffPlatformErrors(tt.name, err, tt.wants.err, opPrefix, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
|
2018-12-04 22:29:11 +00:00
|
|
|
if diff := cmp.Diff(labels, tt.wants.labels, labelCmpOptions...); diff != "" {
|
2018-12-03 16:07:08 +00:00
|
|
|
t.Errorf("labels are different -got/+want\ndiff %s", diff)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-20 20:18:03 +00:00
|
|
|
// func UpdateLabel(
|
|
|
|
// init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
|
|
|
// t *testing.T,
|
|
|
|
// ) {
|
|
|
|
// type args struct {
|
|
|
|
// label platform.Label
|
|
|
|
// update platform.LabelUpdate
|
|
|
|
// }
|
|
|
|
// type wants struct {
|
|
|
|
// err error
|
|
|
|
// labels []*platform.Label
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// tests := []struct {
|
|
|
|
// name string
|
|
|
|
// fields LabelFields
|
|
|
|
// args args
|
|
|
|
// wants wants
|
|
|
|
// }{
|
|
|
|
// {
|
|
|
|
// name: "update label color",
|
|
|
|
// fields: LabelFields{
|
|
|
|
// Labels: []*platform.Label{
|
|
|
|
// {
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// args: args{
|
|
|
|
// label: platform.Label{
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// update: platform.LabelUpdate{
|
|
|
|
// Color: &validColor,
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// wants: wants{
|
|
|
|
// labels: []*platform.Label{
|
|
|
|
// {
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// Color: "fff000",
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// // {
|
|
|
|
// // name: "label update proliferation",
|
|
|
|
// // fields: LabelFields{
|
|
|
|
// // Labels: []*platform.Label{
|
|
|
|
// // {
|
|
|
|
// // ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// // Name: "Tag1",
|
|
|
|
// // },
|
|
|
|
// // {
|
|
|
|
// // ResourceID: MustIDBase16(bucketTwoID),
|
|
|
|
// // Name: "Tag1",
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// // args: args{
|
|
|
|
// // label: platform.Label{
|
|
|
|
// // ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// // Name: "Tag1",
|
|
|
|
// // },
|
|
|
|
// // update: platform.LabelUpdate{
|
|
|
|
// // Color: &validColor,
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// // wants: wants{
|
|
|
|
// // labels: []*platform.Label{
|
|
|
|
// // {
|
|
|
|
// // ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// // Name: "Tag1",
|
|
|
|
// // Color: "fff000",
|
|
|
|
// // },
|
|
|
|
// // {
|
|
|
|
// // ResourceID: MustIDBase16(bucketTwoID),
|
|
|
|
// // Name: "Tag1",
|
|
|
|
// // Color: "fff000",
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// // },
|
|
|
|
// {
|
|
|
|
// name: "invalid label color update",
|
|
|
|
// fields: LabelFields{
|
|
|
|
// Labels: []*platform.Label{
|
|
|
|
// {
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// args: args{
|
|
|
|
// label: platform.Label{
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// update: platform.LabelUpdate{
|
|
|
|
// Color: &invalidColor,
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// wants: wants{
|
|
|
|
// labels: []*platform.Label{
|
|
|
|
// {
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// err: &platform.Error{
|
|
|
|
// Code: platform.EInvalid,
|
|
|
|
// Op: platform.OpUpdateLabel,
|
|
|
|
// Msg: "label color must be valid hex string",
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// {
|
|
|
|
// name: "updating a non-existent label",
|
|
|
|
// fields: LabelFields{
|
|
|
|
// Labels: []*platform.Label{},
|
|
|
|
// },
|
|
|
|
// args: args{
|
|
|
|
// label: platform.Label{
|
|
|
|
// ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
// Name: "Tag1",
|
|
|
|
// },
|
|
|
|
// update: platform.LabelUpdate{
|
|
|
|
// Color: &validColor,
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// wants: wants{
|
|
|
|
// labels: []*platform.Label{},
|
|
|
|
// err: &platform.Error{
|
|
|
|
// Code: platform.ENotFound,
|
|
|
|
// Op: platform.OpUpdateLabel,
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// },
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// for _, tt := range tests {
|
|
|
|
// t.Run(tt.name, func(t *testing.T) {
|
|
|
|
// s, opPrefix, done := init(tt.fields, t)
|
|
|
|
// defer done()
|
|
|
|
// ctx := context.TODO()
|
|
|
|
// _, err := s.UpdateLabel(ctx, &tt.args.label, tt.args.update)
|
|
|
|
// diffPlatformErrors(tt.name, err, tt.wants.err, opPrefix, t)
|
|
|
|
//
|
|
|
|
// labels, err := s.FindLabels(ctx, platform.LabelFilter{})
|
|
|
|
// if err != nil {
|
|
|
|
// t.Fatalf("failed to retrieve labels: %v", err)
|
|
|
|
// }
|
|
|
|
// if diff := cmp.Diff(labels, tt.wants.labels, labelCmpOptions...); diff != "" {
|
|
|
|
// t.Errorf("labels are different -got/+want\ndiff %s", diff)
|
|
|
|
// }
|
|
|
|
// })
|
|
|
|
// }
|
|
|
|
// }
|
2018-12-18 06:59:38 +00:00
|
|
|
|
2018-12-03 16:07:08 +00:00
|
|
|
func DeleteLabel(
|
2018-12-18 07:59:04 +00:00
|
|
|
init func(LabelFields, *testing.T) (platform.LabelService, string, func()),
|
2018-12-03 16:07:08 +00:00
|
|
|
t *testing.T,
|
|
|
|
) {
|
|
|
|
type args struct {
|
|
|
|
label platform.Label
|
|
|
|
}
|
|
|
|
type wants struct {
|
|
|
|
err error
|
|
|
|
labels []*platform.Label
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields LabelFields
|
|
|
|
args args
|
|
|
|
wants wants
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "basic delete label",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
label: platform.Label{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "deleting a non-existant label",
|
|
|
|
fields: LabelFields{
|
|
|
|
Labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
label: platform.Label{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag2",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wants: wants{
|
|
|
|
labels: []*platform.Label{
|
|
|
|
{
|
|
|
|
ResourceID: MustIDBase16(bucketOneID),
|
|
|
|
Name: "Tag1",
|
|
|
|
},
|
|
|
|
},
|
2018-12-18 07:59:04 +00:00
|
|
|
err: &platform.Error{
|
|
|
|
Code: platform.ENotFound,
|
|
|
|
Op: platform.OpDeleteLabel,
|
|
|
|
},
|
2018-12-03 16:07:08 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2018-12-18 07:59:04 +00:00
|
|
|
s, opPrefix, done := init(tt.fields, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
defer done()
|
|
|
|
ctx := context.TODO()
|
|
|
|
err := s.DeleteLabel(ctx, tt.args.label)
|
2018-12-18 07:59:04 +00:00
|
|
|
diffPlatformErrors(tt.name, err, tt.wants.err, opPrefix, t)
|
2018-12-03 16:07:08 +00:00
|
|
|
|
|
|
|
labels, err := s.FindLabels(ctx, platform.LabelFilter{})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to retrieve labels: %v", err)
|
|
|
|
}
|
|
|
|
if diff := cmp.Diff(labels, tt.wants.labels, labelCmpOptions...); diff != "" {
|
|
|
|
t.Errorf("labels are different -got/+want\ndiff %s", diff)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|