Skip to content

Commit

Permalink
Refactor Tink Worker
Browse files Browse the repository at this point in the history
* Create ContainerManager and LogCapturer abstractions
* Add tests for new interfaces
* Clean up worker method arguments

Signed-off-by: Micah Hausler <[email protected]>
  • Loading branch information
micahhausler committed Apr 4, 2022
1 parent e1e2af6 commit 5eb8c9b
Show file tree
Hide file tree
Showing 12 changed files with 1,024 additions and 384 deletions.
35 changes: 30 additions & 5 deletions cmd/tink-worker/cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,18 @@ package cmd
import (
"context"
"fmt"
"os"
"strings"
"time"

dockercli "github.com/docker/docker/client"
"github.com/packethost/pkg/log"
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/spf13/pflag"
"github.com/spf13/viper"
"github.com/tinkerbell/tink/client"
"github.com/tinkerbell/tink/cmd/tink-worker/internal"
"github.com/tinkerbell/tink/cmd/tink-worker/worker"
pb "github.com/tinkerbell/tink/protos/workflow"
"google.golang.org/grpc"
)
Expand Down Expand Up @@ -68,10 +70,33 @@ func NewRootCommand(version string, logger log.Logger) *cobra.Command {
}
rClient := pb.NewWorkflowServiceClient(conn)

regConn := internal.NewRegistryConnDetails(registry, user, pwd, logger)
worker := internal.NewWorker(rClient, regConn, logger, registry, retries, retryInterval, maxFileSize)

err = worker.ProcessWorkflowActions(ctx, workerID, captureActionLogs)
dockerClient, err := dockercli.NewClientWithOpts(dockercli.FromEnv, dockercli.WithAPIVersionNegotiation())
if err != nil {
return err
}
containerManager := worker.NewContainerManager(
logger,
dockerClient,
worker.RegistryConnDetails{
Registry: registry,
Username: user,
Password: pwd,
})

logCapturer := worker.NewDockerLogCapturer(dockerClient, logger, os.Stdout)

w := worker.NewWorker(
workerID,
rClient,
containerManager,
logCapturer,
logger,
worker.WithMaxFileSize(maxFileSize),
worker.WithRetries(retryInterval, retries),
worker.WithLogCapture(captureActionLogs),
worker.WithPrivileged(true))

err = w.ProcessWorkflowActions(ctx)
if err != nil {
return errors.Wrap(err, "worker Finished with error")
}
Expand Down
116 changes: 0 additions & 116 deletions cmd/tink-worker/internal/action.go

This file was deleted.

94 changes: 0 additions & 94 deletions cmd/tink-worker/internal/registry.go

This file was deleted.

78 changes: 0 additions & 78 deletions cmd/tink-worker/internal/registry_test.go

This file was deleted.

Loading

0 comments on commit 5eb8c9b

Please sign in to comment.