2017-04-12 08:27:57 -04:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
2015-09-16 15:49:12 -04:00
|
|
|
// See License.txt for license information.
|
|
|
|
|
|
|
|
|
|
package model
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"strings"
|
|
|
|
|
"testing"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestAuthJson(t *testing.T) {
|
|
|
|
|
a1 := AuthData{}
|
|
|
|
|
a1.ClientId = NewId()
|
|
|
|
|
a1.UserId = NewId()
|
|
|
|
|
a1.Code = NewId()
|
|
|
|
|
|
|
|
|
|
json := a1.ToJson()
|
|
|
|
|
ra1 := AuthDataFromJson(strings.NewReader(json))
|
|
|
|
|
|
|
|
|
|
if a1.Code != ra1.Code {
|
|
|
|
|
t.Fatal("codes didn't match")
|
|
|
|
|
}
|
2017-04-20 09:55:02 -04:00
|
|
|
|
|
|
|
|
a2 := AuthorizeRequest{}
|
|
|
|
|
a2.ClientId = NewId()
|
|
|
|
|
a2.Scope = NewId()
|
|
|
|
|
|
|
|
|
|
json = a2.ToJson()
|
|
|
|
|
ra2 := AuthorizeRequestFromJson(strings.NewReader(json))
|
|
|
|
|
|
|
|
|
|
if a2.ClientId != ra2.ClientId {
|
|
|
|
|
t.Fatal("client ids didn't match")
|
|
|
|
|
}
|
2015-09-16 15:49:12 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestAuthPreSave(t *testing.T) {
|
|
|
|
|
a1 := AuthData{}
|
|
|
|
|
a1.ClientId = NewId()
|
|
|
|
|
a1.UserId = NewId()
|
|
|
|
|
a1.Code = NewId()
|
|
|
|
|
a1.PreSave()
|
|
|
|
|
a1.IsExpired()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestAuthIsValid(t *testing.T) {
|
|
|
|
|
|
|
|
|
|
ad := AuthData{}
|
|
|
|
|
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-03 14:37:58 -03:00
|
|
|
ad.ClientId = NewRandomString(28)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed Client Id")
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-16 15:49:12 -04:00
|
|
|
ad.ClientId = NewId()
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-03 14:37:58 -03:00
|
|
|
ad.UserId = NewRandomString(28)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed User Id")
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-16 15:49:12 -04:00
|
|
|
ad.UserId = NewId()
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-03 14:37:58 -03:00
|
|
|
ad.Code = NewRandomString(129)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed Code to long")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.Code = ""
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed Code not set")
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-16 15:49:12 -04:00
|
|
|
ad.Code = NewId()
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-03 14:37:58 -03:00
|
|
|
ad.ExpiresIn = 0
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed invalid ExpiresIn")
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-16 15:49:12 -04:00
|
|
|
ad.ExpiresIn = 1
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-03 14:37:58 -03:00
|
|
|
ad.CreateAt = 0
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed Invalid Create At")
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-16 15:49:12 -04:00
|
|
|
ad.CreateAt = 1
|
2017-04-03 14:37:58 -03:00
|
|
|
if err := ad.IsValid(); err == nil {
|
2015-09-16 15:49:12 -04:00
|
|
|
t.Fatal()
|
|
|
|
|
}
|
2017-04-03 14:37:58 -03:00
|
|
|
|
|
|
|
|
ad.State = NewRandomString(129)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed invalid State")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.State = NewRandomString(128)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.Scope = NewRandomString(129)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed invalid Scope")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.Scope = NewRandomString(128)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.RedirectUri = ""
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed Redirect URI not set")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.RedirectUri = NewRandomString(28)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed invalid URL")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.RedirectUri = NewRandomString(257)
|
|
|
|
|
if err := ad.IsValid(); err == nil {
|
|
|
|
|
t.Fatal("Should have failed invalid URL")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ad.RedirectUri = "http://example.com"
|
|
|
|
|
if err := ad.IsValid(); err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
2015-09-16 15:49:12 -04:00
|
|
|
}
|