mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 19:42:38 +00:00 
			
		
		
		
	[F3] Forgejo driver and CLI
user, topic, project, label, milestone, repository, pull_request, release, asset, comment, reaction, review providers Signed-off-by: Earl Warren <contact@earl-warren.org> Preserve file size when creating attachments Introduced inc6f5029708repoList.LoadAttributes has a ctx argument now Rename `repo.GetOwner` to `repo.LoadOwner`bd66fa586aupgrade to the latest gof3 (cherry picked from commitc770713656) [F3] ID remapping logic is in place, remove workaround (cherry picked from commitd0fee30167) [F3] it is experimental, do not enable by default (cherry picked from commitde325b21d0) (cherry picked from commit547e7b3c40) (cherry picked from commit820df3a56b) (cherry picked from commiteaba87689b) (cherry picked from commit1b86896b3b) (cherry picked from commit0046aac1c6) (cherry picked from commitf14220df8f) (cherry picked from commit559b731001) (cherry picked from commit801f7d600d)
This commit is contained in:
		
					parent
					
						
							
								6323c6d1a2
							
						
					
				
			
			
				commit
				
					
						6aa76e9bcf
					
				
			
		
					 28 changed files with 2748 additions and 6 deletions
				
			
		
							
								
								
									
										117
									
								
								tests/integration/f3_test.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								tests/integration/f3_test.go
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,117 @@ | |||
| // SPDX-License-Identifier: MIT | ||||
| 
 | ||||
| package integration | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"net/url" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	auth_model "code.gitea.io/gitea/models/auth" | ||||
| 	user_model "code.gitea.io/gitea/models/user" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| 	"code.gitea.io/gitea/services/f3/util" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| 	"lab.forgefriends.org/friendlyforgeformat/gof3" | ||||
| 	f3_forges "lab.forgefriends.org/friendlyforgeformat/gof3/forges" | ||||
| 	f3_common "lab.forgefriends.org/friendlyforgeformat/gof3/forges/common" | ||||
| 	f3_f3 "lab.forgefriends.org/friendlyforgeformat/gof3/forges/f3" | ||||
| 	f3_forgejo "lab.forgefriends.org/friendlyforgeformat/gof3/forges/forgejo" | ||||
| 	"lab.forgefriends.org/friendlyforgeformat/gof3/format" | ||||
| 	f3_util "lab.forgefriends.org/friendlyforgeformat/gof3/util" | ||||
| ) | ||||
| 
 | ||||
| func TestF3(t *testing.T) { | ||||
| 	onGiteaRun(t, func(t *testing.T, u *url.URL) { | ||||
| 		AllowLocalNetworks := setting.Migrations.AllowLocalNetworks | ||||
| 		setting.F3.Enabled = true | ||||
| 		setting.Migrations.AllowLocalNetworks = true | ||||
| 		AppVer := setting.AppVer | ||||
| 		// Gitea SDK (go-sdk) need to parse the AppVer from server response, so we must set it to a valid version string. | ||||
| 		setting.AppVer = "1.16.0" | ||||
| 		defer func() { | ||||
| 			setting.Migrations.AllowLocalNetworks = AllowLocalNetworks | ||||
| 			setting.AppVer = AppVer | ||||
| 		}() | ||||
| 
 | ||||
| 		// | ||||
| 		// Step 1: create a fixture | ||||
| 		// | ||||
| 		fixtureNewF3Forge := func(t *testing.T, user *format.User, tmpDir string) *f3_forges.ForgeRoot { | ||||
| 			root := f3_forges.NewForgeRoot(&f3_f3.Options{ | ||||
| 				Options: gof3.Options{ | ||||
| 					Configuration: gof3.Configuration{ | ||||
| 						Directory: tmpDir, | ||||
| 					}, | ||||
| 					Features: gof3.AllFeatures, | ||||
| 				}, | ||||
| 				Remap: true, | ||||
| 			}) | ||||
| 			return root | ||||
| 		} | ||||
| 		fixture := f3_forges.NewFixture(t, f3_forges.FixtureForgeFactory{Fun: fixtureNewF3Forge, AdminRequired: false}) | ||||
| 		fixture.NewUser(5432) | ||||
| 		fixture.NewMilestone() | ||||
| 		fixture.NewLabel() | ||||
| 		fixture.NewIssue() | ||||
| 		fixture.NewTopic() | ||||
| 		fixture.NewRepository() | ||||
| 		fixture.NewPullRequest() | ||||
| 		fixture.NewRelease() | ||||
| 		fixture.NewAsset() | ||||
| 		fixture.NewIssueComment(nil) | ||||
| 		fixture.NewPullRequestComment() | ||||
| 		fixture.NewReview() | ||||
| 		fixture.NewIssueReaction() | ||||
| 		fixture.NewCommentReaction() | ||||
| 
 | ||||
| 		// | ||||
| 		// Step 2: mirror the fixture into Forgejo | ||||
| 		// | ||||
| 		doer, err := user_model.GetAdminUser() | ||||
| 		assert.NoError(t, err) | ||||
| 		forgejoLocal := util.ForgejoForgeRoot(gof3.AllFeatures, doer) | ||||
| 		options := f3_common.NewMirrorOptionsRecurse() | ||||
| 		forgejoLocal.Forge.Mirror(context.Background(), fixture.Forge, options) | ||||
| 
 | ||||
| 		// | ||||
| 		// Step 3: mirror Forgejo into F3 | ||||
| 		// | ||||
| 		adminUsername := "user1" | ||||
| 		forgejoAPI := f3_forges.NewForgeRootFromDriver(&f3_forgejo.Forgejo{}, &f3_forgejo.Options{ | ||||
| 			Options: gof3.Options{ | ||||
| 				Configuration: gof3.Configuration{ | ||||
| 					URL:       setting.AppURL, | ||||
| 					Directory: t.TempDir(), | ||||
| 				}, | ||||
| 				Features: gof3.AllFeatures, | ||||
| 			}, | ||||
| 			AuthToken: getUserToken(t, adminUsername, auth_model.AccessTokenScopeWriteAdmin, auth_model.AccessTokenScopeAll), | ||||
| 		}) | ||||
| 
 | ||||
| 		f3 := f3_forges.FixtureNewF3Forge(t, nil, t.TempDir()) | ||||
| 		apiForge := forgejoAPI.Forge | ||||
| 		apiUser := apiForge.Users.GetFromFormat(context.Background(), &format.User{UserName: fixture.UserFormat.UserName}) | ||||
| 		apiProject := apiUser.Projects.GetFromFormat(context.Background(), &format.Project{Name: fixture.ProjectFormat.Name}) | ||||
| 		options = f3_common.NewMirrorOptionsRecurse(apiUser, apiProject) | ||||
| 		f3.Forge.Mirror(context.Background(), apiForge, options) | ||||
| 
 | ||||
| 		// | ||||
| 		// Step 4: verify the fixture and F3 are equivalent | ||||
| 		// | ||||
| 		files := f3_util.Command(context.Background(), "find", f3.GetDirectory()) | ||||
| 		assert.Contains(t, files, "/repository/git/hooks") | ||||
| 		assert.Contains(t, files, "/label/") | ||||
| 		assert.Contains(t, files, "/issue/") | ||||
| 		assert.Contains(t, files, "/milestone/") | ||||
| 		assert.Contains(t, files, "/topic/") | ||||
| 		assert.Contains(t, files, "/pull_request/") | ||||
| 		assert.Contains(t, files, "/release/") | ||||
| 		assert.Contains(t, files, "/asset/") | ||||
| 		assert.Contains(t, files, "/comment/") | ||||
| 		assert.Contains(t, files, "/review/") | ||||
| 		assert.Contains(t, files, "/reaction/") | ||||
| 		//		f3_util.Command(context.Background(), "cp", "-a", f3.GetDirectory(), "abc") | ||||
| 	}) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue