forgejo-runner-act/actions/runner_test.go

49 lines
1.1 KiB
Go
Raw Normal View History

2019-01-31 07:53:39 +00:00
package actions
import (
"context"
"testing"
log "github.com/sirupsen/logrus"
"gotest.tools/assert"
)
func TestRunEvent(t *testing.T) {
2019-02-07 17:09:19 +00:00
if testing.Short() {
t.Skip("skipping integration test")
}
2019-01-31 07:53:39 +00:00
tables := []struct {
workflowPath string
eventName string
errorMessage string
}{
{"basic.workflow", "push", ""},
{"pipe.workflow", "push", ""},
{"fail.workflow", "push", "exit with `FAILURE`: 1"},
{"regex.workflow", "push", "exit with `NEUTRAL`: 78"},
2019-02-07 17:09:19 +00:00
{"gitref.workflow", "push", ""},
{"env.workflow", "push", ""},
2019-02-15 16:44:36 +00:00
{"detect_event.workflow", "", ""},
2019-01-31 07:53:39 +00:00
}
log.SetLevel(log.DebugLevel)
for _, table := range tables {
runnerConfig := &RunnerConfig{
Ctx: context.Background(),
WorkflowPath: table.workflowPath,
WorkingDir: "testdata",
EventName: table.eventName,
}
runner, err := NewRunner(runnerConfig)
assert.NilError(t, err, table.workflowPath)
err = runner.RunEvent()
if table.errorMessage == "" {
assert.NilError(t, err, table.workflowPath)
} else {
assert.Error(t, err, table.errorMessage)
}
}
}