2015-01-13 00:02:07 +02:00
|
|
|
package authboss
|
|
|
|
|
2015-01-15 05:18:45 +02:00
|
|
|
import (
|
2015-02-21 09:01:45 +02:00
|
|
|
"bytes"
|
2015-01-15 05:18:45 +02:00
|
|
|
"errors"
|
2015-02-21 09:01:45 +02:00
|
|
|
"strings"
|
2015-01-15 05:18:45 +02:00
|
|
|
"testing"
|
|
|
|
)
|
2015-01-13 00:02:07 +02:00
|
|
|
|
|
|
|
func TestCallbacks(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
ab := New()
|
2015-01-13 00:02:07 +02:00
|
|
|
afterCalled := false
|
|
|
|
beforeCalled := false
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.Before(EventRegister, func(ctx *Context) (Interrupt, error) {
|
2015-01-13 00:02:07 +02:00
|
|
|
beforeCalled = true
|
2015-02-22 07:03:03 +02:00
|
|
|
return InterruptNone, nil
|
2015-01-13 00:02:07 +02:00
|
|
|
})
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.After(EventRegister, func(ctx *Context) error {
|
2015-01-13 00:02:07 +02:00
|
|
|
afterCalled = true
|
2015-02-20 14:03:22 +02:00
|
|
|
return nil
|
2015-01-13 00:02:07 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
if beforeCalled || afterCalled {
|
|
|
|
t.Error("Neither should be called.")
|
|
|
|
}
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
interrupt, err := ab.Callbacks.FireBefore(EventRegister, ab.NewContext())
|
2015-01-13 00:02:07 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Error("Unexpected error:", err)
|
|
|
|
}
|
2015-02-22 07:03:03 +02:00
|
|
|
if interrupt != InterruptNone {
|
2015-02-20 14:03:22 +02:00
|
|
|
t.Error("It should not have been stopped.")
|
|
|
|
}
|
2015-01-13 00:02:07 +02:00
|
|
|
|
|
|
|
if !beforeCalled {
|
|
|
|
t.Error("Expected before to have been called.")
|
|
|
|
}
|
|
|
|
if afterCalled {
|
|
|
|
t.Error("Expected after not to be called.")
|
|
|
|
}
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.FireAfter(EventRegister, ab.NewContext())
|
2015-01-13 00:02:07 +02:00
|
|
|
if !afterCalled {
|
|
|
|
t.Error("Expected after to be called.")
|
|
|
|
}
|
|
|
|
}
|
2015-01-15 05:18:45 +02:00
|
|
|
|
|
|
|
func TestCallbacksInterrupt(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
ab := New()
|
2015-01-15 05:18:45 +02:00
|
|
|
before1 := false
|
|
|
|
before2 := false
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.Before(EventRegister, func(ctx *Context) (Interrupt, error) {
|
2015-02-20 14:03:22 +02:00
|
|
|
before1 = true
|
2015-02-22 07:03:03 +02:00
|
|
|
return InterruptAccountLocked, nil
|
2015-02-20 14:03:22 +02:00
|
|
|
})
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.Before(EventRegister, func(ctx *Context) (Interrupt, error) {
|
2015-02-20 14:03:22 +02:00
|
|
|
before2 = true
|
2015-02-22 07:03:03 +02:00
|
|
|
return InterruptNone, nil
|
2015-02-20 14:03:22 +02:00
|
|
|
})
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
interrupt, err := ab.Callbacks.FireBefore(EventRegister, ab.NewContext())
|
2015-02-20 14:03:22 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2015-02-22 07:03:03 +02:00
|
|
|
if interrupt != InterruptAccountLocked {
|
|
|
|
t.Error("The interrupt signal was not account locked:", interrupt)
|
2015-02-20 14:03:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if !before1 {
|
|
|
|
t.Error("Before1 should have been called.")
|
|
|
|
}
|
|
|
|
if before2 {
|
|
|
|
t.Error("Before2 should not have been called.")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-02-21 09:01:45 +02:00
|
|
|
func TestCallbacksBeforeErrors(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
ab := New()
|
2015-02-21 09:01:45 +02:00
|
|
|
log := &bytes.Buffer{}
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.LogWriter = log
|
2015-02-20 14:03:22 +02:00
|
|
|
before1 := false
|
|
|
|
before2 := false
|
|
|
|
|
2015-02-21 09:01:45 +02:00
|
|
|
errValue := errors.New("Problem occured")
|
2015-01-15 05:18:45 +02:00
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.Before(EventRegister, func(ctx *Context) (Interrupt, error) {
|
2015-01-15 05:18:45 +02:00
|
|
|
before1 = true
|
2015-02-22 07:03:03 +02:00
|
|
|
return InterruptNone, errValue
|
2015-01-15 05:18:45 +02:00
|
|
|
})
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.Before(EventRegister, func(ctx *Context) (Interrupt, error) {
|
2015-01-15 05:18:45 +02:00
|
|
|
before2 = true
|
2015-02-22 07:03:03 +02:00
|
|
|
return InterruptNone, nil
|
2015-01-15 05:18:45 +02:00
|
|
|
})
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
interrupt, err := ab.Callbacks.FireBefore(EventRegister, ab.NewContext())
|
2015-01-15 05:18:45 +02:00
|
|
|
if err != errValue {
|
|
|
|
t.Error("Expected an error to come back.")
|
|
|
|
}
|
2015-02-22 07:03:03 +02:00
|
|
|
if interrupt != InterruptNone {
|
2015-02-21 09:10:18 +02:00
|
|
|
t.Error("It should not have been stopped.")
|
2015-02-20 14:03:22 +02:00
|
|
|
}
|
2015-01-15 05:18:45 +02:00
|
|
|
|
|
|
|
if !before1 {
|
|
|
|
t.Error("Before1 should have been called.")
|
|
|
|
}
|
|
|
|
if before2 {
|
|
|
|
t.Error("Before2 should not have been called.")
|
|
|
|
}
|
2015-02-21 09:01:45 +02:00
|
|
|
|
|
|
|
if estr := log.String(); !strings.Contains(estr, errValue.Error()) {
|
|
|
|
t.Error("Error string wrong:", estr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCallbacksAfterErrors(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2015-02-21 09:01:45 +02:00
|
|
|
log := &bytes.Buffer{}
|
2015-03-31 21:34:03 +02:00
|
|
|
ab := New()
|
|
|
|
ab.LogWriter = log
|
2015-02-21 09:01:45 +02:00
|
|
|
after1 := false
|
|
|
|
after2 := false
|
|
|
|
|
|
|
|
errValue := errors.New("Problem occured")
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.After(EventRegister, func(ctx *Context) error {
|
2015-02-21 09:01:45 +02:00
|
|
|
after1 = true
|
|
|
|
return errValue
|
|
|
|
})
|
2015-03-31 21:34:03 +02:00
|
|
|
ab.Callbacks.After(EventRegister, func(ctx *Context) error {
|
2015-02-21 09:01:45 +02:00
|
|
|
after2 = true
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
2015-03-31 21:34:03 +02:00
|
|
|
err := ab.Callbacks.FireAfter(EventRegister, ab.NewContext())
|
2015-02-21 09:01:45 +02:00
|
|
|
if err != errValue {
|
|
|
|
t.Error("Expected an error to come back.")
|
|
|
|
}
|
|
|
|
|
|
|
|
if !after1 {
|
|
|
|
t.Error("After1 should have been called.")
|
|
|
|
}
|
|
|
|
if after2 {
|
|
|
|
t.Error("After2 should not have been called.")
|
|
|
|
}
|
|
|
|
|
|
|
|
if estr := log.String(); !strings.Contains(estr, errValue.Error()) {
|
|
|
|
t.Error("Error string wrong:", estr)
|
|
|
|
}
|
2015-01-15 05:18:45 +02:00
|
|
|
}
|
2015-02-22 07:03:03 +02:00
|
|
|
|
|
|
|
func TestEventString(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2015-02-22 07:03:03 +02:00
|
|
|
tests := []struct {
|
|
|
|
ev Event
|
|
|
|
str string
|
|
|
|
}{
|
|
|
|
{EventRegister, "EventRegister"},
|
|
|
|
{EventAuth, "EventAuth"},
|
2015-03-14 01:23:43 +02:00
|
|
|
{EventOAuth, "EventOAuth"},
|
2015-02-22 07:03:03 +02:00
|
|
|
{EventAuthFail, "EventAuthFail"},
|
2015-03-14 01:23:43 +02:00
|
|
|
{EventOAuthFail, "EventOAuthFail"},
|
2015-02-22 07:03:03 +02:00
|
|
|
{EventRecoverStart, "EventRecoverStart"},
|
|
|
|
{EventRecoverEnd, "EventRecoverEnd"},
|
|
|
|
{EventGet, "EventGet"},
|
2015-03-02 06:40:09 +02:00
|
|
|
{EventGetUserSession, "EventGetUserSession"},
|
2015-03-06 06:05:47 +02:00
|
|
|
{EventPasswordReset, "EventPasswordReset"},
|
2015-02-22 07:03:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, test := range tests {
|
|
|
|
if got := test.ev.String(); got != test.str {
|
|
|
|
t.Errorf("%d) Wrong string for Event(%d) expected: %v got: %s", i, test.ev, test.str, got)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestInterruptString(t *testing.T) {
|
2015-03-31 21:34:03 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2015-02-22 07:03:03 +02:00
|
|
|
tests := []struct {
|
|
|
|
in Interrupt
|
|
|
|
str string
|
|
|
|
}{
|
|
|
|
{InterruptNone, "InterruptNone"},
|
|
|
|
{InterruptAccountLocked, "InterruptAccountLocked"},
|
|
|
|
{InterruptAccountNotConfirmed, "InterruptAccountNotConfirmed"},
|
2015-02-22 10:24:57 +02:00
|
|
|
{InterruptSessionExpired, "InterruptSessionExpired"},
|
2015-02-22 07:03:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, test := range tests {
|
|
|
|
if got := test.in.String(); got != test.str {
|
|
|
|
t.Errorf("%d) Wrong string for Event(%d) expected: %v got: %s", i, test.in, test.str, got)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|