From e204fdcab8c029f9d07a0ff9f7194233d819f8d0 Mon Sep 17 00:00:00 2001 From: Priya Wadhwa Date: Tue, 21 Aug 2018 15:39:25 -0700 Subject: [PATCH 1/3] Add --tail flag to stream logs with skaffold run Shoulf fix #253. Adds option to stream logs from objects deployed by skaffold run. --- cmd/skaffold/app/cmd/cmd.go | 4 ++++ cmd/skaffold/app/cmd/run.go | 1 + pkg/skaffold/config/options.go | 1 + pkg/skaffold/runner/runner.go | 22 +++++++++++++++++++++- pkg/skaffold/runner/runner_test.go | 1 + 5 files changed, 28 insertions(+), 1 deletion(-) diff --git a/cmd/skaffold/app/cmd/cmd.go b/cmd/skaffold/app/cmd/cmd.go index 6fe953077be..0a9545993d5 100644 --- a/cmd/skaffold/app/cmd/cmd.go +++ b/cmd/skaffold/app/cmd/cmd.go @@ -130,6 +130,10 @@ func AddDevFlags(cmd *cobra.Command) { cmd.Flags().BoolVar(&opts.Cleanup, "cleanup", true, "Delete deployments after dev mode is interrupted") } +func AddRunFlags(cmd *cobra.Command) { + cmd.Flags().BoolVar(&opts.Tail, "tail", false, "Stream logs from deployed objects") +} + func AddRunDevFlags(cmd *cobra.Command) { cmd.Flags().StringVarP(&opts.ConfigurationFile, "filename", "f", "skaffold.yaml", "Filename or URL to the pipeline file") cmd.Flags().BoolVar(&opts.Notification, "toot", false, "Emit a terminal beep after the deploy is complete") diff --git a/cmd/skaffold/app/cmd/run.go b/cmd/skaffold/app/cmd/run.go index 064c5f5df82..d1b9aa5cf02 100644 --- a/cmd/skaffold/app/cmd/run.go +++ b/cmd/skaffold/app/cmd/run.go @@ -35,6 +35,7 @@ func NewCmdRun(out io.Writer) *cobra.Command { }, } AddRunDevFlags(cmd) + AddRunFlags(cmd) cmd.Flags().StringVarP(&opts.CustomTag, "tag", "t", "", "The optional custom tag to use for images which overrides the current Tagger configuration") return cmd diff --git a/pkg/skaffold/config/options.go b/pkg/skaffold/config/options.go index 937aef73db9..4b9cdb3fdc3 100644 --- a/pkg/skaffold/config/options.go +++ b/pkg/skaffold/config/options.go @@ -26,6 +26,7 @@ type SkaffoldOptions struct { ConfigurationFile string Cleanup bool Notification bool + Tail bool Profiles []string CustomTag string Namespace string diff --git a/pkg/skaffold/runner/runner.go b/pkg/skaffold/runner/runner.go index ba94c8509b6..6d706fbcaba 100644 --- a/pkg/skaffold/runner/runner.go +++ b/pkg/skaffold/runner/runner.go @@ -172,7 +172,27 @@ func (r *SkaffoldRunner) Run(ctx context.Context, out io.Writer, artifacts []*v1 return errors.Wrap(err, "deploy step") } - return nil + if !r.opts.Tail { + return nil + } + // If tail is true, stream logs from deployed objects + imageList := kubernetes.NewImageList() + for _, build := range bRes { + imageList.Add(build.Tag) + } + colorPicker := kubernetes.NewColorPicker(artifacts) + logger := kubernetes.NewLogAggregator(out, imageList, colorPicker) + + if err := logger.Start(ctx); err != nil { + return errors.Wrap(err, "starting logger") + } + + for { + select { + case <-ctx.Done(): + return nil + } + } } // Dev watches for changes and runs the skaffold build and deploy diff --git a/pkg/skaffold/runner/runner_test.go b/pkg/skaffold/runner/runner_test.go index 7ad44bf586c..1ae74de758e 100644 --- a/pkg/skaffold/runner/runner_test.go +++ b/pkg/skaffold/runner/runner_test.go @@ -266,6 +266,7 @@ func TestRun(t *testing.T) { Builder: test.builder, Deployer: test.deployer, Tagger: &tag.ChecksumTagger{}, + opts: &config.SkaffoldOptions{}, } err := runner.Run(context.Background(), ioutil.Discard, test.config.Build.Artifacts) From e57c004e253150c6e86f111d86480517eee30384 Mon Sep 17 00:00:00 2001 From: Priya Wadhwa Date: Tue, 21 Aug 2018 16:43:35 -0700 Subject: [PATCH 2/3] fix linting issue --- pkg/skaffold/runner/runner.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/pkg/skaffold/runner/runner.go b/pkg/skaffold/runner/runner.go index 6d706fbcaba..50b839d7b5a 100644 --- a/pkg/skaffold/runner/runner.go +++ b/pkg/skaffold/runner/runner.go @@ -191,6 +191,8 @@ func (r *SkaffoldRunner) Run(ctx context.Context, out io.Writer, artifacts []*v1 select { case <-ctx.Done(): return nil + default: + continue } } } From 2f8d27aedcf919c6d7e1cf9aab410fa08ecf08ed Mon Sep 17 00:00:00 2001 From: Priya Wadhwa Date: Wed, 22 Aug 2018 11:49:16 -0700 Subject: [PATCH 3/3] Address code comments and add --tail flag to skaffold deploy --- cmd/skaffold/app/cmd/cmd.go | 2 +- cmd/skaffold/app/cmd/deploy.go | 27 ++++++++++++++++++++++++--- cmd/skaffold/app/cmd/run.go | 2 +- pkg/skaffold/runner/runner.go | 15 ++++----------- 4 files changed, 30 insertions(+), 16 deletions(-) diff --git a/cmd/skaffold/app/cmd/cmd.go b/cmd/skaffold/app/cmd/cmd.go index 0a9545993d5..4a13b87884c 100644 --- a/cmd/skaffold/app/cmd/cmd.go +++ b/cmd/skaffold/app/cmd/cmd.go @@ -130,7 +130,7 @@ func AddDevFlags(cmd *cobra.Command) { cmd.Flags().BoolVar(&opts.Cleanup, "cleanup", true, "Delete deployments after dev mode is interrupted") } -func AddRunFlags(cmd *cobra.Command) { +func AddRunDeployFlags(cmd *cobra.Command) { cmd.Flags().BoolVar(&opts.Tail, "tail", false, "Stream logs from deployed objects") } diff --git a/cmd/skaffold/app/cmd/deploy.go b/cmd/skaffold/app/cmd/deploy.go index 61594488f58..049423891e6 100644 --- a/cmd/skaffold/app/cmd/deploy.go +++ b/cmd/skaffold/app/cmd/deploy.go @@ -23,6 +23,7 @@ import ( "github.com/GoogleContainerTools/skaffold/pkg/skaffold/build" "github.com/GoogleContainerTools/skaffold/pkg/skaffold/docker" + "github.com/GoogleContainerTools/skaffold/pkg/skaffold/kubernetes" "github.com/pkg/errors" "github.com/spf13/cobra" ) @@ -42,6 +43,7 @@ func NewCmdDeploy(out io.Writer) *cobra.Command { }, } AddRunDevFlags(cmd) + AddRunDeployFlags(cmd) cmd.Flags().StringSliceVar(&images, "images", nil, "A list of images to deploy") cmd.Flags().BoolVarP(&quietFlag, "quiet", "q", false, "Suppress the deploy output") return cmd @@ -50,7 +52,7 @@ func NewCmdDeploy(out io.Writer) *cobra.Command { func runDeploy(out io.Writer) error { ctx := context.Background() - r, _, err := newRunner(opts) + r, config, err := newRunner(opts) if err != nil { return errors.Wrap(err, "creating runner") } @@ -72,6 +74,25 @@ func runDeploy(out io.Writer) error { }) } - _, err = r.Deploy(ctx, deployOut, builds) - return err + if _, err := r.Deploy(ctx, deployOut, builds); err != nil { + return err + } + + if !opts.Tail { + return nil + } + // If tail is true, stream logs from deployed objects + imageList := kubernetes.NewImageList() + for _, b := range builds { + imageList.Add(b.Tag) + } + colorPicker := kubernetes.NewColorPicker(config.Build.Artifacts) + logger := kubernetes.NewLogAggregator(out, imageList, colorPicker) + + if err := logger.Start(ctx); err != nil { + return errors.Wrap(err, "starting logger") + } + + <-ctx.Done() + return nil } diff --git a/cmd/skaffold/app/cmd/run.go b/cmd/skaffold/app/cmd/run.go index d1b9aa5cf02..5ac02c717b0 100644 --- a/cmd/skaffold/app/cmd/run.go +++ b/cmd/skaffold/app/cmd/run.go @@ -35,7 +35,7 @@ func NewCmdRun(out io.Writer) *cobra.Command { }, } AddRunDevFlags(cmd) - AddRunFlags(cmd) + AddRunDeployFlags(cmd) cmd.Flags().StringVarP(&opts.CustomTag, "tag", "t", "", "The optional custom tag to use for images which overrides the current Tagger configuration") return cmd diff --git a/pkg/skaffold/runner/runner.go b/pkg/skaffold/runner/runner.go index 50b839d7b5a..cfe51b8b211 100644 --- a/pkg/skaffold/runner/runner.go +++ b/pkg/skaffold/runner/runner.go @@ -177,24 +177,17 @@ func (r *SkaffoldRunner) Run(ctx context.Context, out io.Writer, artifacts []*v1 } // If tail is true, stream logs from deployed objects imageList := kubernetes.NewImageList() - for _, build := range bRes { - imageList.Add(build.Tag) + for _, b := range bRes { + imageList.Add(b.Tag) } colorPicker := kubernetes.NewColorPicker(artifacts) logger := kubernetes.NewLogAggregator(out, imageList, colorPicker) - if err := logger.Start(ctx); err != nil { return errors.Wrap(err, "starting logger") } - for { - select { - case <-ctx.Done(): - return nil - default: - continue - } - } + <-ctx.Done() + return nil } // Dev watches for changes and runs the skaffold build and deploy