Merge pull request #3069 from fuweid/me-debug-mode-push

ctr/commands/images/push: don't show progress if it is debug mode
This commit is contained in:
Michael Crosby 2019-03-05 11:10:51 -06:00 committed by GitHub
commit e70a530aa3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -63,16 +63,19 @@ var pushCommand = cli.Command{
var ( var (
ref = context.Args().First() ref = context.Args().First()
local = context.Args().Get(1) local = context.Args().Get(1)
debug = context.GlobalBool("debug")
desc ocispec.Descriptor desc ocispec.Descriptor
) )
if ref == "" { if ref == "" {
return errors.New("please provide a remote image reference to push") return errors.New("please provide a remote image reference to push")
} }
client, ctx, cancel, err := commands.NewClient(context) client, ctx, cancel, err := commands.NewClient(context)
if err != nil { if err != nil {
return err return err
} }
defer cancel() defer cancel()
if manifest := context.String("manifest"); manifest != "" { if manifest := context.String("manifest"); manifest != "" {
desc.Digest, err = digest.Parse(manifest) desc.Digest, err = digest.Parse(manifest)
if err != nil { if err != nil {
@ -98,7 +101,12 @@ var pushCommand = cli.Command{
eg, ctx := errgroup.WithContext(ctx) eg, ctx := errgroup.WithContext(ctx)
// used to notify the progress writer
doneCh := make(chan struct{})
eg.Go(func() error { eg.Go(func() error {
defer close(doneCh)
log.G(ctx).WithField("image", ref).WithField("digest", desc.Digest).Debug("pushing") log.G(ctx).WithField("image", ref).WithField("digest", desc.Digest).Debug("pushing")
jobHandler := images.HandlerFunc(func(ctx gocontext.Context, desc ocispec.Descriptor) ([]ocispec.Descriptor, error) { jobHandler := images.HandlerFunc(func(ctx gocontext.Context, desc ocispec.Descriptor) ([]ocispec.Descriptor, error) {
@ -112,43 +120,41 @@ var pushCommand = cli.Command{
) )
}) })
errs := make(chan error) // don't show progress if debug mode is set
go func() { if !debug {
defer close(errs) eg.Go(func() error {
errs <- eg.Wait() var (
}() ticker = time.NewTicker(100 * time.Millisecond)
fw = progress.NewWriter(os.Stdout)
start = time.Now()
done bool
)
var ( defer ticker.Stop()
ticker = time.NewTicker(100 * time.Millisecond)
fw = progress.NewWriter(os.Stdout)
start = time.Now()
done bool
)
defer ticker.Stop()
for { for {
select { select {
case <-ticker.C: case <-ticker.C:
fw.Flush() fw.Flush()
tw := tabwriter.NewWriter(fw, 1, 8, 1, ' ', 0) tw := tabwriter.NewWriter(fw, 1, 8, 1, ' ', 0)
content.Display(tw, ongoing.status(), start) content.Display(tw, ongoing.status(), start)
tw.Flush() tw.Flush()
if done { if done {
fw.Flush() fw.Flush()
return nil return nil
}
case <-doneCh:
done = true
case <-ctx.Done():
done = true // allow ui to update once more
}
} }
case err := <-errs: })
if err != nil {
return err
}
done = true
case <-ctx.Done():
done = true // allow ui to update once more
}
} }
return eg.Wait()
}, },
} }