mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Fix schedule tasks bugs (#28691)
Fix #28157 This PR fix the possible bugs about actions schedule. ## The Changes - Move `UpdateRepositoryUnit` and `SetRepoDefaultBranch` from models to service layer - Remove schedules plan from database and cancel waiting & running schedules tasks in this repository when actions unit has been disabled or global disabled. - Remove schedules plan from database and cancel waiting & running schedules tasks in this repository when default branch changed.
This commit is contained in:
		| @@ -117,6 +117,9 @@ func notify(ctx context.Context, input *notifyInput) error { | ||||
| 		return nil | ||||
| 	} | ||||
| 	if unit_model.TypeActions.UnitGlobalDisabled() { | ||||
| 		if err := actions_model.CleanRepoScheduleTasks(ctx, input.Repo); err != nil { | ||||
| 			log.Error("CleanRepoScheduleTasks: %v", err) | ||||
| 		} | ||||
| 		return nil | ||||
| 	} | ||||
| 	if err := input.Repo.LoadUnits(ctx); err != nil { | ||||
| @@ -153,7 +156,11 @@ func notify(ctx context.Context, input *notifyInput) error { | ||||
|  | ||||
| 	var detectedWorkflows []*actions_module.DetectedWorkflow | ||||
| 	actionsConfig := input.Repo.MustGetUnit(ctx, unit_model.TypeActions).ActionsConfig() | ||||
| 	workflows, schedules, err := actions_module.DetectWorkflows(gitRepo, commit, input.Event, input.Payload) | ||||
| 	workflows, schedules, err := actions_module.DetectWorkflows(gitRepo, commit, | ||||
| 		input.Event, | ||||
| 		input.Payload, | ||||
| 		input.Event == webhook_module.HookEventPush && input.Ref == input.Repo.DefaultBranch, | ||||
| 	) | ||||
| 	if err != nil { | ||||
| 		return fmt.Errorf("DetectWorkflows: %w", err) | ||||
| 	} | ||||
| @@ -167,7 +174,7 @@ func notify(ctx context.Context, input *notifyInput) error { | ||||
| 				continue | ||||
| 			} | ||||
|  | ||||
| 			if wf.TriggerEvent != actions_module.GithubEventPullRequestTarget { | ||||
| 			if wf.TriggerEvent.Name != actions_module.GithubEventPullRequestTarget { | ||||
| 				detectedWorkflows = append(detectedWorkflows, wf) | ||||
| 			} | ||||
| 		} | ||||
| @@ -180,7 +187,7 @@ func notify(ctx context.Context, input *notifyInput) error { | ||||
| 		if err != nil { | ||||
| 			return fmt.Errorf("gitRepo.GetCommit: %w", err) | ||||
| 		} | ||||
| 		baseWorkflows, _, err := actions_module.DetectWorkflows(gitRepo, baseCommit, input.Event, input.Payload) | ||||
| 		baseWorkflows, _, err := actions_module.DetectWorkflows(gitRepo, baseCommit, input.Event, input.Payload, false) | ||||
| 		if err != nil { | ||||
| 			return fmt.Errorf("DetectWorkflows: %w", err) | ||||
| 		} | ||||
| @@ -188,7 +195,7 @@ func notify(ctx context.Context, input *notifyInput) error { | ||||
| 			log.Trace("repo %s with commit %s couldn't find pull_request_target workflows", input.Repo.RepoPath(), baseCommit.ID) | ||||
| 		} else { | ||||
| 			for _, wf := range baseWorkflows { | ||||
| 				if wf.TriggerEvent == actions_module.GithubEventPullRequestTarget { | ||||
| 				if wf.TriggerEvent.Name == actions_module.GithubEventPullRequestTarget { | ||||
| 					detectedWorkflows = append(detectedWorkflows, wf) | ||||
| 				} | ||||
| 			} | ||||
| @@ -265,7 +272,7 @@ func handleWorkflows( | ||||
| 			IsForkPullRequest: isForkPullRequest, | ||||
| 			Event:             input.Event, | ||||
| 			EventPayload:      string(p), | ||||
| 			TriggerEvent:      dwf.TriggerEvent, | ||||
| 			TriggerEvent:      dwf.TriggerEvent.Name, | ||||
| 			Status:            actions_model.StatusWaiting, | ||||
| 		} | ||||
| 		if need, err := ifNeedApproval(ctx, run, input.Repo, input.Doer); err != nil { | ||||
| @@ -289,6 +296,7 @@ func handleWorkflows( | ||||
| 				run.RepoID, | ||||
| 				run.Ref, | ||||
| 				run.WorkflowID, | ||||
| 				run.Event, | ||||
| 			); err != nil { | ||||
| 				log.Error("CancelRunningJobs: %v", err) | ||||
| 			} | ||||
| @@ -414,8 +422,8 @@ func handleSchedules( | ||||
| 		log.Error("CountSchedules: %v", err) | ||||
| 		return err | ||||
| 	} else if count > 0 { | ||||
| 		if err := actions_model.DeleteScheduleTaskByRepo(ctx, input.Repo.ID); err != nil { | ||||
| 			log.Error("DeleteCronTaskByRepo: %v", err) | ||||
| 		if err := actions_model.CleanRepoScheduleTasks(ctx, input.Repo); err != nil { | ||||
| 			log.Error("CleanRepoScheduleTasks: %v", err) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -456,19 +464,6 @@ func handleSchedules( | ||||
| 			Specs:         schedules, | ||||
| 			Content:       dwf.Content, | ||||
| 		} | ||||
|  | ||||
| 		// cancel running jobs if the event is push | ||||
| 		if run.Event == webhook_module.HookEventPush { | ||||
| 			// cancel running jobs of the same workflow | ||||
| 			if err := actions_model.CancelRunningJobs( | ||||
| 				ctx, | ||||
| 				run.RepoID, | ||||
| 				run.Ref, | ||||
| 				run.WorkflowID, | ||||
| 			); err != nil { | ||||
| 				log.Error("CancelRunningJobs: %v", err) | ||||
| 			} | ||||
| 		} | ||||
| 		crons = append(crons, run) | ||||
| 	} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user