sessionstore_test.go 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. package sessionstore_test
  2. import (
  3. "encoding/base64"
  4. "net/http"
  5. "testing"
  6. "github.com/gorilla/securecookie"
  7. "github.com/gorilla/sessions"
  8. "github.com/porter-dev/porter/internal/repository/test"
  9. "github.com/porter-dev/porter/internal/auth/sessionstore"
  10. )
  11. type headerOnlyResponseWriter http.Header
  12. func (ho headerOnlyResponseWriter) Header() http.Header {
  13. return http.Header(ho)
  14. }
  15. func (ho headerOnlyResponseWriter) Write([]byte) (int, error) {
  16. panic("NOIMPL")
  17. }
  18. func (ho headerOnlyResponseWriter) WriteHeader(int) {
  19. panic("NOIMPL")
  20. }
  21. var secret = "secret"
  22. func TestPGStore(t *testing.T) {
  23. repo := test.NewRepository(true)
  24. ss, err := sessionstore.NewStore(
  25. &sessionstore.NewStoreOpts{
  26. SessionRepository: repo.Session(),
  27. CookieSecrets: []string{"secret"},
  28. },
  29. )
  30. if err != nil {
  31. t.Fatal("Failed to get store", err)
  32. }
  33. // ROUND 1 - Check that the cookie is being saved
  34. req, err := http.NewRequest("GET", "http://www.example.com", nil)
  35. if err != nil {
  36. t.Fatal("failed to create request", err)
  37. }
  38. session, err := ss.Get(req, "mysess")
  39. if err != nil {
  40. t.Fatal("failed to get session", err.Error())
  41. }
  42. session.Values["counter"] = 1
  43. m := make(http.Header)
  44. if err = ss.Save(req, headerOnlyResponseWriter(m), session); err != nil {
  45. t.Fatal("Failed to save session:", err.Error())
  46. }
  47. if m["Set-Cookie"][0][0:6] != "mysess" {
  48. t.Fatal("Cookie wasn't set!")
  49. }
  50. // ROUND 2 - check that the cookie can be retrieved
  51. req, err = http.NewRequest("GET", "http://www.example.com", nil)
  52. if err != nil {
  53. t.Fatal("failed to create round 2 request", err)
  54. }
  55. encoded, err := securecookie.EncodeMulti(session.Name(), session.ID, ss.Codecs...)
  56. if err != nil {
  57. t.Fatal("Failed to make cookie value", err)
  58. }
  59. req.AddCookie(sessions.NewCookie(session.Name(), encoded, session.Options))
  60. session, err = ss.Get(req, "mysess")
  61. if err != nil {
  62. t.Fatal("failed to get round 2 session", err.Error())
  63. }
  64. if session.Values["counter"] != 1 {
  65. t.Fatal("Retrieved session had wrong value:", session.Values["counter"])
  66. }
  67. session.Values["counter"] = 9 // set new value for round 3
  68. if err = ss.Save(req, headerOnlyResponseWriter(m), session); err != nil {
  69. t.Fatal("Failed to save session:", err.Error())
  70. }
  71. // ROUND 2 - check that the cookie has been updated
  72. req, err = http.NewRequest("GET", "http://www.example.com", nil)
  73. if err != nil {
  74. t.Fatal("failed to create round 3 request", err)
  75. }
  76. req.AddCookie(sessions.NewCookie(session.Name(), encoded, session.Options))
  77. session, err = ss.Get(req, "mysess")
  78. if err != nil {
  79. t.Fatal("failed to get session round 3", err.Error())
  80. }
  81. if session.Values["counter"] != 9 {
  82. t.Fatal("Retrieved session had wrong value in round 3:", session.Values["counter"])
  83. }
  84. // ROUND 3 - Increase max length
  85. req, err = http.NewRequest("GET", "http://www.example.com", nil)
  86. if err != nil {
  87. t.Fatal("failed to create round 3 request", err)
  88. }
  89. req.AddCookie(sessions.NewCookie(session.Name(), encoded, session.Options))
  90. session, err = ss.New(req, "my session")
  91. if err != nil {
  92. t.Fatal("failed to create session", err)
  93. }
  94. session.Values["big"] = make([]byte, base64.StdEncoding.DecodedLen(4096*2))
  95. if err = ss.Save(req, headerOnlyResponseWriter(m), session); err == nil {
  96. t.Fatal("expected an error, got nil")
  97. }
  98. ss.MaxLength(4096 * 3) // A bit more than the value size to account for encoding overhead.
  99. if err = ss.Save(req, headerOnlyResponseWriter(m), session); err != nil {
  100. t.Fatal("Failed to save session:", err.Error())
  101. }
  102. }
  103. func TestSessionOptionsAreUniquePerSession(t *testing.T) {
  104. repo := test.NewRepository(true)
  105. ss, err := sessionstore.NewStore(
  106. &sessionstore.NewStoreOpts{
  107. SessionRepository: repo.Session(),
  108. CookieSecrets: []string{"secret"},
  109. },
  110. )
  111. if err != nil {
  112. t.Fatal("Failed to get store", err)
  113. }
  114. ss.Options.MaxAge = 900
  115. req, err := http.NewRequest("GET", "http://www.example.com", nil)
  116. if err != nil {
  117. t.Fatal("Failed to create request", err)
  118. }
  119. session, err := ss.Get(req, "newsess")
  120. if err != nil {
  121. t.Fatal("Failed to create session", err)
  122. }
  123. session.Options.MaxAge = -1
  124. if ss.Options.MaxAge != 900 {
  125. t.Fatalf("PGStore.Options.MaxAge: expected %d, got %d", 900, ss.Options.MaxAge)
  126. }
  127. }