mirror of https://github.com/go-gitea/gitea
Use batch database operations instead of one by one to optimze api pulls (#32680)
Resolve #31492 The response time for the Pull Requests API has improved significantly, dropping from over `2000ms` to about `350ms` on my local machine. It's about `6` times faster. A key area for further optimization lies in batch-fetching data for `apiPullRequest.ChangedFiles, apiPullRequest.Additions, and apiPullRequest.Deletions`. Tests `TestAPIViewPulls` does exist and new tests added. - This PR also fixes some bugs in `GetDiff` functions. - This PR also fixes data inconsistent in test data. For a pull request, the head branch's reference should be equal to the reference in `pull/xxx/head`.pull/32768/head
parent
2ac6f2b129
commit
fbe6d9dc6b
@ -0,0 +1,64 @@ |
||||
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||
// SPDX-License-Identifier: MIT
|
||||
|
||||
package issues_test |
||||
|
||||
import ( |
||||
"testing" |
||||
|
||||
"code.gitea.io/gitea/models/db" |
||||
issues_model "code.gitea.io/gitea/models/issues" |
||||
"code.gitea.io/gitea/models/unittest" |
||||
|
||||
"github.com/stretchr/testify/assert" |
||||
) |
||||
|
||||
func TestPullRequestList_LoadAttributes(t *testing.T) { |
||||
assert.NoError(t, unittest.PrepareTestDatabase()) |
||||
|
||||
prs := []*issues_model.PullRequest{ |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1}), |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2}), |
||||
} |
||||
assert.NoError(t, issues_model.PullRequestList(prs).LoadAttributes(db.DefaultContext)) |
||||
for _, pr := range prs { |
||||
assert.NotNil(t, pr.Issue) |
||||
assert.Equal(t, pr.IssueID, pr.Issue.ID) |
||||
} |
||||
|
||||
assert.NoError(t, issues_model.PullRequestList([]*issues_model.PullRequest{}).LoadAttributes(db.DefaultContext)) |
||||
} |
||||
|
||||
func TestPullRequestList_LoadReviewCommentsCounts(t *testing.T) { |
||||
assert.NoError(t, unittest.PrepareTestDatabase()) |
||||
|
||||
prs := []*issues_model.PullRequest{ |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1}), |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2}), |
||||
} |
||||
reviewComments, err := issues_model.PullRequestList(prs).LoadReviewCommentsCounts(db.DefaultContext) |
||||
assert.NoError(t, err) |
||||
assert.Len(t, reviewComments, 2) |
||||
for _, pr := range prs { |
||||
assert.EqualValues(t, reviewComments[pr.IssueID], 1) |
||||
} |
||||
} |
||||
|
||||
func TestPullRequestList_LoadReviews(t *testing.T) { |
||||
assert.NoError(t, unittest.PrepareTestDatabase()) |
||||
|
||||
prs := []*issues_model.PullRequest{ |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 1}), |
||||
unittest.AssertExistsAndLoadBean(t, &issues_model.PullRequest{ID: 2}), |
||||
} |
||||
reviewList, err := issues_model.PullRequestList(prs).LoadReviews(db.DefaultContext) |
||||
assert.NoError(t, err) |
||||
// 1, 7, 8, 9, 10, 22
|
||||
assert.Len(t, reviewList, 6) |
||||
assert.EqualValues(t, 1, reviewList[0].ID) |
||||
assert.EqualValues(t, 7, reviewList[1].ID) |
||||
assert.EqualValues(t, 8, reviewList[2].ID) |
||||
assert.EqualValues(t, 9, reviewList[3].ID) |
||||
assert.EqualValues(t, 10, reviewList[4].ID) |
||||
assert.EqualValues(t, 22, reviewList[5].ID) |
||||
} |
@ -0,0 +1,25 @@ |
||||
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||
// SPDX-License-Identifier: MIT
|
||||
|
||||
package organization_test |
||||
|
||||
import ( |
||||
"testing" |
||||
|
||||
"code.gitea.io/gitea/models/db" |
||||
org_model "code.gitea.io/gitea/models/organization" |
||||
"code.gitea.io/gitea/models/unittest" |
||||
|
||||
"github.com/stretchr/testify/assert" |
||||
) |
||||
|
||||
func Test_GetTeamsByIDs(t *testing.T) { |
||||
assert.NoError(t, unittest.PrepareTestDatabase()) |
||||
|
||||
// 1 owner team, 2 normal team
|
||||
teams, err := org_model.GetTeamsByIDs(db.DefaultContext, []int64{1, 2}) |
||||
assert.NoError(t, err) |
||||
assert.Len(t, teams, 2) |
||||
assert.Equal(t, "Owners", teams[1].Name) |
||||
assert.Equal(t, "team1", teams[2].Name) |
||||
} |
@ -1 +1 @@ |
||||
5f22f7d0d95d614d25a5b68592adb345a4b5c7fd |
||||
985f0301dba5e7b34be866819cd15ad3d8f508ee |
||||
|
Loading…
Reference in new issue