Fix uppercase default branch bug (#1965)
This commit is contained in:
		
					parent
					
						
							
								96152c38b1
							
						
					
				
			
			
				commit
				
					
						5e92b82ac6
					
				
			
		
					 4 changed files with 65 additions and 3 deletions
				
			
		
							
								
								
									
										58
									
								
								integrations/change_default_branch_test.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								integrations/change_default_branch_test.go
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,58 @@
 | 
				
			||||||
 | 
					// 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 (
 | 
				
			||||||
 | 
						"bytes"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"net/http"
 | 
				
			||||||
 | 
						"net/url"
 | 
				
			||||||
 | 
						"testing"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"code.gitea.io/gitea/models"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/stretchr/testify/assert"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestChangeDefaultBranch(t *testing.T) {
 | 
				
			||||||
 | 
						prepareTestEnv(t)
 | 
				
			||||||
 | 
						repo := models.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
 | 
				
			||||||
 | 
						owner := models.AssertExistsAndLoadBean(t, &models.User{ID: repo.OwnerID}).(*models.User)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						session := loginUser(t, owner.Name, "password")
 | 
				
			||||||
 | 
						branchesURL := fmt.Sprintf("/%s/%s/settings/branches", owner.Name, repo.Name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						req := NewRequest(t, "GET", branchesURL)
 | 
				
			||||||
 | 
						resp := session.MakeRequest(t, req)
 | 
				
			||||||
 | 
						assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
 | 
				
			||||||
 | 
						doc, err := NewHtmlParser(resp.Body)
 | 
				
			||||||
 | 
						assert.NoError(t, err)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						req = NewRequestBody(t, "POST", branchesURL,
 | 
				
			||||||
 | 
							bytes.NewBufferString(url.Values{
 | 
				
			||||||
 | 
								"_csrf":  []string{doc.GetInputValueByName("_csrf")},
 | 
				
			||||||
 | 
								"action": []string{"default_branch"},
 | 
				
			||||||
 | 
								"branch": []string{"DefaultBranch"},
 | 
				
			||||||
 | 
							}.Encode()))
 | 
				
			||||||
 | 
						req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
 | 
				
			||||||
 | 
						resp = session.MakeRequest(t, req)
 | 
				
			||||||
 | 
						assert.EqualValues(t, http.StatusFound, resp.HeaderCode)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						req = NewRequest(t, "GET", branchesURL)
 | 
				
			||||||
 | 
						resp = session.MakeRequest(t, req)
 | 
				
			||||||
 | 
						assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
 | 
				
			||||||
 | 
						doc, err = NewHtmlParser(resp.Body)
 | 
				
			||||||
 | 
						assert.NoError(t, err)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						req = NewRequestBody(t, "POST", branchesURL,
 | 
				
			||||||
 | 
							bytes.NewBufferString(url.Values{
 | 
				
			||||||
 | 
								"_csrf":  []string{doc.GetInputValueByName("_csrf")},
 | 
				
			||||||
 | 
								"action": []string{"default_branch"},
 | 
				
			||||||
 | 
								"branch": []string{"does_not_exist"},
 | 
				
			||||||
 | 
							}.Encode()))
 | 
				
			||||||
 | 
						req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
 | 
				
			||||||
 | 
						resp = session.MakeRequest(t, req)
 | 
				
			||||||
 | 
						assert.EqualValues(t, http.StatusNotFound, resp.HeaderCode)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					65f1bf27bc3bf70f64657658635e66094edbcb4d
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					65f1bf27bc3bf70f64657658635e66094edbcb4d
 | 
				
			||||||
| 
						 | 
					@ -480,9 +480,11 @@ func ProtectedBranchPost(ctx *context.Context) {
 | 
				
			||||||
			return
 | 
								return
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		branch := strings.ToLower(ctx.Query("branch"))
 | 
							branch := ctx.Query("branch")
 | 
				
			||||||
		if ctx.Repo.GitRepo.IsBranchExist(branch) &&
 | 
							if !ctx.Repo.GitRepo.IsBranchExist(branch) {
 | 
				
			||||||
			repo.DefaultBranch != branch {
 | 
								ctx.Status(404)
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							} else if repo.DefaultBranch != branch {
 | 
				
			||||||
			repo.DefaultBranch = branch
 | 
								repo.DefaultBranch = branch
 | 
				
			||||||
			if err := ctx.Repo.GitRepo.SetDefaultBranch(branch); err != nil {
 | 
								if err := ctx.Repo.GitRepo.SetDefaultBranch(branch); err != nil {
 | 
				
			||||||
				if !git.IsErrUnsupportedVersion(err) {
 | 
									if !git.IsErrUnsupportedVersion(err) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue