1
0
mirror of https://github.com/volatiletech/authboss.git synced 2025-01-24 05:17:10 +02:00
authboss/defaults/router_test.go
Aaron L d4f4f6c443 Rewrite auth module
Discovered many problems with the abstractions along the way
and did small fixes to get to the end of the auth module.

- Use more constants for random strings
- Create forcing functions to deal with the upgrades to different
  interfaces
2018-02-04 21:24:55 -08:00

84 lines
1.8 KiB
Go

package defaults
import (
"io/ioutil"
"net/http"
"net/http/httptest"
"strings"
"testing"
)
func TestRouter(t *testing.T) {
t.Parallel()
r := NewRouter()
var get, post, delete string
wantGet, wantPost, wantDelete := "testget", "testpost", "testdelete"
r.Get("/test", http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
b, err := ioutil.ReadAll(r.Body)
if err != nil {
panic(err)
}
get = string(b)
}))
r.Post("/test", http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
b, err := ioutil.ReadAll(r.Body)
if err != nil {
panic(err)
}
post = string(b)
}))
r.Delete("/test", http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
b, err := ioutil.ReadAll(r.Body)
if err != nil {
panic(err)
}
delete = string(b)
}))
wr := httptest.NewRecorder()
req := httptest.NewRequest("GET", "/test", strings.NewReader("testget"))
r.ServeHTTP(wr, req)
if get != wantGet {
t.Error("want:", wantGet, "got:", get)
}
if len(post) != 0 || len(delete) != 0 {
t.Error("should be empty:", post, delete)
}
wr = httptest.NewRecorder()
req = httptest.NewRequest("POST", "/test", strings.NewReader("testpost"))
r.ServeHTTP(wr, req)
if post != wantPost {
t.Error("want:", wantPost, "got:", post)
}
if len(delete) != 0 {
t.Error("should be empty:", delete)
}
wr = httptest.NewRecorder()
req = httptest.NewRequest("DELETE", "/test", strings.NewReader("testdelete"))
r.ServeHTTP(wr, req)
if delete != wantDelete {
t.Error("want:", wantDelete, "got:", delete)
}
}
func TestRouterBadMethod(t *testing.T) {
t.Parallel()
r := NewRouter()
wr := httptest.NewRecorder()
req := httptest.NewRequest("OPTIONS", "/", nil)
r.ServeHTTP(wr, req)
if wr.Code != http.StatusMethodNotAllowed {
t.Error("want method not allowed code, got:", wr.Code)
}
}