mirror of
https://github.com/oauth2-proxy/oauth2-proxy.git
synced 2025-01-26 05:27:28 +02:00
6fb3274ca3
Reorganized the structure of the Request Utils due to their widespread use resulting in circular imports issues (mostly because of middleware & logger).
132 lines
3.3 KiB
Go
132 lines
3.3 KiB
Go
package util_test
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
|
|
"github.com/oauth2-proxy/oauth2-proxy/v7/pkg/apis/middleware"
|
|
"github.com/oauth2-proxy/oauth2-proxy/v7/pkg/requests/util"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
)
|
|
|
|
var _ = Describe("Util Suite", func() {
|
|
const (
|
|
proto = "http"
|
|
host = "www.oauth2proxy.test"
|
|
uri = "/test/endpoint"
|
|
)
|
|
var req *http.Request
|
|
|
|
BeforeEach(func() {
|
|
req = httptest.NewRequest(
|
|
http.MethodGet,
|
|
fmt.Sprintf("%s://%s%s", proto, host, uri),
|
|
nil,
|
|
)
|
|
})
|
|
|
|
Context("GetRequestHost", func() {
|
|
Context("IsProxied is false", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{})
|
|
})
|
|
|
|
It("returns the host", func() {
|
|
Expect(util.GetRequestHost(req)).To(Equal(host))
|
|
})
|
|
|
|
It("ignores X-Forwarded-Host and returns the host", func() {
|
|
req.Header.Add("X-Forwarded-Host", "external.oauth2proxy.text")
|
|
Expect(util.GetRequestHost(req)).To(Equal(host))
|
|
})
|
|
})
|
|
|
|
Context("IsProxied is true", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{
|
|
ReverseProxy: true,
|
|
})
|
|
})
|
|
|
|
It("returns the host if X-Forwarded-Host is not present", func() {
|
|
Expect(util.GetRequestHost(req)).To(Equal(host))
|
|
})
|
|
|
|
It("returns the X-Forwarded-Host when present", func() {
|
|
req.Header.Add("X-Forwarded-Host", "external.oauth2proxy.text")
|
|
Expect(util.GetRequestHost(req)).To(Equal("external.oauth2proxy.text"))
|
|
})
|
|
})
|
|
})
|
|
|
|
Context("GetRequestProto", func() {
|
|
Context("IsProxied is false", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{})
|
|
})
|
|
|
|
It("returns the scheme", func() {
|
|
Expect(util.GetRequestProto(req)).To(Equal(proto))
|
|
})
|
|
|
|
It("ignores X-Forwarded-Proto and returns the scheme", func() {
|
|
req.Header.Add("X-Forwarded-Proto", "https")
|
|
Expect(util.GetRequestProto(req)).To(Equal(proto))
|
|
})
|
|
})
|
|
|
|
Context("IsProxied is true", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{
|
|
ReverseProxy: true,
|
|
})
|
|
})
|
|
|
|
It("returns the scheme if X-Forwarded-Proto is not present", func() {
|
|
Expect(util.GetRequestProto(req)).To(Equal(proto))
|
|
})
|
|
|
|
It("returns the X-Forwarded-Proto when present", func() {
|
|
req.Header.Add("X-Forwarded-Proto", "https")
|
|
Expect(util.GetRequestProto(req)).To(Equal("https"))
|
|
})
|
|
})
|
|
})
|
|
|
|
Context("GetRequestURI", func() {
|
|
Context("IsProxied is false", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{})
|
|
})
|
|
|
|
It("returns the URI", func() {
|
|
Expect(util.GetRequestURI(req)).To(Equal(uri))
|
|
})
|
|
|
|
It("ignores X-Forwarded-Uri and returns the URI", func() {
|
|
req.Header.Add("X-Forwarded-Uri", "/some/other/path")
|
|
Expect(util.GetRequestURI(req)).To(Equal(uri))
|
|
})
|
|
})
|
|
|
|
Context("IsProxied is true", func() {
|
|
BeforeEach(func() {
|
|
req = middleware.AddRequestScope(req, &middleware.RequestScope{
|
|
ReverseProxy: true,
|
|
})
|
|
})
|
|
|
|
It("returns the URI if X-Forwarded-Uri is not present", func() {
|
|
Expect(util.GetRequestURI(req)).To(Equal(uri))
|
|
})
|
|
|
|
It("returns the X-Forwarded-Uri when present", func() {
|
|
req.Header.Add("X-Forwarded-Uri", "/some/other/path")
|
|
Expect(util.GetRequestURI(req)).To(Equal("/some/other/path"))
|
|
})
|
|
})
|
|
})
|
|
})
|