mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Co-authored-by: Loïc Dachary <loic@dachary.org> Conflicts: models/consistency_test.go trivial context conflict.
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2021 Gitea. 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"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/models/db"
 | 
						|
	"code.gitea.io/gitea/models/unittest"
 | 
						|
	"code.gitea.io/gitea/modules/setting"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func TestDeleteOrphanedObjects(t *testing.T) {
 | 
						|
	assert.NoError(t, unittest.PrepareTestDatabase())
 | 
						|
 | 
						|
	countBefore, err := db.GetEngine(db.DefaultContext).Count(&PullRequest{})
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	_, err = db.GetEngine(db.DefaultContext).Insert(&PullRequest{IssueID: 1000}, &PullRequest{IssueID: 1001}, &PullRequest{IssueID: 1003})
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	orphaned, err := CountOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id")
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 3, orphaned)
 | 
						|
 | 
						|
	err = DeleteOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id")
 | 
						|
	assert.NoError(t, err)
 | 
						|
 | 
						|
	countAfter, err := db.GetEngine(db.DefaultContext).Count(&PullRequest{})
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, countBefore, countAfter)
 | 
						|
}
 | 
						|
 | 
						|
func TestConsistencyUpdateAction(t *testing.T) {
 | 
						|
	if !setting.Database.UseSQLite3 {
 | 
						|
		t.Skip("Test is only for SQLite database.")
 | 
						|
	}
 | 
						|
	assert.NoError(t, unittest.PrepareTestDatabase())
 | 
						|
	id := 8
 | 
						|
	unittest.AssertExistsAndLoadBean(t, &Action{
 | 
						|
		ID: int64(id),
 | 
						|
	})
 | 
						|
	_, err := db.GetEngine(db.DefaultContext).Exec(`UPDATE action SET created_unix = "" WHERE id = ?`, id)
 | 
						|
	assert.NoError(t, err)
 | 
						|
	actions := make([]*Action, 0, 1)
 | 
						|
	//
 | 
						|
	// XORM returns an error when created_unix is a string
 | 
						|
	//
 | 
						|
	err = db.GetEngine(db.DefaultContext).Where("id = ?", id).Find(&actions)
 | 
						|
	if assert.Error(t, err) {
 | 
						|
		assert.Contains(t, err.Error(), "type string to a int64: invalid syntax")
 | 
						|
	}
 | 
						|
	//
 | 
						|
	// Get rid of incorrectly set created_unix
 | 
						|
	//
 | 
						|
	count, err := CountActionCreatedUnixString()
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 1, count)
 | 
						|
	count, err = FixActionCreatedUnixString()
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 1, count)
 | 
						|
 | 
						|
	count, err = CountActionCreatedUnixString()
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 0, count)
 | 
						|
	count, err = FixActionCreatedUnixString()
 | 
						|
	assert.NoError(t, err)
 | 
						|
	assert.EqualValues(t, 0, count)
 | 
						|
 | 
						|
	//
 | 
						|
	// XORM must be happy now
 | 
						|
	//
 | 
						|
	assert.NoError(t, db.GetEngine(db.DefaultContext).Where("id = ?", id).Find(&actions))
 | 
						|
	unittest.CheckConsistencyFor(t, &Action{})
 | 
						|
}
 |