tpl/collections: Fix intersect on []interface{} handling
authorCameron Moore <moorereason@gmail.com>
Thu, 27 Jul 2017 22:23:49 +0000 (17:23 -0500)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 28 Jul 2017 05:21:21 +0000 (07:21 +0200)
Fixes #3718

tpl/collections/where.go
tpl/collections/where_test.go

index 37be00509e5ba883ebdbc73b231cb3fbeca98546..be5c8205b1124765e8fcacb91214143aaf4e265f 100644 (file)
@@ -53,6 +53,7 @@ func (ns *Namespace) checkCondition(v, mv reflect.Value, op string) (bool, error
        if !v.IsValid() {
                vIsNil = true
        }
+
        mv, mvIsNil := indirect(mv)
        if !mv.IsValid() {
                mvIsNil = true
@@ -115,7 +116,7 @@ func (ns *Namespace) checkCondition(v, mv reflect.Value, op string) (bool, error
                        return false, nil
                }
 
-               if v.Kind() != reflect.Interface && mv.Type().Elem().Kind() != reflect.Interface && mv.Type().Elem() != v.Type() {
+               if v.Kind() != reflect.Interface && mv.Type().Elem().Kind() != reflect.Interface && mv.Type().Elem() != v.Type() && v.Kind() != reflect.Array && v.Kind() != reflect.Slice {
                        return false, nil
                }
                switch v.Kind() {
@@ -144,6 +145,9 @@ func (ns *Namespace) checkCondition(v, mv reflect.Value, op string) (bool, error
                                        ima = append(ima, toTimeUnix(mv.Index(i)))
                                }
                        }
+               case reflect.Array, reflect.Slice:
+                       slv = v.Interface()
+                       slmv = mv.Interface()
                }
        }
 
index 771fafb61da3080fa3a8b1b891fd68fae5357dce..e702837782f03dfbb5f363c808c4cdebd0f27338 100644 (file)
@@ -536,6 +536,12 @@ func TestCheckCondition(t *testing.T) {
                {reflect.ValueOf(true), reflect.ValueOf(false), ">", expect{false, false}},
                {reflect.ValueOf(123), reflect.ValueOf([]int{}), "in", expect{false, false}},
                {reflect.ValueOf(123), reflect.ValueOf(123), "op", expect{false, true}},
+
+               // Issue #3718
+               {reflect.ValueOf([]interface{}{"a"}), reflect.ValueOf([]string{"a", "b"}), "intersect", expect{true, false}},
+               {reflect.ValueOf([]string{"a"}), reflect.ValueOf([]interface{}{"a", "b"}), "intersect", expect{true, false}},
+               {reflect.ValueOf([]interface{}{1, 2}), reflect.ValueOf([]int{1}), "intersect", expect{true, false}},
+               {reflect.ValueOf([]int{1}), reflect.ValueOf([]interface{}{1, 2}), "intersect", expect{true, false}},
        } {
                result, err := ns.checkCondition(test.value, test.match, test.op)
                if test.expect.isError {