Merge pull request #5395 from mikebrow/cmd-check-improve-error-checking
add check quiet option and update usage
This commit is contained in:
commit
079fe6bca8
@ -199,30 +199,42 @@ var setLabelsCommand = cli.Command{
|
|||||||
|
|
||||||
var checkCommand = cli.Command{
|
var checkCommand = cli.Command{
|
||||||
Name: "check",
|
Name: "check",
|
||||||
Usage: "check that an image has all content available locally",
|
Usage: "check existing images to ensure all content is available locally",
|
||||||
ArgsUsage: "[flags] [<filter>, ...]",
|
ArgsUsage: "[flags] [<filter>, ...]",
|
||||||
Description: "check that an image has all content available locally",
|
Description: "check existing images to ensure all content is available locally",
|
||||||
Flags: commands.SnapshotterFlags,
|
Flags: append([]cli.Flag{
|
||||||
|
cli.BoolFlag{
|
||||||
|
Name: "quiet, q",
|
||||||
|
Usage: "print only the ready image refs (fully downloaded and unpacked)",
|
||||||
|
},
|
||||||
|
}, commands.SnapshotterFlags...),
|
||||||
Action: func(context *cli.Context) error {
|
Action: func(context *cli.Context) error {
|
||||||
var (
|
var (
|
||||||
exitErr error
|
exitErr error
|
||||||
|
quiet = context.Bool("quiet")
|
||||||
)
|
)
|
||||||
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()
|
||||||
var (
|
|
||||||
contentStore = client.ContentStore()
|
var contentStore = client.ContentStore()
|
||||||
tw = tabwriter.NewWriter(os.Stdout, 1, 8, 1, ' ', 0)
|
|
||||||
)
|
|
||||||
fmt.Fprintln(tw, "REF\tTYPE\tDIGEST\tSTATUS\tSIZE\tUNPACKED\t")
|
|
||||||
|
|
||||||
args := []string(context.Args())
|
args := []string(context.Args())
|
||||||
imageList, err := client.ListImages(ctx, args...)
|
imageList, err := client.ListImages(ctx, args...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrap(err, "failed listing images")
|
return errors.Wrap(err, "failed listing images")
|
||||||
}
|
}
|
||||||
|
if len(imageList) == 0 {
|
||||||
|
log.G(ctx).Debugf("no images found")
|
||||||
|
return exitErr
|
||||||
|
}
|
||||||
|
|
||||||
|
var tw = tabwriter.NewWriter(os.Stdout, 1, 8, 1, ' ', 0)
|
||||||
|
if !quiet {
|
||||||
|
fmt.Fprintln(tw, "REF\tTYPE\tDIGEST\tSTATUS\tSIZE\tUNPACKED\t")
|
||||||
|
}
|
||||||
|
|
||||||
for _, image := range imageList {
|
for _, image := range imageList {
|
||||||
var (
|
var (
|
||||||
@ -230,6 +242,7 @@ var checkCommand = cli.Command{
|
|||||||
size string
|
size string
|
||||||
requiredSize int64
|
requiredSize int64
|
||||||
presentSize int64
|
presentSize int64
|
||||||
|
complete bool = true
|
||||||
)
|
)
|
||||||
|
|
||||||
available, required, present, missing, err := images.Check(ctx, contentStore, image.Target(), platforms.Default())
|
available, required, present, missing, err := images.Check(ctx, contentStore, image.Target(), platforms.Default())
|
||||||
@ -239,6 +252,7 @@ var checkCommand = cli.Command{
|
|||||||
}
|
}
|
||||||
log.G(ctx).WithError(err).Errorf("unable to check %v", image.Name())
|
log.G(ctx).WithError(err).Errorf("unable to check %v", image.Name())
|
||||||
status = "error"
|
status = "error"
|
||||||
|
complete = false
|
||||||
}
|
}
|
||||||
|
|
||||||
if status != "error" {
|
if status != "error" {
|
||||||
@ -252,6 +266,7 @@ var checkCommand = cli.Command{
|
|||||||
|
|
||||||
if len(missing) > 0 {
|
if len(missing) > 0 {
|
||||||
status = "incomplete"
|
status = "incomplete"
|
||||||
|
complete = false
|
||||||
}
|
}
|
||||||
|
|
||||||
if available {
|
if available {
|
||||||
@ -260,6 +275,7 @@ var checkCommand = cli.Command{
|
|||||||
} else {
|
} else {
|
||||||
status = fmt.Sprintf("unavailable (%v/?)", len(present))
|
status = fmt.Sprintf("unavailable (%v/?)", len(present))
|
||||||
size = fmt.Sprintf("%v/?", progress.Bytes(presentSize))
|
size = fmt.Sprintf("%v/?", progress.Bytes(presentSize))
|
||||||
|
complete = false
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
size = "-"
|
size = "-"
|
||||||
@ -273,6 +289,7 @@ var checkCommand = cli.Command{
|
|||||||
log.G(ctx).WithError(err).Errorf("unable to check unpack for %v", image.Name())
|
log.G(ctx).WithError(err).Errorf("unable to check unpack for %v", image.Name())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if !quiet {
|
||||||
fmt.Fprintf(tw, "%v\t%v\t%v\t%v\t%v\t%t\n",
|
fmt.Fprintf(tw, "%v\t%v\t%v\t%v\t%v\t%t\n",
|
||||||
image.Name(),
|
image.Name(),
|
||||||
image.Target().MediaType,
|
image.Target().MediaType,
|
||||||
@ -280,9 +297,15 @@ var checkCommand = cli.Command{
|
|||||||
status,
|
status,
|
||||||
size,
|
size,
|
||||||
unpacked)
|
unpacked)
|
||||||
|
} else {
|
||||||
|
if complete {
|
||||||
|
fmt.Println(image.Name())
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if !quiet {
|
||||||
tw.Flush()
|
tw.Flush()
|
||||||
|
}
|
||||||
return exitErr
|
return exitErr
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user