mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Fix bugs in rerunning jobs (#29955)
Fix #28761 Fix #27884 Fix #28093 ## Changes ### Rerun all jobs When rerun all jobs, status of the jobs with `needs` will be set to `blocked` instead of `waiting`. Therefore, these jobs will not run until the required jobs are completed. ### Rerun a single job When a single job is rerun, its dependents should also be rerun, just like GitHub does (https://github.com/go-gitea/gitea/issues/28761#issuecomment-2008620820). In this case, only the specified job will be set to `waiting`, its dependents will be set to `blocked` to wait the job. ### Show warning if every job has `needs` If every job in a workflow has `needs`, all jobs will be blocked and no job can be run. So I add a warning message. <img src="https://github.com/go-gitea/gitea/assets/15528715/88f43511-2360-465d-be96-ee92b57ff67b" width="480px" />
This commit is contained in:
		| @@ -104,8 +104,13 @@ func List(ctx *context.Context) { | ||||
| 				workflows = append(workflows, workflow) | ||||
| 				continue | ||||
| 			} | ||||
| 			// Check whether have matching runner | ||||
| 			// The workflow must contain at least one job without "needs". Otherwise, a deadlock will occur and no jobs will be able to run. | ||||
| 			hasJobWithoutNeeds := false | ||||
| 			// Check whether have matching runner and a job without "needs" | ||||
| 			for _, j := range wf.Jobs { | ||||
| 				if !hasJobWithoutNeeds && len(j.Needs()) == 0 { | ||||
| 					hasJobWithoutNeeds = true | ||||
| 				} | ||||
| 				runsOnList := j.RunsOn() | ||||
| 				for _, ro := range runsOnList { | ||||
| 					if strings.Contains(ro, "${{") { | ||||
| @@ -123,6 +128,9 @@ func List(ctx *context.Context) { | ||||
| 					break | ||||
| 				} | ||||
| 			} | ||||
| 			if !hasJobWithoutNeeds { | ||||
| 				workflow.ErrMsg = ctx.Locale.TrString("actions.runs.no_job_without_needs") | ||||
| 			} | ||||
| 			workflows = append(workflows, workflow) | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user