| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | // Copyright 2021 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2022-11-27 13:20:29 -05:00
										 |  |  | // SPDX-License-Identifier: MIT | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | package v1_16 //nolint | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | 	"code.gitea.io/gitea/models/migrations/base" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 	"github.com/stretchr/testify/assert" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | func Test_AddTableCommitStatusIndex(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 	// Create the models used in the migration | 
					
						
							|  |  |  | 	type CommitStatus struct { | 
					
						
							|  |  |  | 		ID     int64  `xorm:"pk autoincr"` | 
					
						
							|  |  |  | 		Index  int64  `xorm:"INDEX UNIQUE(repo_sha_index)"` | 
					
						
							|  |  |  | 		RepoID int64  `xorm:"INDEX UNIQUE(repo_sha_index)"` | 
					
						
							|  |  |  | 		SHA    string `xorm:"VARCHAR(64) NOT NULL INDEX UNIQUE(repo_sha_index)"` | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Prepare and load the testing database | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | 	x, deferable := base.PrepareTestEnv(t, 0, new(CommitStatus)) | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 	if x == nil || t.Failed() { | 
					
						
							|  |  |  | 		defer deferable() | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	defer deferable() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Run the migration | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | 	if err := AddTableCommitStatusIndex(x); err != nil { | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 		assert.NoError(t, err) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	type CommitStatusIndex struct { | 
					
						
							|  |  |  | 		ID       int64 | 
					
						
							|  |  |  | 		RepoID   int64  `xorm:"unique(repo_sha)"` | 
					
						
							|  |  |  | 		SHA      string `xorm:"unique(repo_sha)"` | 
					
						
							|  |  |  | 		MaxIndex int64  `xorm:"index"` | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-20 18:46:10 +01:00
										 |  |  | 	start := 0 | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 	const batchSize = 1000 | 
					
						
							|  |  |  | 	for { | 
					
						
							| 
									
										
										
										
											2022-01-20 18:46:10 +01:00
										 |  |  | 		indexes := make([]CommitStatusIndex, 0, batchSize) | 
					
						
							| 
									
										
										
										
											2021-09-23 18:50:06 +08:00
										 |  |  | 		err := x.Table("commit_status_index").Limit(batchSize, start).Find(&indexes) | 
					
						
							|  |  |  | 		assert.NoError(t, err) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for _, idx := range indexes { | 
					
						
							|  |  |  | 			var maxIndex int | 
					
						
							|  |  |  | 			has, err := x.SQL("SELECT max(`index`) FROM commit_status WHERE repo_id = ? AND sha = ?", idx.RepoID, idx.SHA).Get(&maxIndex) | 
					
						
							|  |  |  | 			assert.NoError(t, err) | 
					
						
							|  |  |  | 			assert.True(t, has) | 
					
						
							|  |  |  | 			assert.EqualValues(t, maxIndex, idx.MaxIndex) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if len(indexes) < batchSize { | 
					
						
							|  |  |  | 			break | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		start += len(indexes) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |