2021-06-25 10:28:55 -04:00
|
|
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
2022-11-27 13:20:29 -05:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-06-25 10:28:55 -04:00
|
|
|
|
2022-09-02 15:18:23 -04:00
|
|
|
package integration
|
2021-06-25 10:28:55 -04:00
|
|
|
|
|
|
|
import (
|
2024-09-18 16:15:03 -04:00
|
|
|
"net/http"
|
2021-06-25 10:28:55 -04:00
|
|
|
"net/url"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/models"
|
2022-11-19 03:12:33 -05:00
|
|
|
"code.gitea.io/gitea/models/db"
|
2022-06-12 11:51:54 -04:00
|
|
|
git_model "code.gitea.io/gitea/models/git"
|
2021-12-09 20:27:50 -05:00
|
|
|
repo_model "code.gitea.io/gitea/models/repo"
|
2021-11-16 03:53:21 -05:00
|
|
|
"code.gitea.io/gitea/models/unittest"
|
2021-11-24 04:49:20 -05:00
|
|
|
user_model "code.gitea.io/gitea/models/user"
|
2021-06-25 10:28:55 -04:00
|
|
|
"code.gitea.io/gitea/modules/git"
|
|
|
|
"code.gitea.io/gitea/services/release"
|
2022-09-02 15:18:23 -04:00
|
|
|
"code.gitea.io/gitea/tests"
|
2021-06-25 10:28:55 -04:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2024-09-18 16:15:03 -04:00
|
|
|
"github.com/stretchr/testify/require"
|
2021-06-25 10:28:55 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestCreateNewTagProtected(t *testing.T) {
|
2022-09-02 15:18:23 -04:00
|
|
|
defer tests.PrepareTestEnv(t)()
|
2021-06-25 10:28:55 -04:00
|
|
|
|
2022-08-15 22:22:25 -04:00
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
|
|
|
|
owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID})
|
2021-06-25 10:28:55 -04:00
|
|
|
|
2024-05-14 02:48:21 -04:00
|
|
|
t.Run("Code", func(t *testing.T) {
|
2022-09-02 15:18:23 -04:00
|
|
|
defer tests.PrintCurrentTest(t)()
|
2021-06-25 10:28:55 -04:00
|
|
|
|
2024-05-14 02:48:21 -04:00
|
|
|
err := release.CreateNewTag(git.DefaultContext, owner, repo, "master", "t-first", "first tag")
|
2021-06-25 10:28:55 -04:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2022-01-19 18:26:57 -05:00
|
|
|
err = release.CreateNewTag(git.DefaultContext, owner, repo, "master", "v-2", "second tag")
|
2021-06-25 10:28:55 -04:00
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, models.IsErrProtectedTagName(err))
|
|
|
|
|
2022-01-19 18:26:57 -05:00
|
|
|
err = release.CreateNewTag(git.DefaultContext, owner, repo, "master", "v-1.1", "third tag")
|
2021-06-25 10:28:55 -04:00
|
|
|
assert.NoError(t, err)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Git", func(t *testing.T) {
|
|
|
|
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
2024-05-14 02:48:21 -04:00
|
|
|
httpContext := NewAPITestContext(t, owner.Name, repo.Name)
|
2021-06-25 10:28:55 -04:00
|
|
|
|
2022-09-04 11:14:53 -04:00
|
|
|
dstPath := t.TempDir()
|
2021-06-25 10:28:55 -04:00
|
|
|
|
|
|
|
u.Path = httpContext.GitPath()
|
2024-05-14 02:48:21 -04:00
|
|
|
u.User = url.UserPassword(owner.Name, userPassword)
|
2021-06-25 10:28:55 -04:00
|
|
|
|
|
|
|
doGitClone(dstPath, u)(t)
|
|
|
|
|
2022-09-04 11:14:53 -04:00
|
|
|
_, _, err := git.NewCommand(git.DefaultContext, "tag", "v-2").RunStdString(&git.RunOpts{Dir: dstPath})
|
2021-06-25 10:28:55 -04:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
2022-03-31 22:55:30 -04:00
|
|
|
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags").RunStdString(&git.RunOpts{Dir: dstPath})
|
2021-06-25 10:28:55 -04:00
|
|
|
assert.Error(t, err)
|
|
|
|
assert.Contains(t, err.Error(), "Tag v-2 is protected")
|
|
|
|
})
|
|
|
|
})
|
2021-12-20 22:12:27 -05:00
|
|
|
|
2024-09-18 16:15:03 -04:00
|
|
|
t.Run("GitTagForce", func(t *testing.T) {
|
|
|
|
onGiteaRun(t, func(t *testing.T, u *url.URL) {
|
|
|
|
httpContext := NewAPITestContext(t, owner.Name, repo.Name)
|
|
|
|
|
|
|
|
dstPath := t.TempDir()
|
|
|
|
|
|
|
|
u.Path = httpContext.GitPath()
|
|
|
|
u.User = url.UserPassword(owner.Name, userPassword)
|
|
|
|
|
|
|
|
doGitClone(dstPath, u)(t)
|
|
|
|
|
|
|
|
_, _, err := git.NewCommand(git.DefaultContext, "tag", "v-1.1", "-m", "force update", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags").RunStdString(&git.RunOpts{Dir: dstPath})
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
_, _, err = git.NewCommand(git.DefaultContext, "tag", "v-1.1", "-m", "force update v2", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags").RunStdString(&git.RunOpts{Dir: dstPath})
|
|
|
|
require.Error(t, err)
|
|
|
|
assert.Contains(t, err.Error(), "the tag already exists in the remote")
|
|
|
|
|
|
|
|
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
|
|
|
|
require.NoError(t, err)
|
|
|
|
req := NewRequestf(t, "GET", "/%s/releases/tag/v-1.1", repo.FullName())
|
|
|
|
resp := MakeRequest(t, req, http.StatusOK)
|
|
|
|
htmlDoc := NewHTMLParser(t, resp.Body)
|
|
|
|
tagsTab := htmlDoc.Find(".release-list-title")
|
|
|
|
assert.Contains(t, tagsTab.Text(), "force update v2")
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-12-20 22:12:27 -05:00
|
|
|
// Cleanup
|
2024-01-14 21:19:25 -05:00
|
|
|
releases, err := db.Find[repo_model.Release](db.DefaultContext, repo_model.FindReleasesOptions{
|
2021-12-20 22:12:27 -05:00
|
|
|
IncludeTags: true,
|
|
|
|
TagNames: []string{"v-1", "v-1.1"},
|
2024-01-14 21:19:25 -05:00
|
|
|
RepoID: repo.ID,
|
2021-12-20 22:12:27 -05:00
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
for _, release := range releases {
|
2023-12-25 15:25:29 -05:00
|
|
|
_, err = db.DeleteByID[repo_model.Release](db.DefaultContext, release.ID)
|
2021-12-20 22:12:27 -05:00
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
|
2022-11-19 03:12:33 -05:00
|
|
|
protectedTags, err := git_model.GetProtectedTags(db.DefaultContext, repo.ID)
|
2021-12-20 22:12:27 -05:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
for _, protectedTag := range protectedTags {
|
2022-11-19 03:12:33 -05:00
|
|
|
err = git_model.DeleteProtectedTag(db.DefaultContext, protectedTag)
|
2021-12-20 22:12:27 -05:00
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
2021-06-25 10:28:55 -04:00
|
|
|
}
|