 3a91f845e8
			
		
	
	
		3a91f845e8
		
			
		
	
	
	
	
		
			
			There is no need to call UpdateRepoStats in the InsertIssues and InsertPullRequests function. They are only called during migration by the CreateIssues and CreateReviews methods of the gitea uploader. The UpdateRepoStats function will be called by the Finish method of the gitea uploader after all reviews and issues are inserted. Calling it before is therefore redundant and the associated SQL requests are not cheap. The statistics tests done after inserting an issue or a pull request are also removed. They predate the implementation of UpdateRepoStats, back when the calculation of the statistics was an integral part of the migration function. The UpdateRepoStats is now tested independantly and these tests are no longer necessary. Signed-off-by: singuliere <singuliere@autistici.org> Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			144 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
	
		
			4.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2022 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 models
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestMigrate_InsertMilestones(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	reponame := "repo1"
 | |
| 	repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{Name: reponame}).(*repo_model.Repository)
 | |
| 	name := "milestonetest1"
 | |
| 	ms := &Milestone{
 | |
| 		RepoID: repo.ID,
 | |
| 		Name:   name,
 | |
| 	}
 | |
| 	err := InsertMilestones(ms)
 | |
| 	assert.NoError(t, err)
 | |
| 	unittest.AssertExistsAndLoadBean(t, ms)
 | |
| 	repoModified := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: repo.ID}).(*repo_model.Repository)
 | |
| 	assert.EqualValues(t, repo.NumMilestones+1, repoModified.NumMilestones)
 | |
| 
 | |
| 	unittest.CheckConsistencyFor(t, &Milestone{})
 | |
| }
 | |
| 
 | |
| func assertCreateIssues(t *testing.T, isPull bool) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	reponame := "repo1"
 | |
| 	repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{Name: reponame}).(*repo_model.Repository)
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID}).(*user_model.User)
 | |
| 	label := unittest.AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
 | |
| 	milestone := unittest.AssertExistsAndLoadBean(t, &Milestone{ID: 1}).(*Milestone)
 | |
| 	assert.EqualValues(t, milestone.ID, 1)
 | |
| 	reaction := &Reaction{
 | |
| 		Type:   "heart",
 | |
| 		UserID: owner.ID,
 | |
| 	}
 | |
| 
 | |
| 	title := "issuetitle1"
 | |
| 	is := &Issue{
 | |
| 		RepoID:      repo.ID,
 | |
| 		MilestoneID: milestone.ID,
 | |
| 		Repo:        repo,
 | |
| 		Title:       title,
 | |
| 		Content:     "issuecontent1",
 | |
| 		IsPull:      isPull,
 | |
| 		PosterID:    owner.ID,
 | |
| 		Poster:      owner,
 | |
| 		IsClosed:    true,
 | |
| 		Labels:      []*Label{label},
 | |
| 		Reactions:   []*Reaction{reaction},
 | |
| 	}
 | |
| 	err := InsertIssues(is)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	i := unittest.AssertExistsAndLoadBean(t, &Issue{Title: title}).(*Issue)
 | |
| 	unittest.AssertExistsAndLoadBean(t, &Reaction{Type: "heart", UserID: owner.ID, IssueID: i.ID})
 | |
| }
 | |
| 
 | |
| func TestMigrate_CreateIssuesIsPullFalse(t *testing.T) {
 | |
| 	assertCreateIssues(t, false)
 | |
| }
 | |
| 
 | |
| func TestMigrate_CreateIssuesIsPullTrue(t *testing.T) {
 | |
| 	assertCreateIssues(t, true)
 | |
| }
 | |
| 
 | |
| func TestMigrate_InsertIssueComments(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	issue := unittest.AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 	_ = issue.LoadRepo()
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: issue.Repo.OwnerID}).(*user_model.User)
 | |
| 	reaction := &Reaction{
 | |
| 		Type:   "heart",
 | |
| 		UserID: owner.ID,
 | |
| 	}
 | |
| 
 | |
| 	comment := &Comment{
 | |
| 		PosterID:  owner.ID,
 | |
| 		Poster:    owner,
 | |
| 		IssueID:   issue.ID,
 | |
| 		Issue:     issue,
 | |
| 		Reactions: []*Reaction{reaction},
 | |
| 	}
 | |
| 
 | |
| 	err := InsertIssueComments([]*Comment{comment})
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	issueModified := unittest.AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
 | |
| 	assert.EqualValues(t, issue.NumComments+1, issueModified.NumComments)
 | |
| 
 | |
| 	unittest.CheckConsistencyFor(t, &Issue{})
 | |
| }
 | |
| 
 | |
| func TestMigrate_InsertPullRequests(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 	reponame := "repo1"
 | |
| 	repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{Name: reponame}).(*repo_model.Repository)
 | |
| 	owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID}).(*user_model.User)
 | |
| 
 | |
| 	i := &Issue{
 | |
| 		RepoID:   repo.ID,
 | |
| 		Repo:     repo,
 | |
| 		Title:    "title1",
 | |
| 		Content:  "issuecontent1",
 | |
| 		IsPull:   true,
 | |
| 		PosterID: owner.ID,
 | |
| 		Poster:   owner,
 | |
| 	}
 | |
| 
 | |
| 	p := &PullRequest{
 | |
| 		Issue: i,
 | |
| 	}
 | |
| 
 | |
| 	err := InsertPullRequests(p)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	_ = unittest.AssertExistsAndLoadBean(t, &PullRequest{IssueID: i.ID}).(*PullRequest)
 | |
| 
 | |
| 	unittest.CheckConsistencyFor(t, &Issue{}, &PullRequest{})
 | |
| }
 | |
| 
 | |
| func TestMigrate_InsertReleases(t *testing.T) {
 | |
| 	assert.NoError(t, unittest.PrepareTestDatabase())
 | |
| 
 | |
| 	a := &repo_model.Attachment{
 | |
| 		UUID: "a0eebc91-9c0c-4ef7-bb6e-6bb9bd380a12",
 | |
| 	}
 | |
| 	r := &Release{
 | |
| 		Attachments: []*repo_model.Attachment{a},
 | |
| 	}
 | |
| 
 | |
| 	err := InsertReleases(r)
 | |
| 	assert.NoError(t, err)
 | |
| }
 |