mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	enable nolintlint scope requirement add comments to new directives so it's more obvious why they are in place --- I can also toggle the mandatory comments on if that's something of interest. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: Giteabot <teabot@gitea.io>
		
			
				
	
	
		
			119 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2023 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package v1_22
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/models/migrations/base"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
	"xorm.io/xorm"
 | 
						|
)
 | 
						|
 | 
						|
func PrepareOldRepository(t *testing.T) (*xorm.Engine, func()) {
 | 
						|
	type Repository struct { // old struct
 | 
						|
		ID int64 `xorm:"pk autoincr"`
 | 
						|
	}
 | 
						|
 | 
						|
	type CommitStatus struct {
 | 
						|
		ID          int64
 | 
						|
		ContextHash string `xorm:"char(40) index"`
 | 
						|
	}
 | 
						|
 | 
						|
	type RepoArchiver struct {
 | 
						|
		ID       int64
 | 
						|
		RepoID   int64  `xorm:"index unique(s)"`
 | 
						|
		Type     int    `xorm:"unique(s)"`
 | 
						|
		CommitID string `xorm:"VARCHAR(40) unique(s)"`
 | 
						|
	}
 | 
						|
 | 
						|
	type ReviewState struct {
 | 
						|
		ID        int64
 | 
						|
		UserID    int64  `xorm:"NOT NULL UNIQUE(pull_commit_user)"`
 | 
						|
		PullID    int64  `xorm:"NOT NULL INDEX UNIQUE(pull_commit_user) DEFAULT 0"`
 | 
						|
		CommitSHA string `xorm:"NOT NULL VARCHAR(40) UNIQUE(pull_commit_user)"`
 | 
						|
	}
 | 
						|
 | 
						|
	type Comment struct {
 | 
						|
		ID        int64
 | 
						|
		CommitSHA string
 | 
						|
	}
 | 
						|
 | 
						|
	type PullRequest struct {
 | 
						|
		ID             int64
 | 
						|
		CommitSHA      string
 | 
						|
		MergeBase      string
 | 
						|
		MergedCommitID string
 | 
						|
	}
 | 
						|
 | 
						|
	type Release struct {
 | 
						|
		ID   int64
 | 
						|
		Sha1 string
 | 
						|
	}
 | 
						|
 | 
						|
	type RepoIndexerStatus struct {
 | 
						|
		ID        int64
 | 
						|
		CommitSHA string
 | 
						|
	}
 | 
						|
 | 
						|
	type Review struct {
 | 
						|
		ID       int64
 | 
						|
		CommitID string
 | 
						|
	}
 | 
						|
 | 
						|
	// Prepare and load the testing database
 | 
						|
	return base.PrepareTestEnv(t, 0,
 | 
						|
		new(Repository),
 | 
						|
		new(CommitStatus),
 | 
						|
		new(RepoArchiver),
 | 
						|
		new(ReviewState),
 | 
						|
		new(Review),
 | 
						|
		new(Comment),
 | 
						|
		new(PullRequest),
 | 
						|
		new(Release),
 | 
						|
		new(RepoIndexerStatus),
 | 
						|
	)
 | 
						|
}
 | 
						|
 | 
						|
func Test_RepositoryFormat(t *testing.T) {
 | 
						|
	x, deferable := PrepareOldRepository(t)
 | 
						|
	defer deferable()
 | 
						|
 | 
						|
	assert.NoError(t, AdjustDBForSha256(x))
 | 
						|
 | 
						|
	type Repository struct {
 | 
						|
		ID               int64  `xorm:"pk autoincr"`
 | 
						|
		ObjectFormatName string `xorg:"not null default('sha1')"`
 | 
						|
	}
 | 
						|
 | 
						|
	repo := new(Repository)
 | 
						|
 | 
						|
	// check we have some records to migrate
 | 
						|
	count, err := x.Count(new(Repository))
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 4, count)
 | 
						|
 | 
						|
	repo.ObjectFormatName = "sha256"
 | 
						|
	_, err = x.Insert(repo)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	id := repo.ID
 | 
						|
 | 
						|
	count, err = x.Count(new(Repository))
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 5, count)
 | 
						|
 | 
						|
	repo = new(Repository)
 | 
						|
	ok, err := x.ID(2).Get(repo)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.True(t, ok)
 | 
						|
	assert.Equal(t, "sha1", repo.ObjectFormatName)
 | 
						|
 | 
						|
	repo = new(Repository)
 | 
						|
	ok, err = x.ID(id).Get(repo)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.True(t, ok)
 | 
						|
	assert.Equal(t, "sha256", repo.ObjectFormatName)
 | 
						|
}
 |