Skip to content

Commit ea9e09a

Browse files
Fix: database not update release when using git push --tags --force (#32040) (#32074)
Backport #32040 by @ExplodingDragon link: https://codeberg.org/forgejo/forgejo/issues/4274 Co-authored-by: Exploding Dragon <[email protected]>
1 parent 2891edb commit ea9e09a

File tree

2 files changed

+46
-8
lines changed

2 files changed

+46
-8
lines changed

Diff for: services/repository/push.go

+10-8
Original file line numberDiff line numberDiff line change
@@ -320,8 +320,9 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
320320
}
321321

322322
releases, err := db.Find[repo_model.Release](ctx, repo_model.FindReleasesOptions{
323-
RepoID: repo.ID,
324-
TagNames: tags,
323+
RepoID: repo.ID,
324+
TagNames: tags,
325+
IncludeTags: true,
325326
})
326327
if err != nil {
327328
return fmt.Errorf("db.Find[repo_model.Release]: %w", err)
@@ -382,12 +383,12 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
382383

383384
rel, has := relMap[lowerTag]
384385

386+
parts := strings.SplitN(tag.Message, "\n", 2)
387+
note := ""
388+
if len(parts) > 1 {
389+
note = parts[1]
390+
}
385391
if !has {
386-
parts := strings.SplitN(tag.Message, "\n", 2)
387-
note := ""
388-
if len(parts) > 1 {
389-
note = parts[1]
390-
}
391392
rel = &repo_model.Release{
392393
RepoID: repo.ID,
393394
Title: parts[0],
@@ -408,10 +409,11 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
408409

409410
newReleases = append(newReleases, rel)
410411
} else {
412+
rel.Title = parts[0]
413+
rel.Note = note
411414
rel.Sha1 = commit.ID.String()
412415
rel.CreatedUnix = timeutil.TimeStamp(createdAt.Unix())
413416
rel.NumCommits = commitsCount
414-
rel.IsDraft = false
415417
if rel.IsTag && author != nil {
416418
rel.PublisherID = author.ID
417419
}

Diff for: tests/integration/repo_tag_test.go

+36
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
package integration
55

66
import (
7+
"net/http"
78
"net/url"
89
"testing"
910

@@ -18,6 +19,7 @@ import (
1819
"code.gitea.io/gitea/tests"
1920

2021
"github.com/stretchr/testify/assert"
22+
"github.com/stretchr/testify/require"
2123
)
2224

2325
func TestCreateNewTagProtected(t *testing.T) {
@@ -60,6 +62,40 @@ func TestCreateNewTagProtected(t *testing.T) {
6062
})
6163
})
6264

65+
t.Run("GitTagForce", func(t *testing.T) {
66+
onGiteaRun(t, func(t *testing.T, u *url.URL) {
67+
httpContext := NewAPITestContext(t, owner.Name, repo.Name)
68+
69+
dstPath := t.TempDir()
70+
71+
u.Path = httpContext.GitPath()
72+
u.User = url.UserPassword(owner.Name, userPassword)
73+
74+
doGitClone(dstPath, u)(t)
75+
76+
_, _, err := git.NewCommand(git.DefaultContext, "tag", "v-1.1", "-m", "force update", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
77+
require.NoError(t, err)
78+
79+
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags").RunStdString(&git.RunOpts{Dir: dstPath})
80+
require.NoError(t, err)
81+
82+
_, _, err = git.NewCommand(git.DefaultContext, "tag", "v-1.1", "-m", "force update v2", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
83+
require.NoError(t, err)
84+
85+
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags").RunStdString(&git.RunOpts{Dir: dstPath})
86+
require.Error(t, err)
87+
assert.Contains(t, err.Error(), "the tag already exists in the remote")
88+
89+
_, _, err = git.NewCommand(git.DefaultContext, "push", "--tags", "--force").RunStdString(&git.RunOpts{Dir: dstPath})
90+
require.NoError(t, err)
91+
req := NewRequestf(t, "GET", "/%s/releases/tag/v-1.1", repo.FullName())
92+
resp := MakeRequest(t, req, http.StatusOK)
93+
htmlDoc := NewHTMLParser(t, resp.Body)
94+
tagsTab := htmlDoc.Find(".release-list-title")
95+
assert.Contains(t, tagsTab.Text(), "force update v2")
96+
})
97+
})
98+
6399
// Cleanup
64100
releases, err := db.Find[repo_model.Release](db.DefaultContext, repo_model.FindReleasesOptions{
65101
IncludeTags: true,

0 commit comments

Comments
 (0)