mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 12:01:08 +00:00 
			
		
		
		
	* Split TestPullRequest out of AddTestPullRequestTask
* A Created field is added to the Issue table
* The Created field is set to the time (with nano resolution) on creation
* Record the nano time repo_module.PushUpdateOptions is created by the hook
* The decision to update a pull request created before a commit was
  pushed is based on the time (with nano resolution) the git hook
  was run and the Created field
It ensures the following happens:
* commit C is pushed
* the git hook queues AddTestPullRequestTask for processing and returns with success
* TestPullRequest is not called yet
* a pull request P with commit C as the head is created
* TestPullRequest runs and ignores P because it was created after the commit was received
When the "created" column is NULL, no verification is done, pull
requests that were created before the column was created in the
database cannot be newer than the latest call to a git hook.
Fixes: https://codeberg.org/forgejo/forgejo/issues/2009
(cherry picked from commit 998a431747)
Conflicts:
	models/forgejo_migrations/migrate.go
	see https://codeberg.org/forgejo/forgejo/pulls/3165#issuecomment-1755941
	services/pull/pull.go
	trivial conflicts
		
	
			
		
			
				
	
	
		
			72 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2020 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package repository
 | |
| 
 | |
| import (
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| )
 | |
| 
 | |
| // PushUpdateOptions defines the push update options
 | |
| type PushUpdateOptions struct {
 | |
| 	PusherID     int64
 | |
| 	PusherName   string
 | |
| 	RepoUserName string
 | |
| 	RepoName     string
 | |
| 	RefFullName  git.RefName // branch, tag or other name to push
 | |
| 	OldCommitID  string
 | |
| 	NewCommitID  string
 | |
| 	TimeNano     int64
 | |
| }
 | |
| 
 | |
| // IsNewRef return true if it's a first-time push to a branch, tag or etc.
 | |
| func (opts *PushUpdateOptions) IsNewRef() bool {
 | |
| 	commitID, err := git.NewIDFromString(opts.OldCommitID)
 | |
| 	return err == nil && commitID.IsZero()
 | |
| }
 | |
| 
 | |
| // IsDelRef return true if it's a deletion to a branch or tag
 | |
| func (opts *PushUpdateOptions) IsDelRef() bool {
 | |
| 	commitID, err := git.NewIDFromString(opts.NewCommitID)
 | |
| 	return err == nil && commitID.IsZero()
 | |
| }
 | |
| 
 | |
| // IsUpdateRef return true if it's an update operation
 | |
| func (opts *PushUpdateOptions) IsUpdateRef() bool {
 | |
| 	return !opts.IsNewRef() && !opts.IsDelRef()
 | |
| }
 | |
| 
 | |
| // IsNewTag return true if it's a creation to a tag
 | |
| func (opts *PushUpdateOptions) IsNewTag() bool {
 | |
| 	return opts.RefFullName.IsTag() && opts.IsNewRef()
 | |
| }
 | |
| 
 | |
| // IsDelTag return true if it's a deletion to a tag
 | |
| func (opts *PushUpdateOptions) IsDelTag() bool {
 | |
| 	return opts.RefFullName.IsTag() && opts.IsDelRef()
 | |
| }
 | |
| 
 | |
| // IsNewBranch return true if it's the first-time push to a branch
 | |
| func (opts *PushUpdateOptions) IsNewBranch() bool {
 | |
| 	return opts.RefFullName.IsBranch() && opts.IsNewRef()
 | |
| }
 | |
| 
 | |
| // IsUpdateBranch return true if it's not the first push to a branch
 | |
| func (opts *PushUpdateOptions) IsUpdateBranch() bool {
 | |
| 	return opts.RefFullName.IsBranch() && opts.IsUpdateRef()
 | |
| }
 | |
| 
 | |
| // IsDelBranch return true if it's a deletion to a branch
 | |
| func (opts *PushUpdateOptions) IsDelBranch() bool {
 | |
| 	return opts.RefFullName.IsBranch() && opts.IsDelRef()
 | |
| }
 | |
| 
 | |
| // RefName returns simple name for ref
 | |
| func (opts *PushUpdateOptions) RefName() string {
 | |
| 	return opts.RefFullName.ShortName()
 | |
| }
 | |
| 
 | |
| // RepoFullName returns repo full name
 | |
| func (opts *PushUpdateOptions) RepoFullName() string {
 | |
| 	return opts.RepoUserName + "/" + opts.RepoName
 | |
| }
 |