Skip to content

Commit

Permalink
Merge pull request #46 from sosedoff/capture-build-error
Browse files Browse the repository at this point in the history
Handle docker image build failures
  • Loading branch information
cplee authored Mar 2, 2019
2 parents 1791f1f + 1c25ee9 commit b18239f
Show file tree
Hide file tree
Showing 6 changed files with 45 additions and 19 deletions.
3 changes: 3 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ export GITHUB_TOKEN = $(shell cat ~/.config/github/token)

default: check

test:
go test -cover -short ./...

check:
$(ACT) -ra check

Expand Down
3 changes: 2 additions & 1 deletion actions/runner_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ func TestRunEvent(t *testing.T) {
{"basic.workflow", "push", ""},
{"pipe.workflow", "push", ""},
{"fail.workflow", "push", "exit with `FAILURE`: 1"},
{"buildfail.workflow", "push", "COPY failed"},
{"regex.workflow", "push", "exit with `NEUTRAL`: 78"},
{"gitref.workflow", "push", ""},
{"env.workflow", "push", ""},
Expand All @@ -42,7 +43,7 @@ func TestRunEvent(t *testing.T) {
if table.errorMessage == "" {
assert.NilError(t, err, table.workflowPath)
} else {
assert.Error(t, err, table.errorMessage)
assert.ErrorContains(t, err, table.errorMessage)
}
}
}
2 changes: 2 additions & 0 deletions actions/testdata/buildfail-action/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
FROM alpine:3.8
COPY foobar /foo/bar
8 changes: 8 additions & 0 deletions actions/testdata/buildfail.workflow
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
workflow "test" {
on = "push"
resolves = ["test-action"]
}

action "test-action" {
uses = "./buildfail-action"
}
3 changes: 2 additions & 1 deletion container/docker_build.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,8 @@ func NewDockerBuildExecutor(input NewDockerBuildExecutorInput) common.Executor {

input.Logger.Debugf("Creating image from context dir '%s' with tag '%s'", input.ContextDir, input.ImageTag)
resp, err := cli.ImageBuild(input.Ctx, buildContext, options)
input.logDockerResponse(resp.Body, err != nil)

err = input.logDockerResponse(resp.Body, err != nil)
if err != nil {
return err
}
Expand Down
45 changes: 28 additions & 17 deletions container/docker_common.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"bufio"
"context"
"encoding/json"
"errors"
"fmt"
"io"
"os"
Expand Down Expand Up @@ -64,42 +65,52 @@ func (i *DockerExecutorInput) writeLog(isError bool, format string, args ...inte

}

func (i *DockerExecutorInput) logDockerResponse(dockerResponse io.ReadCloser, isError bool) {
func (i *DockerExecutorInput) logDockerResponse(dockerResponse io.ReadCloser, isError bool) error {
if dockerResponse == nil {
return
return nil
}
defer dockerResponse.Close()

scanner := bufio.NewScanner(dockerResponse)
msg := dockerMessage{}

for scanner.Scan() {
line := scanner.Bytes()

msg.ID = ""
msg.Stream = ""
msg.Error = ""
msg.ErrorDetail.Message = ""
msg.Status = ""
msg.Progress = ""
if err := json.Unmarshal(line, &msg); err == nil {
if msg.Error != "" {
i.writeLog(isError, "%s", msg.Error)
return
}

if msg.Status != "" {
if msg.Progress != "" {
i.writeLog(isError, "%s :: %s :: %s\n", msg.Status, msg.ID, msg.Progress)
} else {
i.writeLog(isError, "%s :: %s\n", msg.Status, msg.ID)
}
} else if msg.Stream != "" {
i.writeLog(isError, msg.Stream)
if err := json.Unmarshal(line, &msg); err != nil {
i.writeLog(false, "Unable to unmarshal line [%s] ==> %v", string(line), err)
continue
}

if msg.Error != "" {
i.writeLog(isError, "%s", msg.Error)
return errors.New(msg.Error)
}

if msg.ErrorDetail.Message != "" {
i.writeLog(isError, "%s", msg.ErrorDetail.Message)
return errors.New(msg.Error)
}

if msg.Status != "" {
if msg.Progress != "" {
i.writeLog(isError, "%s :: %s :: %s\n", msg.Status, msg.ID, msg.Progress)
} else {
i.writeLog(false, "Unable to handle line: %s", string(line))
i.writeLog(isError, "%s :: %s\n", msg.Status, msg.ID)
}
} else if msg.Stream != "" {
i.writeLog(isError, msg.Stream)
} else {
i.writeLog(false, "Unable to unmarshal line [%s] ==> %v", string(line), err)
i.writeLog(false, "Unable to handle line: %s", string(line))
}
}

return nil
}

0 comments on commit b18239f

Please sign in to comment.