mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-09-12 22:07:17 +00:00
Followup to https://codeberg.org/forgejo/forgejo/pulls/8987 * migrate strings, get rid of the `repo.` prefix * simplify template and test Followup to https://codeberg.org/forgejo/forgejo/pulls/8736#issuecomment-6801385 * restore lost translations Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/9041 Reviewed-by: Beowulf <beowulf@beocode.eu>
127 lines
3.7 KiB
Go
127 lines
3.7 KiB
Go
// Copyright 2024-2025 The Forgejo Authors. All rights reserved.
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
package integration
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
"testing"
|
|
|
|
"forgejo.org/modules/translation"
|
|
"forgejo.org/tests"
|
|
|
|
"github.com/PuerkitoBio/goquery"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
// TestRepoMigrationUI is used to test various form properties of different
|
|
// migration types on /repo/migrate?service_type=%d
|
|
func TestRepoMigrationUI(t *testing.T) {
|
|
defer tests.PrepareTestEnv(t)()
|
|
session := loginUser(t, "user1")
|
|
// Note: nothing is tested in plain Git migration form right now
|
|
|
|
type Migration struct {
|
|
Name string
|
|
ExpectedItems []string
|
|
DescriptionHasPlaceholder bool
|
|
}
|
|
|
|
migrations := map[int]Migration{
|
|
2: {
|
|
"GitHub",
|
|
[]string{"issues", "pull_requests", "labels", "milestones", "releases"},
|
|
true,
|
|
},
|
|
3: {
|
|
"Gitea",
|
|
[]string{"issues", "pull_requests", "labels", "milestones", "releases"},
|
|
true,
|
|
},
|
|
4: {
|
|
"GitLab",
|
|
// Note: the checkbox "Merge requests" has name "pull_requests"
|
|
[]string{"issues", "pull_requests", "labels", "milestones", "releases"},
|
|
true,
|
|
},
|
|
5: {
|
|
"Gogs",
|
|
[]string{"issues", "labels", "milestones"},
|
|
true,
|
|
},
|
|
6: {
|
|
"OneDev",
|
|
[]string{"issues", "pull_requests", "labels", "milestones"},
|
|
true,
|
|
},
|
|
7: {
|
|
"GitBucket",
|
|
[]string{"issues", "pull_requests", "labels", "milestones", "releases"},
|
|
false,
|
|
},
|
|
8: {
|
|
"Codebase",
|
|
// Note: the checkbox "Merge requests" has name "pull_requests"
|
|
[]string{"issues", "pull_requests", "labels", "milestones"},
|
|
true,
|
|
},
|
|
9: {
|
|
"Forgejo",
|
|
[]string{"issues", "pull_requests", "labels", "milestones", "releases"},
|
|
true,
|
|
},
|
|
}
|
|
|
|
for id, migration := range migrations {
|
|
t.Run(migration.Name, func(t *testing.T) {
|
|
response := session.MakeRequest(t, NewRequest(t, "GET", fmt.Sprintf("/repo/migrate?service_type=%d", id)), http.StatusOK)
|
|
page := NewHTMLParser(t, response.Body)
|
|
|
|
items := page.Find("#migrate_items .field .checkbox input")
|
|
testRepoMigrationFormItems(t, items, migration.ExpectedItems)
|
|
|
|
page.AssertElement(t, "#clone_addr", true)
|
|
autocomplete, _ := page.Find("#clone_addr").Attr("autocomplete")
|
|
assert.Equal(t, "url", autocomplete)
|
|
|
|
page.AssertElement(t, "#description", true)
|
|
_, descriptionHasPlaceholder := page.Find("#description").Attr("placeholder")
|
|
assert.Equal(t, migration.DescriptionHasPlaceholder, descriptionHasPlaceholder)
|
|
})
|
|
}
|
|
}
|
|
|
|
func testRepoMigrationFormItems(t *testing.T, items *goquery.Selection, expectedItems []string) {
|
|
t.Helper()
|
|
|
|
// Compare lengths of item lists
|
|
assert.Equal(t, len(expectedItems), items.Length())
|
|
|
|
// Compare contents of item lists
|
|
for index, expectedName := range expectedItems {
|
|
name, exists := items.Eq(index).Attr("name")
|
|
assert.True(t, exists)
|
|
assert.Equal(t, expectedName, name)
|
|
}
|
|
}
|
|
|
|
// TestRepoMigrationTypeSelect is a simple content test for page /repo/migrate
|
|
// where migration source type is selected
|
|
func TestRepoMigrationTypeSelect(t *testing.T) {
|
|
defer tests.PrepareTestEnv(t)()
|
|
|
|
session := loginUser(t, "user1")
|
|
locale := translation.NewLocale("en-US")
|
|
|
|
page := NewHTMLParser(t, session.MakeRequest(t, NewRequest(t, "GET", "/repo/migrate"), http.StatusOK).Body)
|
|
headers := page.Find(".migrate-entry h3").Text()
|
|
descriptions := page.Find(".migrate-entry .description").Text()
|
|
|
|
sourceNames := []string{"github", "gitea", "gitlab", "gogs", "onedev", "gitbucket", "codebase", "forgejo", "pagure"}
|
|
for _, sourceName := range sourceNames {
|
|
assert.Contains(t, strings.ToLower(headers), sourceName)
|
|
assert.Contains(t, descriptions, locale.Tr(fmt.Sprintf("migrate.%s.description", sourceName)))
|
|
}
|
|
}
|