mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-26 13:16:28 +08:00 
			
		
		
		
	 908136c557
			
		
	
	908136c557
	
	
	
		
			
			* add configuration option to restrict users by default * default IsRestricted permission only set on sign up setting this in the model messes with other workflows (e.g. syncing LDAP users) where the IsRestricted permission needs to be explicitly set and not overridden by a config value * fix formatting * Apply suggestions from code review * ensure newly created user is set to restricted * ensure imports are in the correct order Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package integrations
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"net/http"
 | |
| 	"strings"
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/unknwon/i18n"
 | |
| )
 | |
| 
 | |
| func TestSignup(t *testing.T) {
 | |
| 	defer prepareTestEnv(t)()
 | |
| 
 | |
| 	setting.Service.EnableCaptcha = false
 | |
| 
 | |
| 	req := NewRequestWithValues(t, "POST", "/user/sign_up", map[string]string{
 | |
| 		"user_name": "exampleUser",
 | |
| 		"email":     "exampleUser@example.com",
 | |
| 		"password":  "examplePassword!1",
 | |
| 		"retype":    "examplePassword!1",
 | |
| 	})
 | |
| 	MakeRequest(t, req, http.StatusFound)
 | |
| 
 | |
| 	// should be able to view new user's page
 | |
| 	req = NewRequest(t, "GET", "/exampleUser")
 | |
| 	MakeRequest(t, req, http.StatusOK)
 | |
| }
 | |
| 
 | |
| func TestSignupAsRestricted(t *testing.T) {
 | |
| 	defer prepareTestEnv(t)()
 | |
| 
 | |
| 	setting.Service.EnableCaptcha = false
 | |
| 	setting.Service.DefaultUserIsRestricted = true
 | |
| 
 | |
| 	req := NewRequestWithValues(t, "POST", "/user/sign_up", map[string]string{
 | |
| 		"user_name": "restrictedUser",
 | |
| 		"email":     "restrictedUser@example.com",
 | |
| 		"password":  "examplePassword!1",
 | |
| 		"retype":    "examplePassword!1",
 | |
| 	})
 | |
| 	MakeRequest(t, req, http.StatusFound)
 | |
| 
 | |
| 	// should be able to view new user's page
 | |
| 	req = NewRequest(t, "GET", "/restrictedUser")
 | |
| 	MakeRequest(t, req, http.StatusOK)
 | |
| 
 | |
| 	user2 := models.AssertExistsAndLoadBean(t, &models.User{Name: "restrictedUser"}).(*models.User)
 | |
| 	assert.True(t, user2.IsRestricted)
 | |
| }
 | |
| 
 | |
| func TestSignupEmail(t *testing.T) {
 | |
| 	defer prepareTestEnv(t)()
 | |
| 
 | |
| 	setting.Service.EnableCaptcha = false
 | |
| 
 | |
| 	tests := []struct {
 | |
| 		email      string
 | |
| 		wantStatus int
 | |
| 		wantMsg    string
 | |
| 	}{
 | |
| 		{"exampleUser@example.com\r\n", http.StatusOK, i18n.Tr("en", "form.email_invalid", nil)},
 | |
| 		{"exampleUser@example.com\r", http.StatusOK, i18n.Tr("en", "form.email_invalid", nil)},
 | |
| 		{"exampleUser@example.com\n", http.StatusOK, i18n.Tr("en", "form.email_invalid", nil)},
 | |
| 		{"exampleUser@example.com", http.StatusFound, ""},
 | |
| 	}
 | |
| 
 | |
| 	for i, test := range tests {
 | |
| 		req := NewRequestWithValues(t, "POST", "/user/sign_up", map[string]string{
 | |
| 			"user_name": fmt.Sprintf("exampleUser%d", i),
 | |
| 			"email":     test.email,
 | |
| 			"password":  "examplePassword!1",
 | |
| 			"retype":    "examplePassword!1",
 | |
| 		})
 | |
| 		resp := MakeRequest(t, req, test.wantStatus)
 | |
| 		if test.wantMsg != "" {
 | |
| 			htmlDoc := NewHTMLParser(t, resp.Body)
 | |
| 			assert.Equal(t,
 | |
| 				test.wantMsg,
 | |
| 				strings.TrimSpace(htmlDoc.doc.Find(".ui.message").Text()),
 | |
| 			)
 | |
| 		}
 | |
| 	}
 | |
| }
 |