Skip to content

Commit

Permalink
chore: use error context to log errors rather than Go err style.
Browse files Browse the repository at this point in the history
  • Loading branch information
jrasell committed Jun 17, 2021
1 parent c2cb63f commit 5f3fd32
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 23 deletions.
4 changes: 2 additions & 2 deletions api/exec_start.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ func (c *API) attachHandleResize(ctx context.Context, resizeChannel <-chan drive
c.logger.Trace("Resize terminal", "sessionId", sessionId, "height", size.Height, "width", size.Width)
rerr := c.ExecResize(ctx, sessionId, size.Height, size.Width)
if rerr != nil {
c.logger.Error("Failed to resize TTY", "err", rerr)
c.logger.Error("Failed to resize TTY", "error", rerr)
}
}
}
Expand Down Expand Up @@ -155,7 +155,7 @@ func (c *API) ExecStart(ctx context.Context, sessionID string, options ExecStart
go func() {
_, err := io.Copy(socket, options.Stdin)
if err != nil {
c.logger.Error("Failed to send stdin to exec session", "err", err)
c.logger.Error("Failed to send stdin to exec session", "error", err)
}
}()
}
Expand Down
35 changes: 18 additions & 17 deletions driver.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"context"
"errors"
"fmt"
"github.com/hashicorp/nomad-driver-podman/build/pkg/mod/github.com/hashicorp/[email protected]"
"net"
"path/filepath"
"strconv"
Expand Down Expand Up @@ -181,7 +182,7 @@ func (d *Driver) Capabilities() (*drivers.Capabilities, error) {
func (d *Driver) Fingerprint(ctx context.Context) (<-chan *drivers.Fingerprint, error) {
err := shelpers.Init()
if err != nil {
d.logger.Error("Could not init stats helper", "err", err)
d.logger.Error("Could not init stats helper", "error", err)
return nil, err
}
ch := make(chan *drivers.Fingerprint)
Expand Down Expand Up @@ -217,7 +218,7 @@ func (d *Driver) buildFingerprint() *drivers.Fingerprint {
// try to connect and get version info
info, err := d.podman.SystemInfo(d.ctx)
if err != nil {
d.logger.Error("Could not get podman info", "err", err)
d.logger.Error("Could not get podman info", "error", err)
} else {
// yay! we can enable the driver
health = drivers.HealthStateHealthy
Expand Down Expand Up @@ -263,7 +264,7 @@ func (d *Driver) RecoverTask(handle *drivers.TaskHandle) error {

inspectData, err := d.podman.ContainerInspect(d.ctx, taskState.ContainerID)
if err != nil {
d.logger.Warn("Recovery lookup failed", "task", handle.Config.ID, "container", taskState.ContainerID, "err", err)
d.logger.Warn("Recovery lookup failed", "task", handle.Config.ID, "container", taskState.ContainerID, "error", err)
return nil
}

Expand Down Expand Up @@ -291,7 +292,7 @@ func (d *Driver) RecoverTask(handle *drivers.TaskHandle) error {
if d.config.RecoverStopped {
d.logger.Debug("Found a stopped container, try to start it", "container", inspectData.State.Pid)
if err = d.podman.ContainerStart(d.ctx, inspectData.ID); err != nil {
d.logger.Warn("Recovery restart failed", "task", handle.Config.ID, "container", taskState.ContainerID, "err", err)
d.logger.Warn("Recovery restart failed", "task", handle.Config.ID, "container", taskState.ContainerID, "error", err)
} else {
d.logger.Info("Restarted a container during recovery", "container", inspectData.ID)
h.procState = drivers.TaskStateRunning
Expand Down Expand Up @@ -517,7 +518,7 @@ func (d *Driver) StartTask(cfg *drivers.TaskConfig) (*drivers.TaskHandle, *drive

inspectData, err := d.podman.ContainerInspect(d.ctx, containerID)
if err != nil {
d.logger.Error("failed to inspect container", "err", err)
d.logger.Error("failed to inspect container", "error", err)
cleanup()
return nil, nil, fmt.Errorf("failed to start task, could not inspect container : %v", err)
}
Expand Down Expand Up @@ -651,7 +652,7 @@ func (d *Driver) createImage(image string, auth *AuthConfig, forcePull bool) (st
if err != nil {
// If ImageInspectID errors, continue the operation and try
// to pull the image instead
d.logger.Warn("Unable to check for local image", "image", imageName, "err", err)
d.logger.Warn("Unable to check for local image", "image", imageName, "error", err)
}
if !forcePull && imageID != "" {
d.logger.Debug("Found imageID", imageID, "for image", imageName, "in local storage")
Expand Down Expand Up @@ -731,10 +732,10 @@ func (d *Driver) StopTask(taskID string, timeout time.Duration, signal string) e
if err == nil {
return nil
} else if err == api.ContainerNotFound {
d.logger.Debug("Container not found while we wanted to stop it", "task", taskID, "container", handle.containerID, "err", err)
d.logger.Debug("Container not found while we wanted to stop it", "task", taskID, "container", handle.containerID, "error", err)
return nil
} else {
d.logger.Error("Could not stop/kill container", "containerID", handle.containerID, "err", err)
d.logger.Error("Could not stop/kill container", "containerID", handle.containerID, "error", err)
return err
}
}
Expand Down Expand Up @@ -839,17 +840,17 @@ func (d *Driver) ExecTask(taskID string, cmd []string, timeout time.Duration) (*
defer cancel()
sessionId, err := d.podman.ExecCreate(ctx, handle.containerID, createRequest)
if err != nil {
d.logger.Error("Unable to create ExecTask session", "err", err)
d.logger.Error("Unable to create ExecTask session", "error", err)
return nil, err
}
stdout, err := circbuf.NewBuffer(int64(drivers.CheckBufSize))
if err != nil {
d.logger.Error("ExecTask session failed, unable to allocate stdout buffer", "sessionId", sessionId, "err", err)
d.logger.Error("ExecTask session failed, unable to allocate stdout buffer", "sessionId", sessionId, "error", err)
return nil, err
}
stderr, err := circbuf.NewBuffer(int64(drivers.CheckBufSize))
if err != nil {
d.logger.Error("ExecTask session failed, unable to allocate stderr buffer", "sessionId", sessionId, "err", err)
d.logger.Error("ExecTask session failed, unable to allocate stderr buffer", "sessionId", sessionId, "error", err)
return nil, err
}
startRequest := api.ExecStartRequest{
Expand All @@ -862,13 +863,13 @@ func (d *Driver) ExecTask(taskID string, cmd []string, timeout time.Duration) (*
}
err = d.podman.ExecStart(ctx, sessionId, startRequest)
if err != nil {
d.logger.Error("ExecTask session returned with error", "sessionId", sessionId, "err", err)
d.logger.Error("ExecTask session returned with error", "sessionId", sessionId, "error", err)
return nil, err
}

inspectData, err := d.podman.ExecInspect(ctx, sessionId)
if err != nil {
d.logger.Error("Unable to inspect finished ExecTask session", "sessionId", sessionId, "err", err)
d.logger.Error("Unable to inspect finished ExecTask session", "sessionId", sessionId, "error", err)
return nil, err
}
execResult := &drivers.ExecTaskResult{
Expand All @@ -878,7 +879,7 @@ func (d *Driver) ExecTask(taskID string, cmd []string, timeout time.Duration) (*
Stdout: stdout.Bytes(),
Stderr: stderr.Bytes(),
}
d.logger.Trace("ExecTask result", "code", execResult.ExitResult.ExitCode, "out", string(execResult.Stdout), "err", string(execResult.Stderr))
d.logger.Trace("ExecTask result", "code", execResult.ExitResult.ExitCode, "out", string(execResult.Stdout), "error", string(execResult.Stderr))

return execResult, nil
}
Expand All @@ -901,7 +902,7 @@ func (d *Driver) ExecTaskStreaming(ctx context.Context, taskID string, execOptio

sessionId, err := d.podman.ExecCreate(ctx, handle.containerID, createRequest)
if err != nil {
d.logger.Error("Unable to create exec session", "err", err)
d.logger.Error("Unable to create exec session", "error", err)
return nil, err
}

Expand All @@ -917,13 +918,13 @@ func (d *Driver) ExecTaskStreaming(ctx context.Context, taskID string, execOptio
}
err = d.podman.ExecStart(ctx, sessionId, startRequest)
if err != nil {
d.logger.Error("Exec session returned with error", "sessionId", sessionId, "err", err)
d.logger.Error("Exec session returned with error", "sessionId", sessionId, "error", err)
return nil, err
}

inspectData, err := d.podman.ExecInspect(ctx, sessionId)
if err != nil {
d.logger.Error("Unable to inspect finished exec session", "sessionId", sessionId, "err", err)
d.logger.Error("Unable to inspect finished exec session", "sessionId", sessionId, "error", err)
return nil, err
}
exitResult := drivers.ExitResult{
Expand Down
8 changes: 4 additions & 4 deletions handle.go
Original file line number Diff line number Diff line change
Expand Up @@ -169,20 +169,20 @@ func (h *TaskHandle) runContainerMonitor() {
gone = true
}
if gone {
h.logger.Debug("Container is not running anymore", "container", h.containerID, "err", statsErr)
h.logger.Debug("Container is not running anymore", "container", h.containerID, "error", statsErr)
// container was stopped, get exit code and other post mortem infos
inspectData, err := h.driver.podman.ContainerInspect(h.driver.ctx, h.containerID)
h.stateLock.Lock()
h.completedAt = time.Now()
if err != nil {
h.exitResult.Err = fmt.Errorf("Driver was unable to get the exit code. %s: %v", h.containerID, err)
h.logger.Error("Failed to inspect stopped container, can not get exit code", "container", h.containerID, "err", err)
h.logger.Error("Failed to inspect stopped container, can not get exit code", "container", h.containerID, "error", err)
h.exitResult.Signal = 0
} else {
h.exitResult.ExitCode = int(inspectData.State.ExitCode)
if len(inspectData.State.Error) > 0 {
h.exitResult.Err = fmt.Errorf(inspectData.State.Error)
h.logger.Error("Container error", "container", h.containerID, "err", h.exitResult.Err)
h.logger.Error("Container error", "container", h.containerID, "error", h.exitResult.Err)
}
h.completedAt = inspectData.State.FinishedAt
if inspectData.State.OOMKilled {
Expand All @@ -198,7 +198,7 @@ func (h *TaskHandle) runContainerMonitor() {
}
// continue and wait for next cycle, it should eventually
// fall into the "TaskStateExited" case
h.logger.Debug("Could not get container stats, unknown error", "err", fmt.Sprintf("%#v", statsErr))
h.logger.Debug("Could not get container stats, unknown error", "error", fmt.Sprintf("%#v", statsErr))
continue
}

Expand Down

0 comments on commit 5f3fd32

Please sign in to comment.