123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- // Copyright 2018 The Gogs Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package forms
-
- import (
- "strconv"
- "testing"
-
- auth_model "code.gitea.io/gitea/models/auth"
- "code.gitea.io/gitea/modules/setting"
-
- "github.com/gobwas/glob"
- "github.com/stretchr/testify/assert"
- )
-
- func TestRegisterForm_IsDomainAllowed_Empty(t *testing.T) {
- oldService := setting.Service
- defer func() {
- setting.Service = oldService
- }()
-
- setting.Service.EmailDomainAllowList = nil
-
- form := RegisterForm{}
-
- assert.True(t, form.IsEmailDomainAllowed())
- }
-
- func TestRegisterForm_IsDomainAllowed_InvalidEmail(t *testing.T) {
- oldService := setting.Service
- defer func() {
- setting.Service = oldService
- }()
-
- setting.Service.EmailDomainAllowList = []glob.Glob{glob.MustCompile("gitea.io")}
-
- tt := []struct {
- email string
- }{
- {"invalid-email"},
- {"gitea.io"},
- }
-
- for _, v := range tt {
- form := RegisterForm{Email: v.email}
-
- assert.False(t, form.IsEmailDomainAllowed())
- }
- }
-
- func TestRegisterForm_IsDomainAllowed_AllowedEmail(t *testing.T) {
- oldService := setting.Service
- defer func() {
- setting.Service = oldService
- }()
-
- setting.Service.EmailDomainAllowList = []glob.Glob{glob.MustCompile("gitea.io"), glob.MustCompile("*.allow")}
-
- tt := []struct {
- email string
- valid bool
- }{
- {"security@gitea.io", true},
- {"security@gITea.io", true},
- {"invalid", false},
- {"seee@example.com", false},
-
- {"user@my.allow", true},
- {"user@my.allow1", false},
- }
-
- for _, v := range tt {
- form := RegisterForm{Email: v.email}
-
- assert.Equal(t, v.valid, form.IsEmailDomainAllowed())
- }
- }
-
- func TestRegisterForm_IsDomainAllowed_BlockedEmail(t *testing.T) {
- oldService := setting.Service
- defer func() {
- setting.Service = oldService
- }()
-
- setting.Service.EmailDomainAllowList = nil
- setting.Service.EmailDomainBlockList = []glob.Glob{glob.MustCompile("gitea.io"), glob.MustCompile("*.block")}
-
- tt := []struct {
- email string
- valid bool
- }{
- {"security@gitea.io", false},
- {"security@gitea.example", true},
- {"invalid", true},
-
- {"user@my.block", false},
- {"user@my.block1", true},
- }
-
- for _, v := range tt {
- form := RegisterForm{Email: v.email}
-
- assert.Equal(t, v.valid, form.IsEmailDomainAllowed())
- }
- }
-
- func TestNewAccessTokenForm_GetScope(t *testing.T) {
- tests := []struct {
- form NewAccessTokenForm
- scope auth_model.AccessTokenScope
- expectedErr error
- }{
- {
- form: NewAccessTokenForm{Name: "test", Scope: []string{"read:repository"}},
- scope: "read:repository",
- },
- {
- form: NewAccessTokenForm{Name: "test", Scope: []string{"read:repository", "write:user"}},
- scope: "read:repository,write:user",
- },
- }
-
- for i, test := range tests {
- t.Run(strconv.Itoa(i), func(t *testing.T) {
- scope, err := test.form.GetScope()
- assert.Equal(t, test.expectedErr, err)
- assert.Equal(t, test.scope, scope)
- })
- }
- }
|