Add git clone test on integration test (#1682)
This commit is contained in:
		
							parent
							
								
									eecaba2031
								
							
						
					
					
						commit
						f70758dec9
					
				
					 2 changed files with 65 additions and 2 deletions
				
			
		
							
								
								
									
										60
									
								
								integrations/git_test.go
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								integrations/git_test.go
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,60 @@ | |||
| // Copyright 2017 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 integrations | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fmt" | ||||
| 	"io/ioutil" | ||||
| 	"net" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"testing" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"code.gitea.io/git" | ||||
| 
 | ||||
| 	"github.com/Unknwon/com" | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
| 
 | ||||
| func onGiteaWebRun(t *testing.T, callback func(*testing.T, string)) { | ||||
| 	s := http.Server{ | ||||
| 		Handler: mac, | ||||
| 	} | ||||
| 
 | ||||
| 	listener, err := net.Listen("tcp", "") | ||||
| 	assert.NoError(t, err) | ||||
| 
 | ||||
| 	defer func() { | ||||
| 		ctx, cancel := context.WithTimeout(context.Background(), time.Second*10) | ||||
| 		s.Shutdown(ctx) | ||||
| 		cancel() | ||||
| 	}() | ||||
| 
 | ||||
| 	go s.Serve(listener) | ||||
| 
 | ||||
| 	_, port, err := net.SplitHostPort(listener.Addr().String()) | ||||
| 	assert.NoError(t, err) | ||||
| 
 | ||||
| 	callback(t, fmt.Sprintf("http://localhost:%s/", port)) | ||||
| } | ||||
| 
 | ||||
| func TestClone_ViaHTTP_NoLogin(t *testing.T) { | ||||
| 	prepareTestEnv(t) | ||||
| 
 | ||||
| 	onGiteaWebRun(t, func(t *testing.T, urlPrefix string) { | ||||
| 		dstPath, err := ioutil.TempDir("", "repo1") | ||||
| 		assert.NoError(t, err) | ||||
| 		defer os.RemoveAll(dstPath) | ||||
| 
 | ||||
| 		err = git.Clone(fmt.Sprintf("%suser2/repo1.git", urlPrefix), | ||||
| 			dstPath, git.CloneRepoOptions{}) | ||||
| 		assert.NoError(t, err) | ||||
| 
 | ||||
| 		assert.True(t, com.IsExist(filepath.Join(dstPath, "README.md"))) | ||||
| 	}) | ||||
| } | ||||
|  | @ -16,6 +16,7 @@ import ( | |||
| 	"net/url" | ||||
| 	"os" | ||||
| 	"path" | ||||
| 	"path/filepath" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| 
 | ||||
|  | @ -51,7 +52,7 @@ func TestMain(m *testing.M) { | |||
| 
 | ||||
| 	err := models.InitFixtures( | ||||
| 		helper, | ||||
| 		"models/fixtures/", | ||||
| 		path.Join(filepath.Dir(setting.AppPath), "models/fixtures/"), | ||||
| 	) | ||||
| 	if err != nil { | ||||
| 		fmt.Printf("Error initializing test database: %v\n", err) | ||||
|  | @ -134,7 +135,9 @@ func initIntegrationTest() { | |||
| func prepareTestEnv(t testing.TB) { | ||||
| 	assert.NoError(t, models.LoadFixtures()) | ||||
| 	assert.NoError(t, os.RemoveAll(setting.RepoRootPath)) | ||||
| 	assert.NoError(t, com.CopyDir("integrations/gitea-repositories-meta", setting.RepoRootPath)) | ||||
| 
 | ||||
| 	assert.NoError(t, com.CopyDir(path.Join(filepath.Dir(setting.AppPath), "integrations/gitea-repositories-meta"), | ||||
| 		setting.RepoRootPath)) | ||||
| } | ||||
| 
 | ||||
| type TestSession struct { | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Lunny Xiao
						Lunny Xiao