diff options
author | feistel <6742251-feistel@users.noreply.gitlab.com> | 2022-04-25 19:56:34 +0300 |
---|---|---|
committer | feistel <6742251-feistel@users.noreply.gitlab.com> | 2022-04-25 19:56:34 +0300 |
commit | f9754e61e392203d9dbb61cc2276373b90322e85 (patch) | |
tree | e4d56242aaee55666a0c1fe6187b490c0e1f0147 /internal/handlers/https_test.go | |
parent | 950512e00946a5d7df2d82cd6e2a4fe131c90659 (diff) |
Add early return and tests for internal/handlers/https
Diffstat (limited to 'internal/handlers/https_test.go')
-rw-r--r-- | internal/handlers/https_test.go | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/internal/handlers/https_test.go b/internal/handlers/https_test.go new file mode 100644 index 00000000..df78ecbd --- /dev/null +++ b/internal/handlers/https_test.go @@ -0,0 +1,58 @@ +package handlers_test + +import ( + "net/http" + "testing" + + "github.com/stretchr/testify/require" + + "gitlab.com/gitlab-org/gitlab-pages/internal/handlers" +) + +func TestAcmeMiddleware(t *testing.T) { + h := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + w.WriteHeader(http.StatusAccepted) + }) + + httpsURL := "https://example.com" + httpURL := "http://example.com" + + testCases := []struct { + name string + redirect bool + path string + expectedStatus int + }{ + { + name: "http redirects to https with redirect enabled", + redirect: true, + path: httpURL, + expectedStatus: http.StatusTemporaryRedirect, + }, + { + name: "https handled successfully with redirect enabled", + redirect: true, + path: httpsURL, + expectedStatus: http.StatusAccepted, + }, + { + name: "http does not redirect to https with redirect disabled", + redirect: false, + path: httpURL, + expectedStatus: http.StatusAccepted, + }, + { + name: "https handled successfully with redirect disabled", + redirect: false, + path: httpsURL, + expectedStatus: http.StatusAccepted, + }, + } + + for _, tc := range testCases { + t.Run(tc.name, func(t *testing.T) { + m := handlers.HTTPSRedirectMiddleware(h, tc.redirect) + require.HTTPStatusCode(t, m.ServeHTTP, http.MethodGet, tc.path, nil, tc.expectedStatus) + }) + } +} |