mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 11:28:24 +00:00 
			
		
		
		
	The old code generates `structs.Repository.Permissions` with only `access.Permission.AccessMode`, however, it should check the units too, or the value could be incorrect. For example, `structs.Repository.Permissions.Push` could be false even the doer has write access to code unit. Should fix https://github.com/renovatebot/renovate/issues/14059#issuecomment-1047961128 (Not reported by it, I just found it when I was looking into this bug) --- Review tips: The major changes are - `modules/structs/repo.go` https://github.com/go-gitea/gitea/pull/25388/files#diff-870406f6857117f8b03611c43fca0ab9ed6d6e76a2d0069a7c1f17e8fa9092f7 - `services/convert/repository.go` https://github.com/go-gitea/gitea/pull/25388/files#diff-7736f6d2ae894c9edb7729a80ab89aa183b888a26a811a0c1fdebd18726a7101 And other changes are passive.
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2020 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package convert
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	issues_model "code.gitea.io/gitea/models/issues"
 | |
| 	"code.gitea.io/gitea/models/perm"
 | |
| 	access_model "code.gitea.io/gitea/models/perm/access"
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/structs"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestPullRequest_APIFormat(t *testing.T) {
 | |
| 	// with HeadRepo
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	headRepo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
 | |
| 	pr := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1})
 | |
| 	assert.NoError(t, pr.LoadAttributes(db.DefaultContext))
 | |
| 	assert.NoError(t, pr.LoadIssue(db.DefaultContext))
 | |
| 	apiPullRequest := ToAPIPullRequest(git.DefaultContext, pr, nil)
 | |
| 	assert.NotNil(t, apiPullRequest)
 | |
| 	assert.EqualValues(t, &structs.PRBranchInfo{
 | |
| 		Name:       "branch1",
 | |
| 		Ref:        "refs/pull/2/head",
 | |
| 		Sha:        "4a357436d925b5c974181ff12a994538ddc5a269",
 | |
| 		RepoID:     1,
 | |
| 		Repository: ToRepo(db.DefaultContext, headRepo, access_model.Permission{AccessMode: perm.AccessModeRead}),
 | |
| 	}, apiPullRequest.Head)
 | |
| 
 | |
| 	// withOut HeadRepo
 | |
| 	pr = unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1})
 | |
| 	assert.NoError(t, pr.LoadIssue(db.DefaultContext))
 | |
| 	assert.NoError(t, pr.LoadAttributes(db.DefaultContext))
 | |
| 	// simulate fork deletion
 | |
| 	pr.HeadRepo = nil
 | |
| 	pr.HeadRepoID = 100000
 | |
| 	apiPullRequest = ToAPIPullRequest(git.DefaultContext, pr, nil)
 | |
| 	assert.NotNil(t, apiPullRequest)
 | |
| 	assert.Nil(t, apiPullRequest.Head.Repository)
 | |
| 	assert.EqualValues(t, -1, apiPullRequest.Head.RepoID)
 | |
| }
 |