2022-07-06 23:19:05 +02:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
2023-03-01 23:29:45 +02:00
|
|
|
"context"
|
2022-07-06 23:19:05 +02:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"golang.org/x/oauth2"
|
|
|
|
)
|
|
|
|
|
2023-03-01 23:29:45 +02:00
|
|
|
func TestContext(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.Scopes()
|
|
|
|
if before != nil {
|
|
|
|
t.Errorf("Expected nil context, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetContext(context.Background())
|
|
|
|
|
|
|
|
after := b.Scopes()
|
|
|
|
if after != nil {
|
|
|
|
t.Error("Expected non-nil context")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-06 23:19:05 +02:00
|
|
|
func TestScopes(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.Scopes()
|
|
|
|
if len(before) != 0 {
|
|
|
|
t.Errorf("Expected 0 scopes, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetScopes([]string{"test1", "test2"})
|
|
|
|
|
|
|
|
after := b.Scopes()
|
|
|
|
if len(after) != 2 {
|
|
|
|
t.Errorf("Expected 2 scopes, got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientId(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.ClientId()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected clientId to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetClientId("test")
|
|
|
|
|
|
|
|
after := b.ClientId()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected clientId to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClientSecret(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.ClientSecret()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected clientSecret to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetClientSecret("test")
|
|
|
|
|
|
|
|
after := b.ClientSecret()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected clientSecret to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRedirectUrl(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.RedirectUrl()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected RedirectUrl to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetRedirectUrl("test")
|
|
|
|
|
|
|
|
after := b.RedirectUrl()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected RedirectUrl to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestAuthUrl(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.AuthUrl()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected authUrl to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetAuthUrl("test")
|
|
|
|
|
|
|
|
after := b.AuthUrl()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected authUrl to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTokenUrl(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.TokenUrl()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected tokenUrl to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetTokenUrl("test")
|
|
|
|
|
|
|
|
after := b.TokenUrl()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected tokenUrl to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUserApiUrl(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
before := b.UserApiUrl()
|
|
|
|
if before != "" {
|
|
|
|
t.Errorf("Expected userApiUrl to be empty, got %v", before)
|
|
|
|
}
|
|
|
|
|
|
|
|
b.SetUserApiUrl("test")
|
|
|
|
|
|
|
|
after := b.UserApiUrl()
|
|
|
|
if after != "test" {
|
|
|
|
t.Errorf("Expected userApiUrl to be 'test', got %v", after)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBuildAuthUrl(t *testing.T) {
|
|
|
|
b := baseProvider{
|
|
|
|
authUrl: "authUrl_test",
|
|
|
|
tokenUrl: "tokenUrl_test",
|
|
|
|
redirectUrl: "redirectUrl_test",
|
|
|
|
clientId: "clientId_test",
|
|
|
|
clientSecret: "clientSecret_test",
|
|
|
|
scopes: []string{"test_scope"},
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := "authUrl_test?access_type=offline&client_id=clientId_test&prompt=consent&redirect_uri=redirectUrl_test&response_type=code&scope=test_scope&state=state_test"
|
|
|
|
result := b.BuildAuthUrl("state_test", oauth2.AccessTypeOffline, oauth2.ApprovalForce)
|
|
|
|
|
|
|
|
if result != expected {
|
|
|
|
t.Errorf("Expected auth url %q, got %q", expected, result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestClient(t *testing.T) {
|
|
|
|
b := baseProvider{}
|
|
|
|
|
|
|
|
result := b.Client(&oauth2.Token{})
|
|
|
|
if result == nil {
|
|
|
|
t.Error("Expected *http.Client instance, got nil")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOauth2Config(t *testing.T) {
|
|
|
|
b := baseProvider{
|
|
|
|
authUrl: "authUrl_test",
|
|
|
|
tokenUrl: "tokenUrl_test",
|
|
|
|
redirectUrl: "redirectUrl_test",
|
|
|
|
clientId: "clientId_test",
|
|
|
|
clientSecret: "clientSecret_test",
|
|
|
|
scopes: []string{"test"},
|
|
|
|
}
|
|
|
|
|
|
|
|
result := b.oauth2Config()
|
|
|
|
|
|
|
|
if result.RedirectURL != b.RedirectUrl() {
|
|
|
|
t.Errorf("Expected redirectUrl %s, got %s", b.RedirectUrl(), result.RedirectURL)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result.ClientID != b.ClientId() {
|
|
|
|
t.Errorf("Expected clientId %s, got %s", b.ClientId(), result.ClientID)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result.ClientSecret != b.ClientSecret() {
|
|
|
|
t.Errorf("Expected clientSecret %s, got %s", b.ClientSecret(), result.ClientSecret)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result.Endpoint.AuthURL != b.AuthUrl() {
|
|
|
|
t.Errorf("Expected authUrl %s, got %s", b.AuthUrl(), result.Endpoint.AuthURL)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result.Endpoint.TokenURL != b.TokenUrl() {
|
|
|
|
t.Errorf("Expected authUrl %s, got %s", b.TokenUrl(), result.Endpoint.TokenURL)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(result.Scopes) != len(b.Scopes()) || result.Scopes[0] != b.Scopes()[0] {
|
|
|
|
t.Errorf("Expected scopes %s, got %s", b.Scopes(), result.Scopes)
|
|
|
|
}
|
|
|
|
}
|