sessionstore_test.go 3.9 KB

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