feat: optimize transformer go wasm plugin (#712)

This commit is contained in:
Uncle-Justice
2024-01-22 13:40:55 +08:00
committed by GitHub
parent d3d000753d
commit 879192cf99
5 changed files with 1413 additions and 510 deletions

View File

@@ -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"]
}
`),
},