http_test.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. package lib
  2. import (
  3. "net/http"
  4. "net/http/httptest"
  5. "net/url"
  6. "testing"
  7. "github.com/TecharoHQ/anubis"
  8. "github.com/TecharoHQ/anubis/lib/policy"
  9. )
  10. func TestSetCookie(t *testing.T) {
  11. for _, tt := range []struct {
  12. name string
  13. host string
  14. cookieName string
  15. options Options
  16. }{
  17. {
  18. name: "basic",
  19. options: Options{},
  20. host: "",
  21. cookieName: anubis.CookieName,
  22. },
  23. {
  24. name: "domain techaro.lol",
  25. options: Options{CookieDomain: "techaro.lol"},
  26. host: "",
  27. cookieName: anubis.CookieName,
  28. },
  29. {
  30. name: "dynamic cookie domain",
  31. options: Options{CookieDynamicDomain: true},
  32. host: "techaro.lol",
  33. cookieName: anubis.CookieName,
  34. },
  35. } {
  36. t.Run(tt.name, func(t *testing.T) {
  37. srv := spawnAnubis(t, tt.options)
  38. rw := httptest.NewRecorder()
  39. srv.SetCookie(rw, CookieOpts{Value: "test", Host: tt.host})
  40. resp := rw.Result()
  41. cookies := resp.Cookies()
  42. ckie := cookies[0]
  43. if ckie.Name != tt.cookieName {
  44. t.Errorf("wanted cookie named %q, got cookie named %q", tt.cookieName, ckie.Name)
  45. }
  46. })
  47. }
  48. }
  49. func TestClearCookie(t *testing.T) {
  50. srv := spawnAnubis(t, Options{})
  51. rw := httptest.NewRecorder()
  52. srv.ClearCookie(rw, CookieOpts{Host: "localhost"})
  53. resp := rw.Result()
  54. cookies := resp.Cookies()
  55. if len(cookies) != 1 {
  56. t.Errorf("wanted 1 cookie, got %d cookies", len(cookies))
  57. }
  58. ckie := cookies[0]
  59. if ckie.Name != anubis.CookieName {
  60. t.Errorf("wanted cookie named %q, got cookie named %q", anubis.CookieName, ckie.Name)
  61. }
  62. if ckie.MaxAge != -1 {
  63. t.Errorf("wanted cookie max age of -1, got: %d", ckie.MaxAge)
  64. }
  65. }
  66. func TestClearCookieWithDomain(t *testing.T) {
  67. srv := spawnAnubis(t, Options{CookieDomain: "techaro.lol"})
  68. rw := httptest.NewRecorder()
  69. srv.ClearCookie(rw, CookieOpts{Host: "localhost"})
  70. resp := rw.Result()
  71. cookies := resp.Cookies()
  72. if len(cookies) != 1 {
  73. t.Errorf("wanted 1 cookie, got %d cookies", len(cookies))
  74. }
  75. ckie := cookies[0]
  76. if ckie.Name != anubis.CookieName {
  77. t.Errorf("wanted cookie named %q, got cookie named %q", anubis.CookieName, ckie.Name)
  78. }
  79. if ckie.MaxAge != -1 {
  80. t.Errorf("wanted cookie max age of -1, got: %d", ckie.MaxAge)
  81. }
  82. }
  83. func TestClearCookieWithDynamicDomain(t *testing.T) {
  84. srv := spawnAnubis(t, Options{CookieDynamicDomain: true})
  85. rw := httptest.NewRecorder()
  86. srv.ClearCookie(rw, CookieOpts{Host: "subdomain.xeiaso.net"})
  87. resp := rw.Result()
  88. cookies := resp.Cookies()
  89. if len(cookies) != 1 {
  90. t.Errorf("wanted 1 cookie, got %d cookies", len(cookies))
  91. }
  92. ckie := cookies[0]
  93. if ckie.Name != anubis.CookieName {
  94. t.Errorf("wanted cookie named %q, got cookie named %q", anubis.CookieName, ckie.Name)
  95. }
  96. if ckie.Domain != "xeiaso.net" {
  97. t.Errorf("wanted cookie domain %q, got cookie domain %q", "xeiaso.net", ckie.Domain)
  98. }
  99. if ckie.MaxAge != -1 {
  100. t.Errorf("wanted cookie max age of -1, got: %d", ckie.MaxAge)
  101. }
  102. }
  103. func TestRenderIndexRedirect(t *testing.T) {
  104. s := &Server{
  105. opts: Options{
  106. PublicUrl: "https://anubis.example.com",
  107. },
  108. }
  109. req := httptest.NewRequest("GET", "/", nil)
  110. req.Header.Set("X-Forwarded-Proto", "https")
  111. req.Header.Set("X-Forwarded-Host", "example.com")
  112. req.Header.Set("X-Forwarded-Uri", "/foo")
  113. rr := httptest.NewRecorder()
  114. s.RenderIndex(rr, req, policy.CheckResult{}, nil, true)
  115. if rr.Code != http.StatusTemporaryRedirect {
  116. t.Errorf("expected status %d, got %d", http.StatusTemporaryRedirect, rr.Code)
  117. }
  118. location := rr.Header().Get("Location")
  119. parsedURL, err := url.Parse(location)
  120. if err != nil {
  121. t.Fatalf("failed to parse location URL %q: %v", location, err)
  122. }
  123. scheme := "https"
  124. if parsedURL.Scheme != scheme {
  125. t.Errorf("expected scheme to be %q, got %q", scheme, parsedURL.Scheme)
  126. }
  127. host := "anubis.example.com"
  128. if parsedURL.Host != host {
  129. t.Errorf("expected url to be %q, got %q", host, parsedURL.Host)
  130. }
  131. redir := parsedURL.Query().Get("redir")
  132. expectedRedir := "https://example.com/foo"
  133. if redir != expectedRedir {
  134. t.Errorf("expected redir param to be %q, got %q", expectedRedir, redir)
  135. }
  136. }
  137. func TestRenderIndexUnauthorized(t *testing.T) {
  138. s := &Server{
  139. opts: Options{
  140. PublicUrl: "",
  141. },
  142. }
  143. req := httptest.NewRequest("GET", "/", nil)
  144. rr := httptest.NewRecorder()
  145. s.RenderIndex(rr, req, policy.CheckResult{}, nil, true)
  146. if rr.Code != http.StatusUnauthorized {
  147. t.Errorf("expected status %d, got %d", http.StatusUnauthorized, rr.Code)
  148. }
  149. if body := rr.Body.String(); body != "Authorization required" {
  150. t.Errorf("expected body %q, got %q", "Authorization required", body)
  151. }
  152. }