2022-04-22 17:23:14 -07:00
|
|
|
package fediverse
|
|
|
|
|
2022-10-02 14:16:46 -04:00
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
2022-12-23 20:20:59 -08:00
|
|
|
|
|
|
|
"github.com/owncast/owncast/utils"
|
2022-10-02 14:16:46 -04:00
|
|
|
)
|
2022-04-22 17:23:14 -07:00
|
|
|
|
|
|
|
const (
|
|
|
|
accessToken = "fake-access-token"
|
|
|
|
account = "blah"
|
|
|
|
userID = "fake-user-id"
|
|
|
|
userDisplayName = "fake-user-display-name"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestOTPFlowValidation(t *testing.T) {
|
2022-12-23 20:20:59 -08:00
|
|
|
r, success, err := RegisterFediverseOTP(accessToken, userID, userDisplayName, account)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2022-08-02 13:29:06 -07:00
|
|
|
|
|
|
|
if !success {
|
|
|
|
t.Error("Registration should be permitted.")
|
|
|
|
}
|
2022-04-22 17:23:14 -07:00
|
|
|
|
|
|
|
if r.Code == "" {
|
|
|
|
t.Error("Code is empty")
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.Account != account {
|
|
|
|
t.Error("Account is not set correctly")
|
|
|
|
}
|
|
|
|
|
|
|
|
if r.Timestamp.IsZero() {
|
|
|
|
t.Error("Timestamp is empty")
|
|
|
|
}
|
|
|
|
|
|
|
|
valid, registration := ValidateFediverseOTP(accessToken, r.Code)
|
|
|
|
if !valid {
|
|
|
|
t.Error("Code is not valid")
|
|
|
|
}
|
|
|
|
|
|
|
|
if registration.Account != account {
|
|
|
|
t.Error("Account is not set correctly")
|
|
|
|
}
|
|
|
|
|
|
|
|
if registration.UserID != userID {
|
|
|
|
t.Error("UserID is not set correctly")
|
|
|
|
}
|
|
|
|
|
|
|
|
if registration.UserDisplayName != userDisplayName {
|
|
|
|
t.Error("UserDisplayName is not set correctly")
|
|
|
|
}
|
|
|
|
}
|
2022-08-02 13:29:06 -07:00
|
|
|
|
|
|
|
func TestSingleOTPFlowRequest(t *testing.T) {
|
2022-12-23 20:20:59 -08:00
|
|
|
r1, _, _ := RegisterFediverseOTP(accessToken, userID, userDisplayName, account)
|
|
|
|
r2, s2, _ := RegisterFediverseOTP(accessToken, userID, userDisplayName, account)
|
2022-08-02 13:29:06 -07:00
|
|
|
|
|
|
|
if r1.Code != r2.Code {
|
|
|
|
t.Error("Only one registration should be permitted.")
|
|
|
|
}
|
|
|
|
|
|
|
|
if s2 {
|
|
|
|
t.Error("Second registration should not be permitted.")
|
|
|
|
}
|
|
|
|
}
|
2022-10-02 14:16:46 -04:00
|
|
|
|
|
|
|
func TestAccountCaseInsensitive(t *testing.T) {
|
|
|
|
account := "Account"
|
|
|
|
accessToken := "another-fake-access-token"
|
2022-12-23 20:20:59 -08:00
|
|
|
r1, _, _ := RegisterFediverseOTP(accessToken, userID, userDisplayName, account)
|
2022-10-02 14:16:46 -04:00
|
|
|
_, reg1 := ValidateFediverseOTP(accessToken, r1.Code)
|
|
|
|
|
|
|
|
// Simulate second auth with account in different case
|
2022-12-23 20:20:59 -08:00
|
|
|
r2, _, _ := RegisterFediverseOTP(accessToken, userID, userDisplayName, strings.ToUpper(account))
|
2022-10-02 14:16:46 -04:00
|
|
|
_, reg2 := ValidateFediverseOTP(accessToken, r2.Code)
|
|
|
|
|
|
|
|
if reg1.Account != reg2.Account {
|
|
|
|
t.Errorf("Account names should be case-insensitive: %s %s", reg1.Account, reg2.Account)
|
|
|
|
}
|
|
|
|
}
|
2022-12-23 20:20:59 -08:00
|
|
|
|
|
|
|
func TestLimitGlobalPendingRequests(t *testing.T) {
|
|
|
|
for i := 0; i < maxPendingRequests-1; i++ {
|
|
|
|
at, _ := utils.GenerateRandomString(10)
|
|
|
|
uid, _ := utils.GenerateRandomString(10)
|
|
|
|
account, _ := utils.GenerateRandomString(10)
|
|
|
|
|
|
|
|
_, success, error := RegisterFediverseOTP(at, uid, "userDisplayName", account)
|
|
|
|
if !success {
|
|
|
|
t.Error("Registration should be permitted.", i, " of ", len(pendingAuthRequests))
|
|
|
|
}
|
|
|
|
if error != nil {
|
|
|
|
t.Error(error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This one should fail
|
|
|
|
at, _ := utils.GenerateRandomString(10)
|
|
|
|
uid, _ := utils.GenerateRandomString(10)
|
|
|
|
account, _ := utils.GenerateRandomString(10)
|
|
|
|
_, success, error := RegisterFediverseOTP(at, uid, "userDisplayName", account)
|
|
|
|
if success {
|
|
|
|
t.Error("Registration should not be permitted.")
|
|
|
|
}
|
|
|
|
if error == nil {
|
|
|
|
t.Error("Error should be returned.")
|
|
|
|
}
|
|
|
|
}
|