mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-25 02:08:44 +08:00
20f665ede8
* implement k8s service discovery * simplify code * use default namespace if not provided * disable codecov bot comment * ignore adhoc dir * simplify building target in NewClient * reformat code * Fix filepath (#990) * format code, and reorg imports (#991) * add more unit test Co-authored-by: anqiansong <anqiansong@gmail.com>
277 lines
4.6 KiB
Go
277 lines
4.6 KiB
Go
package kube
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
v1 "k8s.io/api/core/v1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
)
|
|
|
|
func TestAdd(t *testing.T) {
|
|
var endpoints []string
|
|
h := NewEventHandler(func(change []string) {
|
|
endpoints = change
|
|
})
|
|
h.OnAdd("bad")
|
|
h.OnAdd(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
{
|
|
IP: "0.0.0.3",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
assert.ElementsMatch(t, []string{"0.0.0.1", "0.0.0.2", "0.0.0.3"}, endpoints)
|
|
}
|
|
|
|
func TestDelete(t *testing.T) {
|
|
var endpoints []string
|
|
h := NewEventHandler(func(change []string) {
|
|
endpoints = change
|
|
})
|
|
h.OnAdd(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
{
|
|
IP: "0.0.0.3",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
h.OnDelete("bad")
|
|
h.OnDelete(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
assert.ElementsMatch(t, []string{"0.0.0.3"}, endpoints)
|
|
}
|
|
|
|
func TestUpdate(t *testing.T) {
|
|
var endpoints []string
|
|
h := NewEventHandler(func(change []string) {
|
|
endpoints = change
|
|
})
|
|
h.OnUpdate(&v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "1",
|
|
},
|
|
}, &v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
{
|
|
IP: "0.0.0.3",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "2",
|
|
},
|
|
})
|
|
assert.ElementsMatch(t, []string{"0.0.0.1", "0.0.0.2", "0.0.0.3"}, endpoints)
|
|
}
|
|
|
|
func TestUpdateNoChange(t *testing.T) {
|
|
h := NewEventHandler(func(change []string) {
|
|
assert.Fail(t, "should not called")
|
|
})
|
|
h.OnUpdate(&v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "1",
|
|
},
|
|
}, &v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "1",
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestUpdateChangeWithDifferentVersion(t *testing.T) {
|
|
var endpoints []string
|
|
h := NewEventHandler(func(change []string) {
|
|
endpoints = change
|
|
})
|
|
h.OnAdd(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.3",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
h.OnUpdate(&v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.3",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "1",
|
|
},
|
|
}, &v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "2",
|
|
},
|
|
})
|
|
assert.ElementsMatch(t, []string{"0.0.0.1", "0.0.0.2"}, endpoints)
|
|
}
|
|
|
|
func TestUpdateNoChangeWithDifferentVersion(t *testing.T) {
|
|
var endpoints []string
|
|
h := NewEventHandler(func(change []string) {
|
|
endpoints = change
|
|
})
|
|
h.OnAdd(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
h.OnUpdate("bad", &v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
},
|
|
},
|
|
}})
|
|
h.OnUpdate(&v1.Endpoints{Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
},
|
|
},
|
|
}}, "bad")
|
|
h.OnUpdate(&v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "1",
|
|
},
|
|
}, &v1.Endpoints{
|
|
Subsets: []v1.EndpointSubset{
|
|
{
|
|
Addresses: []v1.EndpointAddress{
|
|
{
|
|
IP: "0.0.0.1",
|
|
},
|
|
{
|
|
IP: "0.0.0.2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
ResourceVersion: "2",
|
|
},
|
|
})
|
|
assert.ElementsMatch(t, []string{"0.0.0.1", "0.0.0.2"}, endpoints)
|
|
}
|