From a93cc20401e35277d98c3895f035cccba55af0f8 Mon Sep 17 00:00:00 2001 From: nic-chen Date: Mon, 9 Nov 2020 20:42:59 +0800 Subject: [PATCH 1/5] fix: bug #749 --- api/internal/core/entity/format.go | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/api/internal/core/entity/format.go b/api/internal/core/entity/format.go index 0c5d8d1061..6ce04a297a 100644 --- a/api/internal/core/entity/format.go +++ b/api/internal/core/entity/format.go @@ -23,8 +23,8 @@ import ( ) func NodesFormat(obj interface{}) interface{} { + var nodes []*Node if value, ok := obj.(map[string]float64); ok { - var nodes []*Node var strArr []string for key, val := range value { node := &Node{} @@ -48,5 +48,23 @@ func NodesFormat(obj interface{}) interface{} { return nodes } - return obj + if nodes, ok := obj.([]*Node); ok { + return nodes + } + + if value, ok := obj.(map[string]interface{}); ok { + + } + + list := obj.([]interface{}) + for _, v := range list { + val := v.(map[string]interface{}) + node := &Node{} + node.Host = val["host"].(string) + node.Port = int(val["port"].(float64)) + node.Weight = int(val["weight"].(float64)) + nodes = append(nodes, node) + } + + return nodes } From 8c0309a866f8146c17d6b010a91abf56759890e2 Mon Sep 17 00:00:00 2001 From: nic-chen Date: Mon, 9 Nov 2020 21:15:27 +0800 Subject: [PATCH 2/5] fix: bug #749 --- api/internal/core/entity/format.go | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/api/internal/core/entity/format.go b/api/internal/core/entity/format.go index 6ce04a297a..a409644347 100644 --- a/api/internal/core/entity/format.go +++ b/api/internal/core/entity/format.go @@ -52,19 +52,18 @@ func NodesFormat(obj interface{}) interface{} { return nodes } - if value, ok := obj.(map[string]interface{}); ok { - - } + if list, ok := obj.([]interface{}); ok { + for _, v := range list { + val := v.(map[string]interface{}) + node := &Node{} + node.Host = val["host"].(string) + node.Port = int(val["port"].(float64)) + node.Weight = int(val["weight"].(float64)) + nodes = append(nodes, node) + } - list := obj.([]interface{}) - for _, v := range list { - val := v.(map[string]interface{}) - node := &Node{} - node.Host = val["host"].(string) - node.Port = int(val["port"].(float64)) - node.Weight = int(val["weight"].(float64)) - nodes = append(nodes, node) + return nodes } - return nodes + return obj } From ab48ac6e9bd5e54e6c7fbd2737dd8c70923c3e92 Mon Sep 17 00:00:00 2001 From: nic-chen Date: Mon, 9 Nov 2020 21:15:59 +0800 Subject: [PATCH 3/5] test: add test cases --- .../handler/upstream/upstream_test.go | 49 ++++++++++++++++--- 1 file changed, 42 insertions(+), 7 deletions(-) diff --git a/api/internal/handler/upstream/upstream_test.go b/api/internal/handler/upstream/upstream_test.go index 197d3a8fe3..e09dda6b4a 100644 --- a/api/internal/handler/upstream/upstream_test.go +++ b/api/internal/handler/upstream/upstream_test.go @@ -30,6 +30,8 @@ import ( "github.com/apisix/manager-api/internal/core/store" ) +var upstreamHandler *Handler + func TestUpstream(t *testing.T) { // init err := storage.InitETCDClient([]string{"127.0.0.1:2379"}) @@ -37,10 +39,10 @@ func TestUpstream(t *testing.T) { err = store.InitStores() assert.Nil(t, err) - handler := &Handler{ + upstreamHandler = &Handler{ upstreamStore: store.GetStore(store.HubKeyUpstream), } - assert.NotNil(t, handler) + assert.NotNil(t, upstreamHandler) //create ctx := droplet.NewContext() @@ -94,7 +96,7 @@ func TestUpstream(t *testing.T) { err = json.Unmarshal([]byte(reqBody), upstream) assert.Nil(t, err) ctx.SetInput(upstream) - _, err = handler.Create(ctx) + _, err = upstreamHandler.Create(ctx) assert.Nil(t, err) //sleep @@ -104,7 +106,7 @@ func TestUpstream(t *testing.T) { input := &GetInput{} input.ID = "1" ctx.SetInput(input) - ret, err := handler.Get(ctx) + ret, err := upstreamHandler.Get(ctx) stored := ret.(*entity.Upstream) assert.Nil(t, err) assert.Equal(t, stored.ID, upstream.ID) @@ -161,7 +163,7 @@ func TestUpstream(t *testing.T) { err = json.Unmarshal([]byte(reqBody), upstream2) assert.Nil(t, err) ctx.SetInput(upstream2) - _, err = handler.Update(ctx) + _, err = upstreamHandler.Update(ctx) assert.Nil(t, err) //list @@ -170,7 +172,7 @@ func TestUpstream(t *testing.T) { err = json.Unmarshal([]byte(reqBody), listInput) assert.Nil(t, err) ctx.SetInput(listInput) - retPage, err := handler.List(ctx) + retPage, err := upstreamHandler.List(ctx) assert.Nil(t, err) dataPage := retPage.(*store.ListOutput) assert.Equal(t, len(dataPage.Rows), 1) @@ -181,7 +183,40 @@ func TestUpstream(t *testing.T) { err = json.Unmarshal([]byte(reqBody), inputDel) assert.Nil(t, err) ctx.SetInput(inputDel) - _, err = handler.BatchDelete(ctx) + _, err = upstreamHandler.BatchDelete(ctx) assert.Nil(t, err) } + +func TestUpstream_Pass_Host(t *testing.T) { + //create + ctx := droplet.NewContext() + upstream := &entity.Upstream{} + reqBody := `{ + "id": "1", + "nodes": [{ + "host": "httpbin.org", + "port": 80, + "weight": 1 + }], + "type": "roundrobin", + "pass_host": "node" + }` + err := json.Unmarshal([]byte(reqBody), upstream) + assert.Nil(t, err) + ctx.SetInput(upstream) + _, err = upstreamHandler.Create(ctx) + assert.Nil(t, err) + + //sleep + time.Sleep(time.Duration(20) * time.Millisecond) + + //get + input := &GetInput{} + input.ID = "1" + ctx.SetInput(input) + ret, err := upstreamHandler.Get(ctx) + stored := ret.(*entity.Upstream) + assert.Nil(t, err) + assert.Equal(t, stored.ID, upstream.ID) +} From 081db8e8f0807e13481b4f41214a38e2cf33fac2 Mon Sep 17 00:00:00 2001 From: nic-chen Date: Mon, 9 Nov 2020 21:26:07 +0800 Subject: [PATCH 4/5] fix: CI --- api/internal/handler/upstream/upstream_test.go | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/api/internal/handler/upstream/upstream_test.go b/api/internal/handler/upstream/upstream_test.go index e09dda6b4a..8f5505c300 100644 --- a/api/internal/handler/upstream/upstream_test.go +++ b/api/internal/handler/upstream/upstream_test.go @@ -193,7 +193,7 @@ func TestUpstream_Pass_Host(t *testing.T) { ctx := droplet.NewContext() upstream := &entity.Upstream{} reqBody := `{ - "id": "1", + "id": "2", "nodes": [{ "host": "httpbin.org", "port": 80, @@ -219,4 +219,14 @@ func TestUpstream_Pass_Host(t *testing.T) { stored := ret.(*entity.Upstream) assert.Nil(t, err) assert.Equal(t, stored.ID, upstream.ID) + + //delete test data + inputDel := &BatchDelete{} + reqBody = `{"ids": "2"}` + err = json.Unmarshal([]byte(reqBody), inputDel) + assert.Nil(t, err) + ctx.SetInput(inputDel) + _, err = upstreamHandler.BatchDelete(ctx) + assert.Nil(t, err) + } From c3f624838501b090bc71d6fa9e3147a598ac9d0a Mon Sep 17 00:00:00 2001 From: nic-chen Date: Mon, 9 Nov 2020 21:45:35 +0800 Subject: [PATCH 5/5] fix: CI fail --- api/internal/handler/upstream/upstream_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/internal/handler/upstream/upstream_test.go b/api/internal/handler/upstream/upstream_test.go index 8f5505c300..f562c0de9f 100644 --- a/api/internal/handler/upstream/upstream_test.go +++ b/api/internal/handler/upstream/upstream_test.go @@ -213,7 +213,7 @@ func TestUpstream_Pass_Host(t *testing.T) { //get input := &GetInput{} - input.ID = "1" + input.ID = "2" ctx.SetInput(input) ret, err := upstreamHandler.Get(ctx) stored := ret.(*entity.Upstream)