mirror of
https://github.com/volatiletech/authboss.git
synced 2025-01-12 04:23:16 +02:00
180 lines
4.4 KiB
Go
180 lines
4.4 KiB
Go
package response
|
|
|
|
import (
|
|
"html/template"
|
|
"io/ioutil"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"gopkg.in/authboss.v0"
|
|
"gopkg.in/authboss.v0/internal/mocks"
|
|
)
|
|
|
|
var testViewTemplate = template.Must(template.New("").Parse(`{{.external}} {{.fun}} {{.flash_success}} {{.flash_error}} {{.xsrfName}} {{.xsrfToken}}`))
|
|
var testEmailHTMLTemplate = template.Must(template.New("").Parse(`<h2>{{.}}</h2>`))
|
|
var testEmailPlainTemplate = template.Must(template.New("").Parse(`i am a {{.}}`))
|
|
|
|
func TestLoadTemplates(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
file, err := ioutil.TempFile(os.TempDir(), "authboss")
|
|
if err != nil {
|
|
t.Error("Unexpected error:", err)
|
|
}
|
|
if _, err := file.Write([]byte("{{.Val}}")); err != nil {
|
|
t.Error("Error writing to temp file", err)
|
|
}
|
|
|
|
layout, err := template.New("").Parse(`<strong>{{template "authboss" .}}</strong>`)
|
|
if err != nil {
|
|
t.Error("Unexpected error:", err)
|
|
}
|
|
|
|
filename := filepath.Base(file.Name())
|
|
|
|
tpls, err := LoadTemplates(authboss.New(), layout, filepath.Dir(file.Name()), filename)
|
|
if err != nil {
|
|
t.Error("Unexpected error:", err)
|
|
}
|
|
|
|
if len(tpls) != 1 {
|
|
t.Error("Expected 1 template:", len(tpls))
|
|
}
|
|
|
|
if _, ok := tpls[filename]; !ok {
|
|
t.Error("Expected tpl with name:", filename)
|
|
}
|
|
}
|
|
|
|
func TestTemplates_Render(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
cookies := mocks.NewMockClientStorer()
|
|
ab := authboss.New()
|
|
ab.LayoutDataMaker = func(_ http.ResponseWriter, _ *http.Request) authboss.HTMLData {
|
|
return authboss.HTMLData{"fun": "is"}
|
|
}
|
|
ab.XSRFName = "do you think"
|
|
ab.XSRFMaker = func(_ http.ResponseWriter, _ *http.Request) string {
|
|
return "that's air you're breathing now?"
|
|
}
|
|
|
|
// Set up flashes
|
|
cookies.Put(authboss.FlashSuccessKey, "no")
|
|
cookies.Put(authboss.FlashErrorKey, "spoon")
|
|
|
|
r, _ := http.NewRequest("GET", "http://localhost", nil)
|
|
w := httptest.NewRecorder()
|
|
ctx, _ := ab.ContextFromRequest(r)
|
|
ctx.SessionStorer = cookies
|
|
|
|
tpls := Templates{
|
|
"hello": testViewTemplate,
|
|
}
|
|
|
|
err := tpls.Render(ctx, w, r, "hello", authboss.HTMLData{"external": "there"})
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
if w.Body.String() != "there is no spoon do you think that's air you're breathing now?" {
|
|
t.Error("Body was wrong:", w.Body.String())
|
|
}
|
|
}
|
|
|
|
func Test_Email(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
ab := authboss.New()
|
|
mockMailer := &mocks.MockMailer{}
|
|
ab.Mailer = mockMailer
|
|
|
|
htmlTpls := Templates{"html": testEmailHTMLTemplate}
|
|
textTpls := Templates{"plain": testEmailPlainTemplate}
|
|
|
|
email := authboss.Email{
|
|
To: []string{"a@b.c"},
|
|
}
|
|
|
|
err := Email(ab.Mailer, email, htmlTpls, "html", textTpls, "plain", "spoon")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
if len(mockMailer.Last.To) != 1 {
|
|
t.Error("Expected 1 to addr")
|
|
}
|
|
if mockMailer.Last.To[0] != "a@b.c" {
|
|
t.Error("Unexpected to addr @ 0:", mockMailer.Last.To[0])
|
|
}
|
|
|
|
if mockMailer.Last.HTMLBody != "<h2>spoon</h2>" {
|
|
t.Error("Unexpected HTMLBody:", mockMailer.Last.HTMLBody)
|
|
}
|
|
|
|
if mockMailer.Last.TextBody != "i am a spoon" {
|
|
t.Error("Unexpected TextBody:", mockMailer.Last.TextBody)
|
|
}
|
|
}
|
|
|
|
func TestRedirect(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
ab := authboss.New()
|
|
cookies := mocks.NewMockClientStorer()
|
|
|
|
r, _ := http.NewRequest("GET", "http://localhost", nil)
|
|
w := httptest.NewRecorder()
|
|
ctx, _ := ab.ContextFromRequest(r)
|
|
ctx.SessionStorer = cookies
|
|
|
|
Redirect(ctx, w, r, "/", "success", "failure", false)
|
|
|
|
if w.Code != http.StatusFound {
|
|
t.Error("Expected a redirect.")
|
|
}
|
|
|
|
if w.Header().Get("Location") != "/" {
|
|
t.Error("Expected to be redirected to root.")
|
|
}
|
|
|
|
if val, _ := cookies.Get(authboss.FlashSuccessKey); val != "success" {
|
|
t.Error("Flash success msg wrong:", val)
|
|
}
|
|
if val, _ := cookies.Get(authboss.FlashErrorKey); val != "failure" {
|
|
t.Error("Flash failure msg wrong:", val)
|
|
}
|
|
}
|
|
|
|
func TestRedirect_Override(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
ab := authboss.New()
|
|
cookies := mocks.NewMockClientStorer()
|
|
|
|
r, _ := http.NewRequest("GET", "http://localhost?redir=foo/bar", nil)
|
|
w := httptest.NewRecorder()
|
|
ctx, _ := ab.ContextFromRequest(r)
|
|
ctx.SessionStorer = cookies
|
|
|
|
Redirect(ctx, w, r, "/shouldNotGo", "success", "failure", true)
|
|
|
|
if w.Code != http.StatusFound {
|
|
t.Error("Expected a redirect.")
|
|
}
|
|
|
|
if w.Header().Get("Location") != "/foo/bar" {
|
|
t.Error("Expected to be redirected to root.")
|
|
}
|
|
|
|
if val, _ := cookies.Get(authboss.FlashSuccessKey); val != "success" {
|
|
t.Error("Flash success msg wrong:", val)
|
|
}
|
|
if val, _ := cookies.Get(authboss.FlashErrorKey); val != "failure" {
|
|
t.Error("Flash failure msg wrong:", val)
|
|
}
|
|
}
|