structured message for selector; matching functionality

pull/6/head
Meir Fischer 2014-07-31 00:29:42 -04:00
parent 6af0717205
commit 80b1fa000e
2 changed files with 102 additions and 0 deletions

View File

@ -105,6 +105,54 @@ func (t andTerm) String() string {
return strings.Join(terms, ",")
}
type Comparator int
const (
IN Comparator = iota + 1
NOT_IN
)
// only not named 'Selector' due to name
// conflict until Selector is deprecated
type LabelSelector struct {
Requirements []Requirement
}
type Requirement struct {
key string
comparator Comparator
strValues []string
}
func (r *Requirement) containsStr(value string) bool {
for _, x := range r.strValues {
if value == x {
return true
}
}
return false
}
func (r *Requirement) Matches(ls Labels) bool {
switch r.comparator {
case IN:
return r.containsStr(ls.Get(r.key))
case NOT_IN:
return !r.containsStr(ls.Get(r.key))
default:
return false
}
}
func (sg *LabelSelector) Matches(ls Labels) bool {
for _, req := range sg.Requirements {
if sat := req.Matches(ls); !sat {
return false
}
}
return true
}
func try(selectorPiece, op string) (lhs, rhs string, ok bool) {
pieces := strings.Split(selectorPiece, op)
if len(pieces) == 2 {

View File

@ -163,3 +163,57 @@ func TestSetIsEmpty(t *testing.T) {
t.Errorf("Nested andTerm should not be empty")
}
}
func expectMatchRequirement(t *testing.T, req Requirement, ls Set) {
if !req.Matches(ls) {
t.Errorf("Wanted '%+v' to match '%s', but it did not.\n", req, ls)
}
}
func expectNoMatchRequirement(t *testing.T, req Requirement, ls Set) {
if req.Matches(ls) {
t.Errorf("Wanted '%+v' to not match '%s', but it did.", req, ls)
}
}
func TestRequirementMatches(t *testing.T) {
s := Set{"x": "foo", "y": "baz"}
a := Requirement{key: "x", comparator: IN, strValues: []string{"foo"}}
b := Requirement{key: "x", comparator: NOT_IN, strValues: []string{"beta"}}
c := Requirement{key: "y", comparator: IN, strValues: nil}
d := Requirement{key: "y", strValues: []string{"foo"}}
expectMatchRequirement(t, a, s)
expectMatchRequirement(t, b, s)
expectNoMatchRequirement(t, c, s)
expectNoMatchRequirement(t, d, s)
}
func expectMatchLabSelector(t *testing.T, lsel LabelSelector, s Set) {
if !lsel.Matches(s) {
t.Errorf("Wanted '%+v' to match '%s', but it did not.\n", lsel, s)
}
}
func expectNoMatchLabSelector(t *testing.T, lsel LabelSelector, s Set) {
if lsel.Matches(s) {
t.Errorf("Wanted '%+v' to not match '%s', but it did.\n", lsel, s)
}
}
func TestLabelSelectorMatches(t *testing.T) {
s := Set{"x": "foo", "y": "baz"}
allMatch := LabelSelector{
Requirements: []Requirement{
{key: "x", comparator: IN, strValues: []string{"foo"}},
{key: "y", comparator: NOT_IN, strValues: []string{"alpha"}},
},
}
singleNonMatch := LabelSelector{
Requirements: []Requirement{
{key: "x", comparator: IN, strValues: []string{"foo"}},
{key: "y", comparator: IN, strValues: []string{"alpha"}},
},
}
expectMatchLabSelector(t, allMatch, s)
expectNoMatchLabSelector(t, singleNonMatch, s)
}