From 1d64fef1a13a810550b3bba08bfaa23c7c63522b Mon Sep 17 00:00:00 2001 From: Aidan Steele Date: Tue, 9 Apr 2019 20:45:58 +1000 Subject: [PATCH 1/2] =?UTF-8?q?Use=20docker=E2=80=99s=20stdcopy=20to=20ens?= =?UTF-8?q?ure=20we=20don=E2=80=99t=20emit=20garbage=20bytes=20to=20stdout?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- container/docker_common.go | 11 ++++---- container/docker_run_test.go | 55 ++++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+), 6 deletions(-) create mode 100644 container/docker_run_test.go diff --git a/container/docker_common.go b/container/docker_common.go index 1a33eb0..5d9352e 100644 --- a/container/docker_common.go +++ b/container/docker_common.go @@ -6,6 +6,7 @@ import ( "encoding/json" "errors" "fmt" + "github.com/docker/docker/pkg/stdcopy" "io" "os" @@ -31,12 +32,10 @@ type dockerMessage struct { } func (i *DockerExecutorInput) logDockerOutput(dockerResponse io.Reader) { - scanner := bufio.NewScanner(dockerResponse) - if i.Logger == nil { - return - } - for scanner.Scan() { - i.Logger.Infof(scanner.Text()) + w := i.Logger.Writer() + _, err := stdcopy.StdCopy(w, w, dockerResponse) + if err != nil { + i.Logger.Error(err) } } diff --git a/container/docker_run_test.go b/container/docker_run_test.go new file mode 100644 index 0000000..a1dfd9c --- /dev/null +++ b/container/docker_run_test.go @@ -0,0 +1,55 @@ +package container + +import ( + "bytes" + "context" + "github.com/nektos/act/common" + "github.com/sirupsen/logrus" + "github.com/stretchr/testify/assert" + "io/ioutil" + "testing" +) + +type rawFormatter struct{} + +func (f *rawFormatter) Format(entry *logrus.Entry) ([]byte, error) { + return []byte(entry.Message), nil +} + +func TestNewDockerRunExecutor(t *testing.T) { + if testing.Short() { + t.Skip("skipping slower test") + } + + noopLogger := logrus.New() + noopLogger.SetOutput(ioutil.Discard) + + buf := &bytes.Buffer{} + logger := logrus.New() + logger.SetOutput(buf) + logger.SetFormatter(&rawFormatter{}) + + runner := NewDockerRunExecutor(NewDockerRunExecutorInput{ + DockerExecutorInput: DockerExecutorInput{ + Ctx: context.TODO(), + Logger: logrus.NewEntry(logger), + }, + Image: "hello-world", + }) + + puller := NewDockerPullExecutor(NewDockerPullExecutorInput{ + DockerExecutorInput: DockerExecutorInput{ + Ctx: context.TODO(), + Logger: logrus.NewEntry(noopLogger), + }, + Image: "hello-world", + }) + + pipeline := common.NewPipelineExecutor(puller, runner) + err := pipeline() + assert.NoError(t, err) + + expected := `docker run image=hello-world entrypoint=[] cmd=[]Hello from Docker!` + actual := buf.String() + assert.Equal(t, expected, actual[:len(expected)]) +} From 367ec0c61c43de19fbb1ae7a01283eb66b436d9a Mon Sep 17 00:00:00 2001 From: Max Held Date: Mon, 20 May 2019 19:49:10 +0200 Subject: [PATCH 2/2] explain how to "skip" some actions using filter I just figured this out; might be helpful for other users. --- README.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/README.md b/README.md index 842f446..f26e3f5 100644 --- a/README.md +++ b/README.md @@ -49,6 +49,21 @@ act -r act -v ``` +# Skip Actions When Run in `act` + +You may sometimes want to skip some actions when you're running a `main.workflow` in act, such as deployment. +You can achieve something similar by using a [filter](https://github.com/actions/bin/tree/master/filter) action, filtering on all [`GITHUB_ACTOR`](https://developer.github.com/actions/creating-github-actions/accessing-the-runtime-environment/#environment-variables)s *except* `nektos/act`, which is the `GITHUB_ACTOR` set by `act`. + +``` +action "Filter Not Act" { + uses = "actions/bin/filter@3c0b4f0e63ea54ea5df2914b4fabf383368cd0da" + args = "not actor nektos/act" +} +``` + +Just remember that GitHub actions will cancel all upcoming and concurrent actions on a neutral exit code. +To avoid prematurely cancelling actions, place this filter at the latest possible point in the build graph. + # Support Need help? Ask on [Gitter](https://gitter.im/nektos/act)!