tests(runner): move arm64 test to own func (#1095)
Prevents random failing of all other runs when qemu binfmt is not set up Signed-off-by: Ryan <me@hackerc.at> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
This commit is contained in:
parent
afb23a2891
commit
72dd2d344c
3 changed files with 156 additions and 157 deletions
|
@ -12,18 +12,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestJobExecutor(t *testing.T) {
|
func TestJobExecutor(t *testing.T) {
|
||||||
platforms := map[string]string{
|
|
||||||
"ubuntu-latest": baseImage,
|
|
||||||
}
|
|
||||||
tables := []TestJobFileInfo{
|
tables := []TestJobFileInfo{
|
||||||
{"testdata", "uses-and-run-in-one-step", "push", "Invalid run/uses syntax for job:test step:Test", platforms, ""},
|
{workdir, "uses-and-run-in-one-step", "push", "Invalid run/uses syntax for job:test step:Test", platforms},
|
||||||
{"testdata", "uses-github-empty", "push", "Expected format {org}/{repo}[/path]@ref", platforms, ""},
|
{workdir, "uses-github-empty", "push", "Expected format {org}/{repo}[/path]@ref", platforms},
|
||||||
{"testdata", "uses-github-noref", "push", "Expected format {org}/{repo}[/path]@ref", platforms, ""},
|
{workdir, "uses-github-noref", "push", "Expected format {org}/{repo}[/path]@ref", platforms},
|
||||||
{"testdata", "uses-github-root", "push", "", platforms, ""},
|
{workdir, "uses-github-root", "push", "", platforms},
|
||||||
{"testdata", "uses-github-path", "push", "", platforms, ""},
|
{workdir, "uses-github-path", "push", "", platforms},
|
||||||
{"testdata", "uses-docker-url", "push", "", platforms, ""},
|
{workdir, "uses-docker-url", "push", "", platforms},
|
||||||
{"testdata", "uses-github-full-sha", "push", "", platforms, ""},
|
{workdir, "uses-github-full-sha", "push", "", platforms},
|
||||||
{"testdata", "uses-github-short-sha", "push", "Unable to resolve action `actions/hello-world-docker-action@b136eb8`, the provided ref `b136eb8` is the shortened version of a commit SHA, which is not supported. Please use the full commit SHA `b136eb8894c5cb1dd5807da824be97ccdf9b5423` instead", platforms, ""},
|
{workdir, "uses-github-short-sha", "push", "Unable to resolve action `actions/hello-world-docker-action@b136eb8`, the provided ref `b136eb8` is the shortened version of a commit SHA, which is not supported. Please use the full commit SHA `b136eb8894c5cb1dd5807da824be97ccdf9b5423` instead", platforms},
|
||||||
}
|
}
|
||||||
// These tests are sufficient to only check syntax.
|
// These tests are sufficient to only check syntax.
|
||||||
ctx := common.WithDryrun(context.Background(), true)
|
ctx := common.WithDryrun(context.Background(), true)
|
||||||
|
|
|
@ -13,7 +13,6 @@ import (
|
||||||
"github.com/nektos/act/pkg/model"
|
"github.com/nektos/act/pkg/model"
|
||||||
|
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
"github.com/sirupsen/logrus/hooks/test"
|
|
||||||
assert "github.com/stretchr/testify/assert"
|
assert "github.com/stretchr/testify/assert"
|
||||||
yaml "gopkg.in/yaml.v3"
|
yaml "gopkg.in/yaml.v3"
|
||||||
)
|
)
|
||||||
|
@ -26,7 +25,6 @@ func TestRunContext_EvalBool(t *testing.T) {
|
||||||
})
|
})
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
hook := test.NewGlobal()
|
|
||||||
rc := &RunContext{
|
rc := &RunContext{
|
||||||
Config: &Config{
|
Config: &Config{
|
||||||
Workdir: ".",
|
Workdir: ".",
|
||||||
|
@ -157,14 +155,12 @@ func TestRunContext_EvalBool(t *testing.T) {
|
||||||
table := table
|
table := table
|
||||||
t.Run(table.in, func(t *testing.T) {
|
t.Run(table.in, func(t *testing.T) {
|
||||||
assertObject := assert.New(t)
|
assertObject := assert.New(t)
|
||||||
defer hook.Reset()
|
|
||||||
b, err := EvalBool(rc.ExprEval, table.in)
|
b, err := EvalBool(rc.ExprEval, table.in)
|
||||||
if table.wantErr {
|
if table.wantErr {
|
||||||
assertObject.Error(err)
|
assertObject.Error(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
assertObject.Equal(table.out, b, fmt.Sprintf("Expected %s to be %v, was %v", table.in, table.out, b))
|
assertObject.Equal(table.out, b, fmt.Sprintf("Expected %s to be %v, was %v", table.in, table.out, b))
|
||||||
assertObject.Empty(hook.LastEntry(), table.in)
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,12 +16,31 @@ import (
|
||||||
"github.com/nektos/act/pkg/model"
|
"github.com/nektos/act/pkg/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
var baseImage = "node:16-buster-slim"
|
var (
|
||||||
|
baseImage = "node:16-buster-slim"
|
||||||
|
platforms map[string]string
|
||||||
|
logLevel = log.DebugLevel
|
||||||
|
workdir = "testdata"
|
||||||
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
if p := os.Getenv("ACT_TEST_IMAGE"); p != "" {
|
if p := os.Getenv("ACT_TEST_IMAGE"); p != "" {
|
||||||
baseImage = p
|
baseImage = p
|
||||||
}
|
}
|
||||||
|
|
||||||
|
platforms = map[string]string{
|
||||||
|
"ubuntu-latest": baseImage,
|
||||||
|
}
|
||||||
|
|
||||||
|
if l := os.Getenv("ACT_TEST_LOG_LEVEL"); l != "" {
|
||||||
|
if lvl, err := log.ParseLevel(l); err == nil {
|
||||||
|
logLevel = lvl
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if wd, err := filepath.Abs(workdir); err == nil {
|
||||||
|
workdir = wd
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGraphEvent(t *testing.T) {
|
func TestGraphEvent(t *testing.T) {
|
||||||
|
@ -48,38 +67,47 @@ type TestJobFileInfo struct {
|
||||||
eventName string
|
eventName string
|
||||||
errorMessage string
|
errorMessage string
|
||||||
platforms map[string]string
|
platforms map[string]string
|
||||||
containerArchitecture string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func runTestJobFile(ctx context.Context, t *testing.T, tjfi TestJobFileInfo) {
|
func (j *TestJobFileInfo) runTest(ctx context.Context, t *testing.T, cfg *Config) {
|
||||||
t.Run(tjfi.workflowPath, func(t *testing.T) {
|
log.SetLevel(logLevel)
|
||||||
workdir, err := filepath.Abs(tjfi.workdir)
|
|
||||||
|
workdir, err := filepath.Abs(j.workdir)
|
||||||
assert.Nil(t, err, workdir)
|
assert.Nil(t, err, workdir)
|
||||||
fullWorkflowPath := filepath.Join(workdir, tjfi.workflowPath)
|
|
||||||
|
fullWorkflowPath := filepath.Join(workdir, j.workflowPath)
|
||||||
runnerConfig := &Config{
|
runnerConfig := &Config{
|
||||||
Workdir: workdir,
|
Workdir: workdir,
|
||||||
BindWorkdir: false,
|
BindWorkdir: false,
|
||||||
EventName: tjfi.eventName,
|
EventName: j.eventName,
|
||||||
Platforms: tjfi.platforms,
|
EventPath: cfg.EventPath,
|
||||||
|
Platforms: j.platforms,
|
||||||
ReuseContainers: false,
|
ReuseContainers: false,
|
||||||
ContainerArchitecture: tjfi.containerArchitecture,
|
Env: cfg.Env,
|
||||||
|
Secrets: cfg.Secrets,
|
||||||
GitHubInstance: "github.com",
|
GitHubInstance: "github.com",
|
||||||
|
ContainerArchitecture: cfg.ContainerArchitecture,
|
||||||
}
|
}
|
||||||
|
|
||||||
runner, err := New(runnerConfig)
|
runner, err := New(runnerConfig)
|
||||||
assert.Nil(t, err, tjfi.workflowPath)
|
assert.Nil(t, err, j.workflowPath)
|
||||||
|
|
||||||
planner, err := model.NewWorkflowPlanner(fullWorkflowPath, true)
|
planner, err := model.NewWorkflowPlanner(fullWorkflowPath, true)
|
||||||
assert.Nil(t, err, fullWorkflowPath)
|
assert.Nil(t, err, fullWorkflowPath)
|
||||||
|
|
||||||
plan := planner.PlanEvent(tjfi.eventName)
|
plan := planner.PlanEvent(j.eventName)
|
||||||
|
|
||||||
err = runner.NewPlanExecutor(plan)(ctx)
|
err = runner.NewPlanExecutor(plan)(ctx)
|
||||||
if tjfi.errorMessage == "" {
|
if j.errorMessage == "" {
|
||||||
assert.Nil(t, err, fullWorkflowPath)
|
assert.Nil(t, err, fullWorkflowPath)
|
||||||
} else {
|
} else {
|
||||||
assert.Error(t, err, tjfi.errorMessage)
|
assert.Error(t, err, j.errorMessage)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func runTestJobFile(ctx context.Context, t *testing.T, j TestJobFileInfo) {
|
||||||
|
t.Run(j.workflowPath, func(t *testing.T) {
|
||||||
|
j.runTest(ctx, t, &Config{})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,112 +116,109 @@ func TestRunEvent(t *testing.T) {
|
||||||
t.Skip("skipping integration test")
|
t.Skip("skipping integration test")
|
||||||
}
|
}
|
||||||
|
|
||||||
platforms := map[string]string{
|
ctx := context.Background()
|
||||||
"ubuntu-latest": baseImage,
|
|
||||||
}
|
|
||||||
|
|
||||||
tables := []TestJobFileInfo{
|
tables := []TestJobFileInfo{
|
||||||
{"testdata", "basic", "push", "", platforms, ""},
|
// Shells
|
||||||
{"testdata", "fail", "push", "exit with `FAILURE`: 1", platforms, ""},
|
{workdir, "shells/defaults", "push", "", platforms},
|
||||||
{"testdata", "runs-on", "push", "", platforms, ""},
|
|
||||||
{"testdata", "checkout", "push", "", platforms, ""},
|
|
||||||
{"testdata", "non-existent-action", "push", "Job 'nopanic' failed", platforms, ""},
|
|
||||||
{"testdata", "shells/defaults", "push", "", platforms, ""},
|
|
||||||
// TODO: figure out why it fails
|
// TODO: figure out why it fails
|
||||||
// {"testdata", "shells/custom", "push", "", map[string]string{"ubuntu-latest": "ghcr.io/justingrote/act-pwsh:latest"}, ""}, // custom image with pwsh
|
// {workdir, "shells/custom", "push", "", map[string]string{"ubuntu-latest": "ghcr.io/justingrote/act-pwsh:latest"}, }, // custom image with pwsh
|
||||||
{"testdata", "shells/pwsh", "push", "", map[string]string{"ubuntu-latest": "ghcr.io/justingrote/act-pwsh:latest"}, ""}, // custom image with pwsh
|
{workdir, "shells/pwsh", "push", "", map[string]string{"ubuntu-latest": "ghcr.io/justingrote/act-pwsh:latest"}}, // custom image with pwsh
|
||||||
{"testdata", "shells/bash", "push", "", platforms, ""},
|
{workdir, "shells/bash", "push", "", platforms},
|
||||||
{"testdata", "shells/python", "push", "", map[string]string{"ubuntu-latest": "node:16-buster"}, ""}, // slim doesn't have python
|
{workdir, "shells/python", "push", "", map[string]string{"ubuntu-latest": "node:16-buster"}}, // slim doesn't have python
|
||||||
{"testdata", "shells/sh", "push", "", platforms, ""},
|
{workdir, "shells/sh", "push", "", platforms},
|
||||||
{"testdata", "job-container", "push", "", platforms, ""},
|
|
||||||
{"testdata", "job-container-non-root", "push", "", platforms, ""},
|
|
||||||
{"testdata", "container-hostname", "push", "", platforms, ""},
|
|
||||||
{"testdata", "uses-docker-url", "push", "", platforms, ""},
|
|
||||||
{"testdata", "remote-action-docker", "push", "", platforms, ""},
|
|
||||||
{"testdata", "remote-action-js", "push", "", platforms, ""},
|
|
||||||
{"testdata", "local-action-docker-url", "push", "", platforms, ""},
|
|
||||||
{"testdata", "local-action-dockerfile", "push", "", platforms, ""},
|
|
||||||
{"testdata", "local-action-via-composite-dockerfile", "push", "", platforms, ""},
|
|
||||||
{"testdata", "local-action-js", "push", "", platforms, ""},
|
|
||||||
{"testdata", "matrix", "push", "", platforms, ""},
|
|
||||||
{"testdata", "matrix-include-exclude", "push", "", platforms, ""},
|
|
||||||
{"testdata", "commands", "push", "", platforms, ""},
|
|
||||||
{"testdata", "workdir", "push", "", platforms, ""},
|
|
||||||
{"testdata", "defaults-run", "push", "", platforms, ""},
|
|
||||||
{"testdata", "uses-composite", "push", "", platforms, ""},
|
|
||||||
{"testdata", "uses-composite-with-error", "push", "Job 'failing-composite-action' failed", platforms, ""},
|
|
||||||
{"testdata", "uses-nested-composite", "push", "", platforms, ""},
|
|
||||||
{"testdata", "uses-workflow", "push", "reusable workflows are currently not supported (see https://github.com/nektos/act/issues/826 for updates)", platforms, ""},
|
|
||||||
{"testdata", "composite-fail-with-output", "push", "", platforms, ""},
|
|
||||||
{"testdata", "issue-597", "push", "", platforms, ""},
|
|
||||||
{"testdata", "issue-598", "push", "", platforms, ""},
|
|
||||||
{"testdata", "if-env-act", "push", "", platforms, ""},
|
|
||||||
{"testdata", "env-and-path", "push", "", platforms, ""},
|
|
||||||
{"testdata", "outputs", "push", "", platforms, ""},
|
|
||||||
{"testdata", "steps-context/conclusion", "push", "", platforms, ""},
|
|
||||||
{"testdata", "steps-context/outcome", "push", "", platforms, ""},
|
|
||||||
{"testdata", "job-status-check", "push", "job 'fail' failed", platforms, ""},
|
|
||||||
{"testdata", "if-expressions", "push", "Job 'mytest' failed", platforms, ""},
|
|
||||||
{"testdata", "evalmatrix", "push", "", platforms, ""},
|
|
||||||
{"testdata", "evalmatrixneeds", "push", "", platforms, ""},
|
|
||||||
{"testdata", "evalmatrixneeds2", "push", "", platforms, ""},
|
|
||||||
{"testdata", "evalmatrix-merge-map", "push", "", platforms, ""},
|
|
||||||
{"testdata", "evalmatrix-merge-array", "push", "", platforms, ""},
|
|
||||||
{"../model/testdata", "strategy", "push", "", platforms, ""}, // TODO: move all testdata into pkg so we can validate it with planner and runner
|
|
||||||
// {"testdata", "issue-228", "push", "", platforms, ""}, // TODO [igni]: Remove this once everything passes
|
|
||||||
{"../model/testdata", "container-volumes", "push", "", platforms, ""},
|
|
||||||
|
|
||||||
// single test for different architecture: linux/arm64
|
// Local action
|
||||||
{"testdata", "basic", "push", "", platforms, "linux/arm64"},
|
{workdir, "local-action-docker-url", "push", "", platforms},
|
||||||
|
{workdir, "local-action-dockerfile", "push", "", platforms},
|
||||||
|
{workdir, "local-action-via-composite-dockerfile", "push", "", platforms},
|
||||||
|
{workdir, "local-action-js", "push", "", platforms},
|
||||||
|
|
||||||
|
// Uses
|
||||||
|
{workdir, "uses-composite", "push", "", platforms},
|
||||||
|
{workdir, "uses-composite-with-error", "push", "Job 'failing-composite-action' failed", platforms},
|
||||||
|
{workdir, "uses-nested-composite", "push", "", platforms},
|
||||||
|
{workdir, "uses-workflow", "push", "reusable workflows are currently not supported (see https://github.com/nektos/act/issues/826 for updates)", platforms},
|
||||||
|
{workdir, "uses-docker-url", "push", "", platforms},
|
||||||
|
|
||||||
|
// Eval
|
||||||
|
{workdir, "evalmatrix", "push", "", platforms},
|
||||||
|
{workdir, "evalmatrixneeds", "push", "", platforms},
|
||||||
|
{workdir, "evalmatrixneeds2", "push", "", platforms},
|
||||||
|
{workdir, "evalmatrix-merge-map", "push", "", platforms},
|
||||||
|
{workdir, "evalmatrix-merge-array", "push", "", platforms},
|
||||||
|
|
||||||
|
{workdir, "basic", "push", "", platforms},
|
||||||
|
{workdir, "fail", "push", "exit with `FAILURE`: 1", platforms},
|
||||||
|
{workdir, "runs-on", "push", "", platforms},
|
||||||
|
{workdir, "checkout", "push", "", platforms},
|
||||||
|
{workdir, "job-container", "push", "", platforms},
|
||||||
|
{workdir, "job-container-non-root", "push", "", platforms},
|
||||||
|
{workdir, "container-hostname", "push", "", platforms},
|
||||||
|
{workdir, "remote-action-docker", "push", "", platforms},
|
||||||
|
{workdir, "remote-action-js", "push", "", platforms},
|
||||||
|
{workdir, "matrix", "push", "", platforms},
|
||||||
|
{workdir, "matrix-include-exclude", "push", "", platforms},
|
||||||
|
{workdir, "commands", "push", "", platforms},
|
||||||
|
{workdir, "workdir", "push", "", platforms},
|
||||||
|
{workdir, "defaults-run", "push", "", platforms},
|
||||||
|
{workdir, "composite-fail-with-output", "push", "", platforms},
|
||||||
|
{workdir, "issue-597", "push", "", platforms},
|
||||||
|
{workdir, "issue-598", "push", "", platforms},
|
||||||
|
{workdir, "if-env-act", "push", "", platforms},
|
||||||
|
{workdir, "env-and-path", "push", "", platforms},
|
||||||
|
{workdir, "non-existent-action", "push", "Job 'nopanic' failed", platforms},
|
||||||
|
{workdir, "outputs", "push", "", platforms},
|
||||||
|
{workdir, "steps-context/conclusion", "push", "", platforms},
|
||||||
|
{workdir, "steps-context/outcome", "push", "", platforms},
|
||||||
|
{workdir, "job-status-check", "push", "job 'fail' failed", platforms},
|
||||||
|
{workdir, "if-expressions", "push", "Job 'mytest' failed", platforms},
|
||||||
|
{"../model/testdata", "strategy", "push", "", platforms}, // TODO: move all testdata into pkg so we can validate it with planner and runner
|
||||||
|
// {"testdata", "issue-228", "push", "", platforms, }, // TODO [igni]: Remove this once everything passes
|
||||||
|
{"../model/testdata", "container-volumes", "push", "", platforms},
|
||||||
}
|
}
|
||||||
log.SetLevel(log.DebugLevel)
|
|
||||||
|
|
||||||
ctx := context.Background()
|
|
||||||
|
|
||||||
for _, table := range tables {
|
for _, table := range tables {
|
||||||
runTestJobFile(ctx, t, table)
|
runTestJobFile(ctx, t, table)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRunEventSecrets(t *testing.T) {
|
func TestRunDifferentArchitecture(t *testing.T) {
|
||||||
if testing.Short() {
|
if testing.Short() {
|
||||||
t.Skip("skipping integration test")
|
t.Skip("skipping integration test")
|
||||||
}
|
}
|
||||||
|
|
||||||
log.SetLevel(log.DebugLevel)
|
tjfi := TestJobFileInfo{
|
||||||
ctx := context.Background()
|
workdir: workdir,
|
||||||
|
workflowPath: "basic",
|
||||||
platforms := map[string]string{
|
eventName: "push",
|
||||||
"ubuntu-latest": baseImage,
|
errorMessage: "",
|
||||||
|
platforms: platforms,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tjfi.runTest(context.Background(), t, &Config{ContainerArchitecture: "linux/arm64"})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunEventSecrets(t *testing.T) {
|
||||||
|
if testing.Short() {
|
||||||
|
t.Skip("skipping integration test")
|
||||||
|
}
|
||||||
workflowPath := "secrets"
|
workflowPath := "secrets"
|
||||||
eventName := "push"
|
|
||||||
|
|
||||||
workdir, err := filepath.Abs("testdata")
|
tjfi := TestJobFileInfo{
|
||||||
assert.Nil(t, err, workflowPath)
|
workdir: workdir,
|
||||||
|
workflowPath: workflowPath,
|
||||||
env, _ := godotenv.Read(filepath.Join(workdir, workflowPath, ".env"))
|
eventName: "push",
|
||||||
secrets, _ := godotenv.Read(filepath.Join(workdir, workflowPath, ".secrets"))
|
errorMessage: "",
|
||||||
|
platforms: platforms,
|
||||||
runnerConfig := &Config{
|
|
||||||
Workdir: workdir,
|
|
||||||
EventName: eventName,
|
|
||||||
Platforms: platforms,
|
|
||||||
ReuseContainers: false,
|
|
||||||
Secrets: secrets,
|
|
||||||
Env: env,
|
|
||||||
}
|
}
|
||||||
runner, err := New(runnerConfig)
|
|
||||||
assert.Nil(t, err, workflowPath)
|
|
||||||
|
|
||||||
planner, err := model.NewWorkflowPlanner(fmt.Sprintf("testdata/%s", workflowPath), true)
|
env, err := godotenv.Read(filepath.Join(workdir, workflowPath, ".env"))
|
||||||
assert.Nil(t, err, workflowPath)
|
assert.NoError(t, err, "Failed to read .env")
|
||||||
|
secrets, _ := godotenv.Read(filepath.Join(workdir, workflowPath, ".secrets"))
|
||||||
|
assert.NoError(t, err, "Failed to read .secrets")
|
||||||
|
|
||||||
plan := planner.PlanEvent(eventName)
|
tjfi.runTest(context.Background(), t, &Config{Secrets: secrets, Env: env})
|
||||||
|
|
||||||
err = runner.NewPlanExecutor(plan)(ctx)
|
|
||||||
assert.Nil(t, err, workflowPath)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRunEventPullRequest(t *testing.T) {
|
func TestRunEventPullRequest(t *testing.T) {
|
||||||
|
@ -201,36 +226,17 @@ func TestRunEventPullRequest(t *testing.T) {
|
||||||
t.Skip("skipping integration test")
|
t.Skip("skipping integration test")
|
||||||
}
|
}
|
||||||
|
|
||||||
log.SetLevel(log.DebugLevel)
|
|
||||||
ctx := context.Background()
|
|
||||||
|
|
||||||
platforms := map[string]string{
|
|
||||||
"ubuntu-latest": baseImage,
|
|
||||||
}
|
|
||||||
|
|
||||||
workflowPath := "pull-request"
|
workflowPath := "pull-request"
|
||||||
eventName := "pull_request"
|
|
||||||
|
|
||||||
workdir, err := filepath.Abs("testdata")
|
tjfi := TestJobFileInfo{
|
||||||
assert.Nil(t, err, workflowPath)
|
workdir: workdir,
|
||||||
|
workflowPath: workflowPath,
|
||||||
runnerConfig := &Config{
|
eventName: "pull_request",
|
||||||
Workdir: workdir,
|
errorMessage: "",
|
||||||
EventName: eventName,
|
platforms: platforms,
|
||||||
EventPath: filepath.Join(workdir, workflowPath, "event.json"),
|
|
||||||
Platforms: platforms,
|
|
||||||
ReuseContainers: false,
|
|
||||||
}
|
}
|
||||||
runner, err := New(runnerConfig)
|
|
||||||
assert.Nil(t, err, workflowPath)
|
|
||||||
|
|
||||||
planner, err := model.NewWorkflowPlanner(fmt.Sprintf("testdata/%s", workflowPath), true)
|
tjfi.runTest(context.Background(), t, &Config{EventPath: filepath.Join(workdir, workflowPath, "event.json")})
|
||||||
assert.Nil(t, err, workflowPath)
|
|
||||||
|
|
||||||
plan := planner.PlanEvent(eventName)
|
|
||||||
|
|
||||||
err = runner.NewPlanExecutor(plan)(ctx)
|
|
||||||
assert.Nil(t, err, workflowPath)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestContainerPath(t *testing.T) {
|
func TestContainerPath(t *testing.T) {
|
||||||
|
|
Loading…
Reference in a new issue