mirror of
https://github.com/alibaba/higress.git
synced 2026-06-09 04:37:31 +08:00
feat: optimize transformer go wasm plugin (#712)
This commit is contained in:
@@ -113,27 +113,216 @@ var WasmPluginsTransformer = suite.ConformanceTest{
|
||||
},
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 4: request body transformer",
|
||||
TestCaseName: "case 3: req&resp bothway header&query transformer",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo3.com",
|
||||
Path: "/get/index.html?k1=v11&k1=v12&k2=v2",
|
||||
Headers: map[string]string{
|
||||
"X-remove": "exist",
|
||||
"X-not-renamed": "test",
|
||||
"X-replace": "not-replaced",
|
||||
"X-dedupe-first": "1,2,3",
|
||||
"X-dedupe-last": "a,b,c",
|
||||
"X-dedupe-unique": "1,2,3,3,2,1",
|
||||
},
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo3.com",
|
||||
Path: "/get/index.html?k2-new=v2-new&k3=v31&k3=v32&k4=v31",
|
||||
Headers: map[string]string{
|
||||
"X-renamed": "test",
|
||||
"X-replace": "replaced",
|
||||
"X-add-append": "add,append", // header with same name
|
||||
"X-map": "add,append",
|
||||
"X-dedupe-first": "1",
|
||||
"X-dedupe-last": "c",
|
||||
"X-dedupe-unique": "1,2,3",
|
||||
},
|
||||
},
|
||||
AbsentHeaders: []string{"X-remove"},
|
||||
},
|
||||
},
|
||||
Response: http.AssertionResponse{
|
||||
AdditionalResponseHeaders: map[string]string{
|
||||
"X-remove": "exist",
|
||||
"X-not-renamed": "test",
|
||||
"X-replace": "not-replaced",
|
||||
},
|
||||
ExpectedResponse: http.Response{
|
||||
StatusCode: 200,
|
||||
Headers: map[string]string{
|
||||
"X-renamed": "test",
|
||||
"X-replace": "replace-get", // regexp matches path and replace "replace-$1"
|
||||
"X-add-append": "add-foo3,append-index", // regexp matches host and replace "add-$1"
|
||||
"X-map": "add-foo3,append-index",
|
||||
},
|
||||
AbsentHeaders: []string{"X-remove"},
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 4: request transformer with arbitary order",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo4.com",
|
||||
Path: "/get?k1=v11&k1=v12",
|
||||
Headers: map[string]string{
|
||||
"X-dedupe-first": "1,2,3",
|
||||
"X-dedupe-last": "a,b,c",
|
||||
"X-dedupe-unique": "1,2,3,3,2,1",
|
||||
},
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo4.com",
|
||||
Path: "/get?k2=v11&k2=v22&k3-new=v31",
|
||||
Headers: map[string]string{
|
||||
"X-add-append": "add",
|
||||
"X-map-dedupe-first": "1,append",
|
||||
"X-dedupe-last": "X-dedupe-last-replaced",
|
||||
"X-dedupe-unique-renamed": "1,2,3",
|
||||
},
|
||||
},
|
||||
AbsentHeaders: []string{"X-dedupe-first"},
|
||||
},
|
||||
},
|
||||
Response: http.AssertionResponse{
|
||||
ExpectedResponse: http.Response{
|
||||
StatusCode: 200,
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 5: response transformer with arbitary order",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo5.com",
|
||||
Path: "/get/index.html",
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo5.com",
|
||||
Path: "/get/index.html",
|
||||
},
|
||||
},
|
||||
},
|
||||
Response: http.AssertionResponse{
|
||||
AdditionalResponseHeaders: map[string]string{
|
||||
"X-remove": "exist",
|
||||
"X-not-renamed": "test",
|
||||
"X-replace": "not-replaced",
|
||||
},
|
||||
ExpectedResponse: http.Response{
|
||||
StatusCode: 200,
|
||||
Headers: map[string]string{
|
||||
"X-renamed": "test",
|
||||
"X-replace": "replace-get", // regexp matches path and replace "replace-$1"
|
||||
"X-add-append": "add-foo5,append-index", // regexp matches host and replace "add-$1"
|
||||
"X-map": "add-foo5",
|
||||
},
|
||||
AbsentHeaders: []string{"X-remove"},
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 6: request transformer, map from query to header",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo6.com",
|
||||
Path: "/get?kmap=vmap",
|
||||
Headers: map[string]string{},
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo6.com",
|
||||
Path: "/get?kmap=vmap",
|
||||
Headers: map[string]string{
|
||||
"X-map": "vmap",
|
||||
},
|
||||
},
|
||||
|
||||
},
|
||||
},
|
||||
Response: http.AssertionResponse{
|
||||
ExpectedResponse: http.Response{
|
||||
|
||||
StatusCode: 200,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 7: request transformer, map from header to query",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo7.com",
|
||||
Path: "/get",
|
||||
Headers: map[string]string{
|
||||
"X-map": "vmap",
|
||||
},
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo7.com",
|
||||
Path: "/get?kmap=vmap",
|
||||
Headers: map[string]string{
|
||||
"X-map": "vmap",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
Response: http.AssertionResponse{
|
||||
ExpectedResponse: http.Response{
|
||||
StatusCode: 200,
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 8: request body transformer",
|
||||
TargetBackend: "infra-backend-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo8.com",
|
||||
Path: "/post",
|
||||
// TODO(Uncle-Justice) dedupe, replace的body插件逻辑有问题,暂跳过测试
|
||||
Method: "POST",
|
||||
Body: []byte(`
|
||||
{
|
||||
"X-removed":["v1", "v2"],
|
||||
"X-not-renamed":["v1"]
|
||||
"X-not-renamed":["v1"],
|
||||
"X-to-be-mapped":["v1", "v2"]
|
||||
}
|
||||
`),
|
||||
ContentType: http.ContentTypeApplicationJson,
|
||||
},
|
||||
ExpectedRequest: &http.ExpectedRequest{
|
||||
Request: http.Request{
|
||||
Host: "foo4.com",
|
||||
Host: "foo8.com",
|
||||
Path: "/post",
|
||||
// TODO(Uncle-Justice) dedupe, replace的body插件逻辑有问题,暂跳过测试
|
||||
Method: "POST",
|
||||
@@ -142,7 +331,8 @@ var WasmPluginsTransformer = suite.ConformanceTest{
|
||||
{
|
||||
"X-renamed":["v1"],
|
||||
"X-add-append":["add","append"],
|
||||
"X-map":["add","append"]
|
||||
"X-to-be-mapped":["v1", "v2"],
|
||||
"X-map":["v1", "v2"]
|
||||
}
|
||||
`),
|
||||
},
|
||||
@@ -156,21 +346,22 @@ var WasmPluginsTransformer = suite.ConformanceTest{
|
||||
},
|
||||
{
|
||||
Meta: http.AssertionMeta{
|
||||
TestCaseName: "case 5: response json body transformer",
|
||||
TestCaseName: "case 9: response json body transformer",
|
||||
TargetBackend: "infra-backend-echo-body-v1",
|
||||
TargetNamespace: "higress-conformance-infra",
|
||||
CompareTarget: http.CompareTargetResponse,
|
||||
},
|
||||
Request: http.AssertionRequest{
|
||||
ActualRequest: http.Request{
|
||||
Host: "foo5.com",
|
||||
Host: "foo9.com",
|
||||
Path: "/post",
|
||||
// TODO(Uncle-Justice) dedupe, replace的body插件逻辑有问题,暂跳过测试
|
||||
Method: "POST",
|
||||
Body: []byte(`
|
||||
{
|
||||
"X-removed":["v1", "v2"],
|
||||
"X-not-renamed":["v1"]
|
||||
"X-not-renamed":["v1"],
|
||||
"X-to-be-mapped":["v1", "v2"]
|
||||
}
|
||||
`),
|
||||
ContentType: http.ContentTypeApplicationJson,
|
||||
@@ -184,7 +375,8 @@ var WasmPluginsTransformer = suite.ConformanceTest{
|
||||
{
|
||||
"X-renamed":["v1"],
|
||||
"X-add-append":["add","append"],
|
||||
"X-map":["add","append"]
|
||||
"X-to-be-mapped":["v1", "v2"],
|
||||
"X-map":["v1", "v2"]
|
||||
}
|
||||
`),
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user