mirror of
https://github.com/go-gitea/gitea
synced 2025-01-05 17:34:48 +01:00
Add runner check in repo action page (#24124)
![image](https://user-images.githubusercontent.com/18380374/232996647-13c2b9f1-c9e9-42d9-acbf-8a6e16b175a6.png) Maybe we can also add online runner check? e.g. : Target runner is offline.
This commit is contained in:
parent
5e7543fcf4
commit
01214c8ada
3 changed files with 43 additions and 13 deletions
|
@ -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 (
|
||||||
|
@ -24,9 +28,8 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type Workflow struct {
|
type Workflow struct {
|
||||||
Entry git.TreeEntry
|
Entry git.TreeEntry
|
||||||
IsInvalid bool
|
ErrMsg string
|
||||||
ErrMsg string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// MustEnableActions check if actions are enabled in settings
|
// MustEnableActions check if actions are enabled in settings
|
||||||
|
@ -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}}
|
||||||
|
|
Loading…
Reference in a new issue