mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 08:21:11 +00:00 
			
		
		
		
	Demonstrate that the it's not possible to migrate or add a push mirror from a URL that contains credentials.
		
			
				
	
	
		
			101 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2017 The Gitea Authors. All rights reserved.
 | 
						|
// Copyright 2025 The Forgejo Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package integration
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"net/http"
 | 
						|
	"net/http/httptest"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	auth_model "forgejo.org/models/auth"
 | 
						|
	"forgejo.org/modules/structs"
 | 
						|
	"forgejo.org/modules/translation"
 | 
						|
	"forgejo.org/tests"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func testRepoMigrate(t testing.TB, session *TestSession, cloneAddr, repoName string, service structs.GitServiceType) *httptest.ResponseRecorder {
 | 
						|
	req := NewRequest(t, "GET", fmt.Sprintf("/repo/migrate?service_type=%d", service)) // render plain git migration page
 | 
						|
	resp := session.MakeRequest(t, req, http.StatusOK)
 | 
						|
	htmlDoc := NewHTMLParser(t, resp.Body)
 | 
						|
 | 
						|
	link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action")
 | 
						|
	assert.True(t, exists, "The template has changed")
 | 
						|
 | 
						|
	uid, exists := htmlDoc.doc.Find("#uid").Attr("value")
 | 
						|
	assert.True(t, exists, "The template has changed")
 | 
						|
 | 
						|
	req = NewRequestWithValues(t, "POST", link, map[string]string{
 | 
						|
		"_csrf":      htmlDoc.GetCSRF(),
 | 
						|
		"clone_addr": cloneAddr,
 | 
						|
		"uid":        uid,
 | 
						|
		"repo_name":  repoName,
 | 
						|
		"service":    fmt.Sprintf("%d", service),
 | 
						|
	})
 | 
						|
	resp = session.MakeRequest(t, req, http.StatusSeeOther)
 | 
						|
 | 
						|
	return resp
 | 
						|
}
 | 
						|
 | 
						|
func TestRepoMigrate(t *testing.T) {
 | 
						|
	defer tests.PrepareTestEnv(t)()
 | 
						|
	session := loginUser(t, "user2")
 | 
						|
	for _, s := range []struct {
 | 
						|
		testName  string
 | 
						|
		cloneAddr string
 | 
						|
		repoName  string
 | 
						|
		service   structs.GitServiceType
 | 
						|
	}{
 | 
						|
		{"TestMigrateGithub", "https://github.com/go-gitea/test_repo.git", "git", structs.PlainGitService},
 | 
						|
		{"TestMigrateGithub", "https://github.com/go-gitea/test_repo.git", "github", structs.GithubService},
 | 
						|
	} {
 | 
						|
		t.Run(s.testName, func(t *testing.T) {
 | 
						|
			testRepoMigrate(t, session, s.cloneAddr, s.repoName, s.service)
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestRepoMigrateCredentials(t *testing.T) {
 | 
						|
	defer tests.PrepareTestEnv(t)()
 | 
						|
 | 
						|
	session := loginUser(t, "user2")
 | 
						|
	cloneAddr := "https://:TOKEN@example.com/example/example.git"
 | 
						|
 | 
						|
	t.Run("Web route", func(t *testing.T) {
 | 
						|
		defer tests.PrintCurrentTest(t)()
 | 
						|
 | 
						|
		resp := session.MakeRequest(t, NewRequestWithValues(t, "POST", "/repo/migrate?service_type=1", map[string]string{
 | 
						|
			"_csrf":      GetCSRF(t, session, "/repo/migrate?service_type=1"),
 | 
						|
			"clone_addr": cloneAddr,
 | 
						|
			"uid":        "2",
 | 
						|
			"repo_name":  "example",
 | 
						|
			"service":    "1",
 | 
						|
		}), http.StatusOK)
 | 
						|
 | 
						|
		htmlDoc := NewHTMLParser(t, resp.Body)
 | 
						|
		assert.Contains(t,
 | 
						|
			htmlDoc.doc.Find(".ui.negative.message").Text(),
 | 
						|
			translation.NewLocale("en-US").Tr("migrate.form.error.url_credentials"),
 | 
						|
		)
 | 
						|
	})
 | 
						|
 | 
						|
	t.Run("API route", func(t *testing.T) {
 | 
						|
		defer tests.PrintCurrentTest(t)()
 | 
						|
 | 
						|
		token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository)
 | 
						|
		resp := MakeRequest(t, NewRequestWithJSON(t, "POST", "/api/v1/repos/migrate", &structs.MigrateRepoOptions{
 | 
						|
			CloneAddr:   cloneAddr,
 | 
						|
			RepoOwnerID: 2,
 | 
						|
			RepoName:    "example",
 | 
						|
		}).AddTokenAuth(token), http.StatusUnprocessableEntity)
 | 
						|
 | 
						|
		var respBody map[string]any
 | 
						|
		DecodeJSON(t, resp, &respBody)
 | 
						|
 | 
						|
		assert.Equal(t, "The URL contains credentials.", respBody["message"])
 | 
						|
	})
 | 
						|
}
 |