diff options
author | Vladimir Shushlin <v.shushlin@gmail.com> | 2021-01-05 17:41:40 +0300 |
---|---|---|
committer | Vladimir Shushlin <v.shushlin@gmail.com> | 2021-01-05 17:41:40 +0300 |
commit | ad8f7ff5423cde7b5f56d12b8fe592eb9b8193e0 (patch) | |
tree | be0d07c09f4c8b59c6217d0bf542161824627f89 /test/acceptance/serving_test.go | |
parent | e4ddf96500cab8587671147848e51da91ff6e300 (diff) | |
parent | 68a4f5bec4e3863c48b533c662839f4b3383a6b7 (diff) |
Merge branch 'master' into security-master
Diffstat (limited to 'test/acceptance/serving_test.go')
-rw-r--r-- | test/acceptance/serving_test.go | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/test/acceptance/serving_test.go b/test/acceptance/serving_test.go index da2843a0..66b5fa47 100644 --- a/test/acceptance/serving_test.go +++ b/test/acceptance/serving_test.go @@ -552,3 +552,22 @@ func doCrossOriginRequest(t *testing.T, spec ListenSpec, method, reqMethod, url rsp.Body.Close() return rsp } + +func TestQueryStringPersistedInSlashRewrite(t *testing.T) { + skipUnlessEnabled(t) + teardown := RunPagesProcess(t, *pagesBinary, listeners, "") + defer teardown() + + rsp, err := GetRedirectPage(t, httpsListener, "group.gitlab-example.com", "project?q=test") + require.NoError(t, err) + defer rsp.Body.Close() + + require.Equal(t, http.StatusFound, rsp.StatusCode) + require.Equal(t, 1, len(rsp.Header["Location"])) + require.Equal(t, "//group.gitlab-example.com/project/?q=test", rsp.Header.Get("Location")) + + rsp, err = GetPageFromListener(t, httpsListener, "group.gitlab-example.com", "project/?q=test") + require.NoError(t, err) + defer rsp.Body.Close() + require.Equal(t, http.StatusOK, rsp.StatusCode) +} |