mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Add runner check in repo action page (#24124)
 Maybe we can also add online runner check? e.g. : Target runner is offline.
This commit is contained in:
		@@ -3407,7 +3407,7 @@ runs.open_tab = %d Open
 | 
				
			|||||||
runs.closed_tab = %d Closed
 | 
					runs.closed_tab = %d Closed
 | 
				
			||||||
runs.commit = Commit
 | 
					runs.commit = Commit
 | 
				
			||||||
runs.pushed_by = Pushed by
 | 
					runs.pushed_by = Pushed by
 | 
				
			||||||
runs.valid_workflow_helper = Workflow config file is valid.
 | 
					 | 
				
			||||||
runs.invalid_workflow_helper = Workflow config file is invalid. Please check your config file: %s
 | 
					runs.invalid_workflow_helper = Workflow config file is invalid. Please check your config file: %s
 | 
				
			||||||
 | 
					runs.no_matching_runner_helper = No matching runner: %s
 | 
				
			||||||
 | 
					
 | 
				
			||||||
need_approval_desc = Need approval to run workflows for fork pull request.
 | 
					need_approval_desc = Need approval to run workflows for fork pull request.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,7 @@
 | 
				
			|||||||
package actions
 | 
					package actions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
 | 
						"bytes"
 | 
				
			||||||
	"net/http"
 | 
						"net/http"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	actions_model "code.gitea.io/gitea/models/actions"
 | 
						actions_model "code.gitea.io/gitea/models/actions"
 | 
				
			||||||
@@ -11,11 +12,14 @@ import (
 | 
				
			|||||||
	"code.gitea.io/gitea/models/unit"
 | 
						"code.gitea.io/gitea/models/unit"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/actions"
 | 
						"code.gitea.io/gitea/modules/actions"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/base"
 | 
						"code.gitea.io/gitea/modules/base"
 | 
				
			||||||
 | 
						"code.gitea.io/gitea/modules/container"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/context"
 | 
						"code.gitea.io/gitea/modules/context"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/git"
 | 
						"code.gitea.io/gitea/modules/git"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/setting"
 | 
						"code.gitea.io/gitea/modules/setting"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/util"
 | 
						"code.gitea.io/gitea/modules/util"
 | 
				
			||||||
	"code.gitea.io/gitea/services/convert"
 | 
						"code.gitea.io/gitea/services/convert"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"github.com/nektos/act/pkg/model"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const (
 | 
					const (
 | 
				
			||||||
@@ -25,7 +29,6 @@ const (
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
type Workflow struct {
 | 
					type Workflow struct {
 | 
				
			||||||
	Entry  git.TreeEntry
 | 
						Entry  git.TreeEntry
 | 
				
			||||||
	IsInvalid bool
 | 
					 | 
				
			||||||
	ErrMsg string
 | 
						ErrMsg string
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -73,6 +76,23 @@ func List(ctx *context.Context) {
 | 
				
			|||||||
			ctx.Error(http.StatusInternalServerError, err.Error())
 | 
								ctx.Error(http.StatusInternalServerError, err.Error())
 | 
				
			||||||
			return
 | 
								return
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// Get all runner labels
 | 
				
			||||||
 | 
							opts := actions_model.FindRunnerOptions{
 | 
				
			||||||
 | 
								RepoID:        ctx.Repo.Repository.ID,
 | 
				
			||||||
 | 
								WithAvailable: true,
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							runners, err := actions_model.FindRunners(ctx, opts)
 | 
				
			||||||
 | 
							if err != nil {
 | 
				
			||||||
 | 
								ctx.ServerError("FindRunners", err)
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							allRunnerLabels := make(container.Set[string])
 | 
				
			||||||
 | 
							for _, r := range runners {
 | 
				
			||||||
 | 
								allRunnerLabels.AddMultiple(r.AgentLabels...)
 | 
				
			||||||
 | 
								allRunnerLabels.AddMultiple(r.CustomLabels...)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		workflows = make([]Workflow, 0, len(entries))
 | 
							workflows = make([]Workflow, 0, len(entries))
 | 
				
			||||||
		for _, entry := range entries {
 | 
							for _, entry := range entries {
 | 
				
			||||||
			workflow := Workflow{Entry: *entry}
 | 
								workflow := Workflow{Entry: *entry}
 | 
				
			||||||
@@ -81,10 +101,24 @@ func List(ctx *context.Context) {
 | 
				
			|||||||
				ctx.Error(http.StatusInternalServerError, err.Error())
 | 
									ctx.Error(http.StatusInternalServerError, err.Error())
 | 
				
			||||||
				return
 | 
									return
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			_, err = actions.GetEventsFromContent(content)
 | 
								wf, err := model.ReadWorkflow(bytes.NewReader(content))
 | 
				
			||||||
			if err != nil {
 | 
								if err != nil {
 | 
				
			||||||
				workflow.IsInvalid = true
 | 
									workflow.ErrMsg = ctx.Locale.Tr("actions.runs.invalid_workflow_helper", err.Error())
 | 
				
			||||||
				workflow.ErrMsg = err.Error()
 | 
									workflows = append(workflows, workflow)
 | 
				
			||||||
 | 
									continue
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								// Check whether have matching runner
 | 
				
			||||||
 | 
								for _, j := range wf.Jobs {
 | 
				
			||||||
 | 
									runsOnList := j.RunsOn()
 | 
				
			||||||
 | 
									for _, ro := range runsOnList {
 | 
				
			||||||
 | 
										if !allRunnerLabels.Contains(ro) {
 | 
				
			||||||
 | 
											workflow.ErrMsg = ctx.Locale.Tr("actions.runs.no_matching_runner_helper", ro)
 | 
				
			||||||
 | 
											break
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									if workflow.ErrMsg != "" {
 | 
				
			||||||
 | 
										break
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
			workflows = append(workflows, workflow)
 | 
								workflows = append(workflows, workflow)
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -10,14 +10,10 @@
 | 
				
			|||||||
					<div class="divider"></div>
 | 
										<div class="divider"></div>
 | 
				
			||||||
					{{range .workflows}}
 | 
										{{range .workflows}}
 | 
				
			||||||
						<a class="item{{if eq .Entry.Name $.CurWorkflow}} active{{end}}" href="{{$.Link}}?workflow={{.Entry.Name}}">{{.Entry.Name}}
 | 
											<a class="item{{if eq .Entry.Name $.CurWorkflow}} active{{end}}" href="{{$.Link}}?workflow={{.Entry.Name}}">{{.Entry.Name}}
 | 
				
			||||||
							{{if .IsInvalid}}
 | 
												{{if .ErrMsg}}
 | 
				
			||||||
								<span data-tooltip-content="{{$.locale.Tr "actions.runs.invalid_workflow_helper" (.ErrMsg)}}">
 | 
													<span data-tooltip-content="{{.ErrMsg}}">
 | 
				
			||||||
									<i class="warning icon red"></i>
 | 
														<i class="warning icon red"></i>
 | 
				
			||||||
								</span>
 | 
													</span>
 | 
				
			||||||
							{{else}}
 | 
					 | 
				
			||||||
								<span data-tooltip-content="{{$.locale.Tr "actions.runs.valid_workflow_helper"}}">
 | 
					 | 
				
			||||||
									<i class="check icon green"></i>
 | 
					 | 
				
			||||||
								</span>
 | 
					 | 
				
			||||||
							{{end}}
 | 
												{{end}}
 | 
				
			||||||
						</a>
 | 
											</a>
 | 
				
			||||||
					{{end}}
 | 
										{{end}}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user