mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	`[repository.pull-request] DELAY_CHECK_FOR_INACTIVE_DAYS` is a new setting to delay the mergeable check for pull requests that have been inactive for the specified number of days. This avoids potentially long delays for big repositories with many pull requests. and reduces system load overall when there are many repositories or pull requests. When viewing the PR, checking will start immediately and the PR merge box will automatically reload when complete. Accessing the PR through the API will also start checking immediately. The default value of `7` provides a balance between system load, and keeping behavior similar to what it was before both for users and API access. With `0` all conflict checking will be delayed, while `-1` always checks immediately to restore the previous behavior. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors.
 | |
| // All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package pull
 | |
| 
 | |
| import (
 | |
| 	"strconv"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	issues_model "code.gitea.io/gitea/models/issues"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	"code.gitea.io/gitea/modules/queue"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestPullRequest_AddToTaskQueue(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	idChan := make(chan int64, 10)
 | |
| 	testHandler := func(items ...string) []string {
 | |
| 		for _, s := range items {
 | |
| 			id, _ := strconv.ParseInt(s, 10, 64)
 | |
| 			idChan <- id
 | |
| 		}
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	cfg, err := setting.GetQueueSettings(setting.CfgProvider, "pr_patch_checker")
 | |
| 	assert.NoError(t, err)
 | |
| 	prPatchCheckerQueue, err = queue.NewWorkerPoolQueueWithContext(t.Context(), "pr_patch_checker", cfg, testHandler, true)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	pr := unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2})
 | |
| 	StartPullRequestCheckImmediately(db.DefaultContext, pr)
 | |
| 
 | |
| 	assert.Eventually(t, func() bool {
 | |
| 		pr = unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2})
 | |
| 		return pr.Status == issues_model.PullRequestStatusChecking
 | |
| 	}, 1*time.Second, 100*time.Millisecond)
 | |
| 
 | |
| 	has, err := prPatchCheckerQueue.Has(strconv.FormatInt(pr.ID, 10))
 | |
| 	assert.True(t, has)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	go prPatchCheckerQueue.Run()
 | |
| 
 | |
| 	select {
 | |
| 	case id := <-idChan:
 | |
| 		assert.Equal(t, pr.ID, id)
 | |
| 	case <-time.After(time.Second):
 | |
| 		assert.FailNow(t, "Timeout: nothing was added to pullRequestQueue")
 | |
| 	}
 | |
| 
 | |
| 	has, err = prPatchCheckerQueue.Has(strconv.FormatInt(pr.ID, 10))
 | |
| 	assert.False(t, has)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	pr = unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2})
 | |
| 	assert.Equal(t, issues_model.PullRequestStatusChecking, pr.Status)
 | |
| 
 | |
| 	prPatchCheckerQueue.ShutdownWait(5 * time.Second)
 | |
| 	prPatchCheckerQueue = nil
 | |
| }
 |