2023-01-31 07:49:55 +00:00
|
|
|
package jobparser
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/nektos/act/pkg/model"
|
2023-03-29 05:57:29 +00:00
|
|
|
|
2023-01-31 07:49:55 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
2023-03-29 05:57:29 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"gopkg.in/yaml.v3"
|
2023-01-31 07:49:55 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestParseRawOn(t *testing.T) {
|
|
|
|
kases := []struct {
|
|
|
|
input string
|
|
|
|
result []*Event
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
input: "on: issue_comment",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "issue_comment",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
input: "on:\n - push\n - pull_request",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "pull_request",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n branches:\n - master",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"branches": {
|
|
|
|
"master",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n branch_protection_rule:\n types: [created, deleted]",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "branch_protection_rule",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"types": {
|
|
|
|
"created",
|
|
|
|
"deleted",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n project:\n types: [created, deleted]\n milestone:\n types: [opened, deleted]",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "project",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"types": {
|
|
|
|
"created",
|
|
|
|
"deleted",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "milestone",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"types": {
|
|
|
|
"opened",
|
|
|
|
"deleted",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n pull_request:\n types:\n - opened\n branches:\n - 'releases/**'",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "pull_request",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"types": {
|
|
|
|
"opened",
|
|
|
|
},
|
|
|
|
"branches": {
|
|
|
|
"releases/**",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n branches:\n - main\n pull_request:\n types:\n - opened\n branches:\n - '**'",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"branches": {
|
|
|
|
"main",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "pull_request",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"types": {
|
|
|
|
"opened",
|
|
|
|
},
|
|
|
|
"branches": {
|
|
|
|
"**",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n branches:\n - 'main'\n - 'releases/**'",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"branches": {
|
|
|
|
"main",
|
|
|
|
"releases/**",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n tags:\n - v1.**",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "push",
|
2023-03-24 12:15:46 +00:00
|
|
|
acts: map[string][]string{
|
2023-01-31 07:49:55 +00:00
|
|
|
"tags": {
|
|
|
|
"v1.**",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on: [pull_request, workflow_dispatch]",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "pull_request",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Name: "workflow_dispatch",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2023-03-24 12:15:46 +00:00
|
|
|
{
|
|
|
|
input: "on:\n schedule:\n - cron: '20 6 * * *'",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "schedule",
|
|
|
|
schedules: []map[string]string{
|
|
|
|
{
|
|
|
|
"cron": "20 6 * * *",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-08-22 12:25:17 +00:00
|
|
|
{
|
|
|
|
input: "on:\n workflow_dispatch:\n inputs:\n test:\n type: string",
|
|
|
|
result: []*Event{
|
|
|
|
{
|
|
|
|
Name: "workflow_dispatch",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2023-01-31 07:49:55 +00:00
|
|
|
}
|
|
|
|
for _, kase := range kases {
|
|
|
|
t.Run(kase.input, func(t *testing.T) {
|
|
|
|
origin, err := model.ReadWorkflow(strings.NewReader(kase.input))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
events, err := ParseRawOn(&origin.RawOn)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, kase.result, events, fmt.Sprintf("%#v", events))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2023-03-29 05:57:29 +00:00
|
|
|
|
|
|
|
func TestSingleWorkflow_SetJob(t *testing.T) {
|
|
|
|
t.Run("erase needs", func(t *testing.T) {
|
|
|
|
content := ReadTestdata(t, "erase_needs.in.yaml")
|
|
|
|
want := ReadTestdata(t, "erase_needs.out.yaml")
|
|
|
|
swf, err := Parse(content)
|
|
|
|
require.NoError(t, err)
|
|
|
|
builder := &strings.Builder{}
|
|
|
|
for _, v := range swf {
|
|
|
|
id, job := v.Job()
|
|
|
|
require.NoError(t, v.SetJob(id, job.EraseNeeds()))
|
|
|
|
|
|
|
|
if builder.Len() > 0 {
|
|
|
|
builder.WriteString("---\n")
|
|
|
|
}
|
|
|
|
encoder := yaml.NewEncoder(builder)
|
|
|
|
encoder.SetIndent(2)
|
|
|
|
require.NoError(t, encoder.Encode(v))
|
|
|
|
}
|
|
|
|
assert.Equal(t, string(want), builder.String())
|
|
|
|
})
|
|
|
|
}
|
2023-04-24 15:16:41 +00:00
|
|
|
|
|
|
|
func TestParseMappingNode(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
input string
|
|
|
|
scalars []string
|
|
|
|
datas []interface{}
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n branches:\n - master",
|
|
|
|
scalars: []string{"push"},
|
|
|
|
datas: []interface {
|
|
|
|
}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"branches": []interface{}{"master"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n branch_protection_rule:\n types: [created, deleted]",
|
|
|
|
scalars: []string{"branch_protection_rule"},
|
|
|
|
datas: []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"types": []interface{}{"created", "deleted"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n project:\n types: [created, deleted]\n milestone:\n types: [opened, deleted]",
|
|
|
|
scalars: []string{"project", "milestone"},
|
|
|
|
datas: []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"types": []interface{}{"created", "deleted"},
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"types": []interface{}{"opened", "deleted"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n pull_request:\n types:\n - opened\n branches:\n - 'releases/**'",
|
|
|
|
scalars: []string{"pull_request"},
|
|
|
|
datas: []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"types": []interface{}{"opened"},
|
|
|
|
"branches": []interface{}{"releases/**"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n push:\n branches:\n - main\n pull_request:\n types:\n - opened\n branches:\n - '**'",
|
|
|
|
scalars: []string{"push", "pull_request"},
|
|
|
|
datas: []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"branches": []interface{}{"main"},
|
|
|
|
},
|
|
|
|
map[string]interface{}{
|
|
|
|
"types": []interface{}{"opened"},
|
|
|
|
"branches": []interface{}{"**"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
input: "on:\n schedule:\n - cron: '20 6 * * *'",
|
|
|
|
scalars: []string{"schedule"},
|
|
|
|
datas: []interface{}{
|
|
|
|
[]interface{}{map[string]interface{}{
|
|
|
|
"cron": "20 6 * * *",
|
|
|
|
}},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.input, func(t *testing.T) {
|
|
|
|
workflow, err := model.ReadWorkflow(strings.NewReader(test.input))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
scalars, datas, err := parseMappingNode[interface{}](&workflow.RawOn)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, test.scalars, scalars, fmt.Sprintf("%#v", scalars))
|
|
|
|
assert.EqualValues(t, test.datas, datas, fmt.Sprintf("%#v", datas))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|