mirror of
https://github.com/oauth2-proxy/oauth2-proxy.git
synced 2025-01-24 05:26:55 +02:00
602dac7852
* Use a specialized ResponseWriter in middleware * Track User & Upstream in RequestScope * Wrap responses in our custom ResponseWriter * Add tests for logging middleware * Inject upstream metadata into request scope * Use custom ResponseWriter only in logging middleware * Assume RequestScope is never nil
64 lines
1.7 KiB
Go
64 lines
1.7 KiB
Go
package upstream
|
|
|
|
import (
|
|
"crypto/rand"
|
|
"io"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"os"
|
|
|
|
middlewareapi "github.com/oauth2-proxy/oauth2-proxy/v7/pkg/apis/middleware"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/ginkgo/extensions/table"
|
|
. "github.com/onsi/gomega"
|
|
)
|
|
|
|
var _ = Describe("File Server Suite", func() {
|
|
var dir string
|
|
var handler http.Handler
|
|
var id string
|
|
|
|
const (
|
|
foo = "foo"
|
|
bar = "bar"
|
|
baz = "baz"
|
|
pageNotFound = "404 page not found\n"
|
|
)
|
|
|
|
BeforeEach(func() {
|
|
// Generate a random id before each test to check the GAP-Upstream-Address
|
|
// is being set correctly
|
|
idBytes := make([]byte, 16)
|
|
_, err := io.ReadFull(rand.Reader, idBytes)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
id = string(idBytes)
|
|
|
|
handler = newFileServer(id, "/files", filesDir)
|
|
})
|
|
|
|
AfterEach(func() {
|
|
Expect(os.RemoveAll(dir)).To(Succeed())
|
|
})
|
|
|
|
DescribeTable("fileServer ServeHTTP",
|
|
func(requestPath string, expectedResponseCode int, expectedBody string) {
|
|
req := httptest.NewRequest("", requestPath, nil)
|
|
req = middlewareapi.AddRequestScope(req, &middlewareapi.RequestScope{})
|
|
|
|
rw := httptest.NewRecorder()
|
|
handler.ServeHTTP(rw, req)
|
|
|
|
scope := middlewareapi.GetRequestScope(req)
|
|
Expect(scope.Upstream).To(Equal(id))
|
|
|
|
Expect(rw.Code).To(Equal(expectedResponseCode))
|
|
Expect(rw.Body.String()).To(Equal(expectedBody))
|
|
},
|
|
Entry("for file foo", "/files/foo", 200, foo),
|
|
Entry("for file bar", "/files/bar", 200, bar),
|
|
Entry("for file foo/baz", "/files/subdir/baz", 200, baz),
|
|
Entry("for a non-existent file inside the path", "/files/baz", 404, pageNotFound),
|
|
Entry("for a non-existent file oustide the path", "/baz", 404, pageNotFound),
|
|
)
|
|
})
|