mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 08:21:11 +00:00 
			
		
		
		
	Merge pull request '[v8.0/forgejo] Fix: database not updated when using git push --tags --force' (#5371) from bp-v8.0/forgejo-a6508f5 into v8.0/forgejo
		
	Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/5371
This commit is contained in:
		
				commit
				
					
						da212f25c5
					
				
			
		
					 2 changed files with 45 additions and 11 deletions
				
			
		| 
						 | 
					@ -311,6 +311,7 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
 | 
				
			||||||
	releases, err := db.Find[repo_model.Release](ctx, repo_model.FindReleasesOptions{
 | 
						releases, err := db.Find[repo_model.Release](ctx, repo_model.FindReleasesOptions{
 | 
				
			||||||
		RepoID:      repo.ID,
 | 
							RepoID:      repo.ID,
 | 
				
			||||||
		TagNames:    tags,
 | 
							TagNames:    tags,
 | 
				
			||||||
 | 
							IncludeTags: true,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return fmt.Errorf("db.Find[repo_model.Release]: %w", err)
 | 
							return fmt.Errorf("db.Find[repo_model.Release]: %w", err)
 | 
				
			||||||
| 
						 | 
					@ -369,14 +370,13 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
 | 
				
			||||||
			return fmt.Errorf("CommitsCount: %w", err)
 | 
								return fmt.Errorf("CommitsCount: %w", err)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		rel, has := relMap[lowerTag]
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if !has {
 | 
					 | 
				
			||||||
		parts := strings.SplitN(tag.Message, "\n", 2)
 | 
							parts := strings.SplitN(tag.Message, "\n", 2)
 | 
				
			||||||
		note := ""
 | 
							note := ""
 | 
				
			||||||
		if len(parts) > 1 {
 | 
							if len(parts) > 1 {
 | 
				
			||||||
			note = parts[1]
 | 
								note = parts[1]
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if rel, has := relMap[lowerTag]; !has {
 | 
				
			||||||
			rel = &repo_model.Release{
 | 
								rel = &repo_model.Release{
 | 
				
			||||||
				RepoID:       repo.ID,
 | 
									RepoID:       repo.ID,
 | 
				
			||||||
				Title:        parts[0],
 | 
									Title:        parts[0],
 | 
				
			||||||
| 
						 | 
					@ -394,13 +394,13 @@ func pushUpdateAddTags(ctx context.Context, repo *repo_model.Repository, gitRepo
 | 
				
			||||||
			if author != nil {
 | 
								if author != nil {
 | 
				
			||||||
				rel.PublisherID = author.ID
 | 
									rel.PublisherID = author.ID
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					 | 
				
			||||||
			newReleases = append(newReleases, rel)
 | 
								newReleases = append(newReleases, rel)
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
 | 
								rel.Title = parts[0]
 | 
				
			||||||
 | 
								rel.Note = note
 | 
				
			||||||
			rel.Sha1 = commit.ID.String()
 | 
								rel.Sha1 = commit.ID.String()
 | 
				
			||||||
			rel.CreatedUnix = timeutil.TimeStamp(createdAt.Unix())
 | 
								rel.CreatedUnix = timeutil.TimeStamp(createdAt.Unix())
 | 
				
			||||||
			rel.NumCommits = commitsCount
 | 
								rel.NumCommits = commitsCount
 | 
				
			||||||
			rel.IsDraft = false
 | 
					 | 
				
			||||||
			if rel.IsTag && author != nil {
 | 
								if rel.IsTag && author != nil {
 | 
				
			||||||
				rel.PublisherID = author.ID
 | 
									rel.PublisherID = author.ID
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -108,6 +108,40 @@ func TestCreateNewTagProtected(t *testing.T) {
 | 
				
			||||||
		})
 | 
							})
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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")
 | 
				
			||||||
 | 
							})
 | 
				
			||||||
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// Cleanup
 | 
						// Cleanup
 | 
				
			||||||
	releases, err := db.Find[repo_model.Release](db.DefaultContext, repo_model.FindReleasesOptions{
 | 
						releases, err := db.Find[repo_model.Release](db.DefaultContext, repo_model.FindReleasesOptions{
 | 
				
			||||||
		IncludeTags: true,
 | 
							IncludeTags: true,
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue