Files
photoprism/internal/form/oauth_create_token_test.go
2024-07-02 12:54:56 +02:00

208 lines
4.7 KiB
Go

package form
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/photoprism/photoprism/pkg/authn"
)
func TestOAuthCreateToken_Validate(t *testing.T) {
t.Run("Valid", func(t *testing.T) {
m := OAuthCreateToken{
ClientID: "cs5gfen1bgxz7s9i",
ClientSecret: "abc",
Scope: "*",
}
assert.NoError(t, m.Validate())
assert.Equal(t, "*", m.CleanScope())
})
t.Run("GrantType", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantClientCredentials,
ClientID: "cs5gfen1bgxz7s9i",
ClientSecret: "abc",
Scope: "*",
}
assert.NoError(t, m.Validate())
assert.Equal(t, "*", m.CleanScope())
})
t.Run("NoClientID", func(t *testing.T) {
m := OAuthCreateToken{
ClientID: "",
ClientSecret: "Alice123!",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("InvalidClientID", func(t *testing.T) {
m := OAuthCreateToken{
ClientID: "s5gfen1bgxz7s9i",
ClientSecret: "Alice123!",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("NoSecret", func(t *testing.T) {
m := OAuthCreateToken{
ClientID: "cs5gfen1bgxz7s9i",
ClientSecret: "",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("InvalidSecret", func(t *testing.T) {
m := OAuthCreateToken{
ClientID: "cs5gfen1bgxz7s9i",
ClientSecret: "abc 123",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordSuccess", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "admin",
Password: "cs5gfen1bgxz7s9i",
ClientName: "test",
Scope: "*",
}
assert.NoError(t, m.Validate())
})
t.Run("GrantTypePasswordUsernameRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "",
Password: "abcdefg",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordUsernameTooLong", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "aaaaabbbbbccccdddddfffffrrrrrttttttyyyyssssssssssdddddllllloooooooooowerty",
Password: "abcdefg",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordPasswordRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "admin",
Password: "",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordPasswordTooLong", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "admin",
Password: "aaaaabbbbbccccdddddfffffrrrrrttttttyyyyssssssssssdddddllllloooooooooowerty",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordClientRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "admin",
Password: "cs5gfen1bgxz7s9i",
ClientName: "",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypePasswordScopeRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantPassword,
Username: "admin",
Password: "cs5gfen1bgxz7s9i",
ClientName: "test",
Scope: "",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypeSessionSuccess", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantSession,
Username: "admin",
ClientName: "test",
Scope: "*",
}
assert.NoError(t, m.Validate())
})
t.Run("GrantTypeSessionUsernameRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantSession,
Username: "",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypeSessionClientRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantSession,
Username: "admin",
ClientName: "",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypeSessionUsernameTooLong", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantSession,
Username: "aaaaabbbbbccccdddddfffffrrrrrttttttyyyyssssssssssdddddllllloooooooooowert",
ClientName: "test",
Scope: "*",
}
assert.Error(t, m.Validate())
})
t.Run("GrantTypeSessionScopeRequired", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: authn.GrantSession,
Username: "admin",
ClientName: "test",
Scope: "",
}
assert.Error(t, m.Validate())
})
t.Run("InvalidGrantType", func(t *testing.T) {
m := OAuthCreateToken{
GrantType: "invalid",
Username: "admin",
Password: "cs5gfen1bgxz7s9i",
ClientName: "test",
Scope: "",
}
assert.Error(t, m.Validate())
})
}