From 2b54e2e4341d4d7d58814fc6221ef73aba049ebd Mon Sep 17 00:00:00 2001 From: husharp Date: Thu, 14 Sep 2023 09:39:22 +0800 Subject: [PATCH] test clean path Signed-off-by: husharp --- server/api/server_test.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/server/api/server_test.go b/server/api/server_test.go index 88253b3a6242..3d47f20e89e7 100644 --- a/server/api/server_test.go +++ b/server/api/server_test.go @@ -16,7 +16,9 @@ package api import ( "context" + "fmt" "net/http" + "net/http/httptest" "sort" "sync" "testing" @@ -210,3 +212,22 @@ func (suite *serviceTestSuite) TestServiceLabels() { apiutil.NewAccessPath("/pd/api/v1/metric/query", http.MethodGet)) suite.Equal("QueryMetric", serviceLabel) } + +func (suite *adminTestSuite) TestCleanPath() { + re := suite.Require() + // transfer path to /config + url := fmt.Sprintf("%s/admin/persist-file/../../config", suite.urlPrefix) + cfg := &config.Config{} + err := testutil.ReadGetJSON(re, testDialClient, url, cfg) + suite.NoError(err) + + // handled by router + response := httptest.NewRecorder() + r, _, _ := NewHandler(context.Background(), suite.svr) + request, err := http.NewRequest(http.MethodGet, url, nil) + re.NoError(err) + r.ServeHTTP(response, request) + // handled by `cleanPath` which is in `mux.ServeHTTP` + re.NotNil(response.Result().Header["Location"]) + re.Contains(response.Result().Header["Location"][0], "/pd/api/v1/config") +}