2019-05-06 13:33:33 +00:00
|
|
|
package sessions_test
|
|
|
|
|
|
|
|
import (
|
2019-05-06 21:34:43 +00:00
|
|
|
"net/http"
|
2019-05-06 13:33:33 +00:00
|
|
|
"testing"
|
2019-05-06 21:34:43 +00:00
|
|
|
"time"
|
2019-05-06 13:33:33 +00:00
|
|
|
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
"github.com/pusher/oauth2_proxy/pkg/apis/options"
|
2019-05-06 21:34:43 +00:00
|
|
|
sessionsapi "github.com/pusher/oauth2_proxy/pkg/apis/sessions"
|
2019-05-06 13:33:33 +00:00
|
|
|
"github.com/pusher/oauth2_proxy/pkg/sessions"
|
|
|
|
"github.com/pusher/oauth2_proxy/pkg/sessions/cookie"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestSessionStore(t *testing.T) {
|
|
|
|
RegisterFailHandler(Fail)
|
|
|
|
RunSpecs(t, "SessionStore")
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ = Describe("NewSessionStore", func() {
|
|
|
|
var opts *options.SessionOptions
|
|
|
|
var cookieOpts *options.CookieOptions
|
|
|
|
|
2019-05-06 21:34:43 +00:00
|
|
|
var request *http.Request
|
|
|
|
var response http.ResponseWriter
|
|
|
|
var session *sessionsapi.SessionState
|
|
|
|
|
|
|
|
CheckCookieOptions := func() {
|
|
|
|
Context("the cookies returned", func() {
|
|
|
|
var cookies []*http.Cookie
|
|
|
|
BeforeEach(func() {
|
|
|
|
req := http.Request{}
|
|
|
|
req.Header.Add("Cookie", response.Header().Get("Set-Cookie"))
|
|
|
|
cookies = req.Cookies()
|
|
|
|
})
|
|
|
|
|
|
|
|
It("have the correct name set", func() {
|
|
|
|
if len(cookies) == 1 {
|
|
|
|
Expect(cookies[0].Name).To(Equal(cookieOpts.CookieName))
|
|
|
|
} else {
|
|
|
|
for _, cookie := range cookies {
|
|
|
|
Expect(cookie.Name).To(ContainSubstring(cookieOpts.CookieName))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
It("have the correct path set", func() {
|
|
|
|
for _, cookie := range cookies {
|
|
|
|
Expect(cookie.Path).To(Equal(cookieOpts.CookiePath))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
It("have the correct domain set", func() {
|
|
|
|
for _, cookie := range cookies {
|
|
|
|
Expect(cookie.Domain).To(Equal(cookieOpts.CookieDomain))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
It("have the correct HTTPOnly set", func() {
|
|
|
|
for _, cookie := range cookies {
|
|
|
|
Expect(cookie.HttpOnly).To(Equal(cookieOpts.CookieHTTPOnly))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
It("have the correct secure set", func() {
|
|
|
|
for _, cookie := range cookies {
|
|
|
|
Expect(cookie.Secure).To(Equal(cookieOpts.CookieSecure))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
RunCookieTests := func() {
|
|
|
|
var ss sessionsapi.SessionStore
|
|
|
|
|
|
|
|
Context("with default options", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
var err error
|
|
|
|
ss, err = sessions.NewSessionStore(opts, cookieOpts)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("when SaveSession is called", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
err := ss.SaveSession(response, request, session)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("sets a `set-cookie` header in the response", func() {
|
|
|
|
Expect(response.Header().Get("Set-Cookie")).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
CheckCookieOptions()
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("when ClearSession is called", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
err := ss.ClearSession(response, request)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("sets a `set-cookie` header in the response", func() {
|
|
|
|
Expect(response.Header().Get("set-cookie")).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
CheckCookieOptions()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("with non-default options", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
cookieOpts = &options.CookieOptions{
|
|
|
|
CookieName: "_cookie_name",
|
|
|
|
CookiePath: "/path",
|
|
|
|
CookieExpire: time.Duration(72) * time.Hour,
|
|
|
|
CookieRefresh: time.Duration(3600),
|
|
|
|
CookieSecure: false,
|
|
|
|
CookieHTTPOnly: false,
|
|
|
|
CookieDomain: "example.com",
|
|
|
|
}
|
|
|
|
|
|
|
|
var err error
|
|
|
|
ss, err = sessions.NewSessionStore(opts, cookieOpts)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("when SaveSession is called", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
err := ss.SaveSession(response, request, session)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("sets a `set-cookie` header in the response", func() {
|
|
|
|
Expect(response.Header().Get("Set-Cookie")).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
CheckCookieOptions()
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("when ClearSession is called", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
err := ss.ClearSession(response, request)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("sets a `set-cookie` header in the response", func() {
|
|
|
|
Expect(response.Header().Get("set-cookie")).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
CheckCookieOptions()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-05-06 13:33:33 +00:00
|
|
|
BeforeEach(func() {
|
|
|
|
opts = &options.SessionOptions{}
|
2019-05-06 21:34:43 +00:00
|
|
|
|
|
|
|
// Set default options in CookieOptions
|
|
|
|
cookieOpts = &options.CookieOptions{
|
|
|
|
CookieName: "_oauth2_proxy",
|
|
|
|
CookiePath: "/",
|
|
|
|
CookieExpire: time.Duration(168) * time.Hour,
|
|
|
|
CookieRefresh: time.Duration(0),
|
|
|
|
CookieSecure: true,
|
|
|
|
CookieHTTPOnly: true,
|
|
|
|
}
|
2019-05-06 13:33:33 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
Context("with type 'cookie'", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
opts.Type = options.CookieSessionStoreType
|
|
|
|
})
|
|
|
|
|
2019-05-06 21:34:43 +00:00
|
|
|
It("creates a cookie.SessionStore", func() {
|
2019-05-06 13:33:33 +00:00
|
|
|
ss, err := sessions.NewSessionStore(opts, cookieOpts)
|
|
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
Expect(ss).To(BeAssignableToTypeOf(&cookie.SessionStore{}))
|
|
|
|
})
|
2019-05-06 21:34:43 +00:00
|
|
|
|
|
|
|
Context("the cookie.SessionStore", func() {
|
|
|
|
RunCookieTests()
|
|
|
|
})
|
2019-05-06 13:33:33 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
Context("with an invalid type", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
opts.Type = "invalid-type"
|
|
|
|
})
|
|
|
|
|
|
|
|
It("returns an error", func() {
|
|
|
|
ss, err := sessions.NewSessionStore(opts, cookieOpts)
|
|
|
|
Expect(err).To(HaveOccurred())
|
|
|
|
Expect(err.Error()).To(Equal("unknown session store type 'invalid-type'"))
|
|
|
|
Expect(ss).To(BeNil())
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|