From 3183bb48929a465517811e138ae36c43f782024e Mon Sep 17 00:00:00 2001 From: Xiaoxuan Wang Date: Wed, 11 Dec 2024 17:15:08 +0800 Subject: [PATCH 1/4] push render Signed-off-by: Xiaoxuan Wang --- cmd/oras/internal/display/metadata/interface.go | 14 +++++++------- cmd/oras/internal/display/metadata/json/push.go | 10 ++++++---- .../internal/display/metadata/template/push.go | 10 ++++++---- cmd/oras/internal/display/metadata/text/push.go | 12 +++++++----- .../internal/display/metadata/text/push_test.go | 3 ++- cmd/oras/root/push.go | 4 ++-- 6 files changed, 30 insertions(+), 23 deletions(-) diff --git a/cmd/oras/internal/display/metadata/interface.go b/cmd/oras/internal/display/metadata/interface.go index 8099bd872..696fb73ff 100644 --- a/cmd/oras/internal/display/metadata/interface.go +++ b/cmd/oras/internal/display/metadata/interface.go @@ -20,17 +20,17 @@ import ( "oras.land/oras/cmd/oras/internal/option" ) +// Renderer renders metadata information when an operation is complete. +type Renderer interface { + Render() error +} + // PushHandler handles metadata output for push events. type PushHandler interface { TaggedHandler - OnCopied(opts *option.Target) error - OnCompleted(root ocispec.Descriptor) error -} - -// Renderer renders metadata information when an operation is complete. -type Renderer interface { - Render() error + OnCopied(opts *option.Target, root ocispec.Descriptor) error + Renderer } // AttachHandler handles metadata output for attach events. diff --git a/cmd/oras/internal/display/metadata/json/push.go b/cmd/oras/internal/display/metadata/json/push.go index 6c3a03ebe..4d8d6f21c 100644 --- a/cmd/oras/internal/display/metadata/json/push.go +++ b/cmd/oras/internal/display/metadata/json/push.go @@ -31,6 +31,7 @@ type PushHandler struct { path string out io.Writer tagged model.Tagged + root ocispec.Descriptor } // NewPushHandler creates a new handler for push events. @@ -47,15 +48,16 @@ func (ph *PushHandler) OnTagged(desc ocispec.Descriptor, tag string) error { } // OnCopied is called after files are copied. -func (ph *PushHandler) OnCopied(opts *option.Target) error { +func (ph *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) error { if opts.RawReference != "" && !contentutil.IsDigest(opts.Reference) { ph.tagged.AddTag(opts.Reference) } ph.path = opts.Path + ph.root = root return nil } -// OnCompleted is called after the push is completed. -func (ph *PushHandler) OnCompleted(root ocispec.Descriptor) error { - return output.PrintPrettyJSON(ph.out, model.NewPush(root, ph.path, ph.tagged.Tags())) +// Render is called after the push is completed. +func (ph *PushHandler) Render() error { + return output.PrintPrettyJSON(ph.out, model.NewPush(ph.root, ph.path, ph.tagged.Tags())) } diff --git a/cmd/oras/internal/display/metadata/template/push.go b/cmd/oras/internal/display/metadata/template/push.go index 22de93876..33228e6cc 100644 --- a/cmd/oras/internal/display/metadata/template/push.go +++ b/cmd/oras/internal/display/metadata/template/push.go @@ -32,6 +32,7 @@ type PushHandler struct { path string tagged model.Tagged out io.Writer + root ocispec.Descriptor } // NewPushHandler returns a new handler for push events. @@ -49,15 +50,16 @@ func (ph *PushHandler) OnTagged(desc ocispec.Descriptor, tag string) error { } // OnCopied is called after files are copied. -func (ph *PushHandler) OnCopied(opts *option.Target) error { +func (ph *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) error { if opts.RawReference != "" && !contentutil.IsDigest(opts.Reference) { ph.tagged.AddTag(opts.Reference) } ph.path = opts.Path + ph.root = root return nil } -// OnCompleted is called after the push is completed. -func (ph *PushHandler) OnCompleted(root ocispec.Descriptor) error { - return output.ParseAndWrite(ph.out, model.NewPush(root, ph.path, ph.tagged.Tags()), ph.template) +// Render is called after the push is completed. +func (ph *PushHandler) Render() error { + return output.ParseAndWrite(ph.out, model.NewPush(ph.root, ph.path, ph.tagged.Tags()), ph.template) } diff --git a/cmd/oras/internal/display/metadata/text/push.go b/cmd/oras/internal/display/metadata/text/push.go index b84b510a3..a258d374e 100644 --- a/cmd/oras/internal/display/metadata/text/push.go +++ b/cmd/oras/internal/display/metadata/text/push.go @@ -28,6 +28,7 @@ import ( type PushHandler struct { printer *output.Printer tagLock sync.Mutex + root ocispec.Descriptor } // NewPushHandler returns a new handler for push events. @@ -45,15 +46,16 @@ func (h *PushHandler) OnTagged(_ ocispec.Descriptor, tag string) error { } // OnCopied is called after files are copied. -func (h *PushHandler) OnCopied(opts *option.Target) error { +func (h *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) error { + h.root = root return h.printer.Println("Pushed", opts.AnnotatedReference()) } -// OnCompleted is called after the push is completed. -func (h *PushHandler) OnCompleted(root ocispec.Descriptor) error { - err := h.printer.Println("ArtifactType:", root.ArtifactType) +// Render is called after the push is completed. +func (h *PushHandler) Render() error { + err := h.printer.Println("ArtifactType:", h.root.ArtifactType) if err != nil { return err } - return h.printer.Println("Digest:", root.Digest) + return h.printer.Println("Digest:", h.root.Digest) } diff --git a/cmd/oras/internal/display/metadata/text/push_test.go b/cmd/oras/internal/display/metadata/text/push_test.go index 960de4134..8871b8e35 100644 --- a/cmd/oras/internal/display/metadata/text/push_test.go +++ b/cmd/oras/internal/display/metadata/text/push_test.go @@ -68,8 +68,9 @@ func TestPushHandler_OnCompleted(t *testing.T) { printer := output.NewPrinter(tt.out, os.Stderr) p := &PushHandler{ printer: printer, + root: tt.root, } - if err := p.OnCompleted(tt.root); (err != nil) != tt.wantErr { + if err := p.Render(); (err != nil) != tt.wantErr { t.Errorf("PushHandler.OnCompleted() error = %v, wantErr %v", err, tt.wantErr) } }) diff --git a/cmd/oras/root/push.go b/cmd/oras/root/push.go index bc47c4fd4..cb9a47789 100644 --- a/cmd/oras/root/push.go +++ b/cmd/oras/root/push.go @@ -270,7 +270,7 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { if err != nil { return err } - err = displayMetadata.OnCopied(&opts.Target) + err = displayMetadata.OnCopied(&opts.Target, root) if err != nil { return err } @@ -288,7 +288,7 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { } } - err = displayMetadata.OnCompleted(root) + err = displayMetadata.Render() if err != nil { return err } From 8997f95f27d9307fe6c95f15e2d8bd56d89a3fb3 Mon Sep 17 00:00:00 2001 From: Xiaoxuan Wang Date: Thu, 12 Dec 2024 14:34:09 +0800 Subject: [PATCH 2/4] resolved comments Signed-off-by: Xiaoxuan Wang --- cmd/oras/internal/display/metadata/json/push.go | 2 +- cmd/oras/internal/display/metadata/template/push.go | 2 +- cmd/oras/internal/display/metadata/text/push.go | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/cmd/oras/internal/display/metadata/json/push.go b/cmd/oras/internal/display/metadata/json/push.go index 4d8d6f21c..9433829e6 100644 --- a/cmd/oras/internal/display/metadata/json/push.go +++ b/cmd/oras/internal/display/metadata/json/push.go @@ -57,7 +57,7 @@ func (ph *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) er return nil } -// Render is called after the push is completed. +// Render implements PushHandler. func (ph *PushHandler) Render() error { return output.PrintPrettyJSON(ph.out, model.NewPush(ph.root, ph.path, ph.tagged.Tags())) } diff --git a/cmd/oras/internal/display/metadata/template/push.go b/cmd/oras/internal/display/metadata/template/push.go index 33228e6cc..bc40f0afa 100644 --- a/cmd/oras/internal/display/metadata/template/push.go +++ b/cmd/oras/internal/display/metadata/template/push.go @@ -59,7 +59,7 @@ func (ph *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) er return nil } -// Render is called after the push is completed. +// Render implements PushHandler. func (ph *PushHandler) Render() error { return output.ParseAndWrite(ph.out, model.NewPush(ph.root, ph.path, ph.tagged.Tags()), ph.template) } diff --git a/cmd/oras/internal/display/metadata/text/push.go b/cmd/oras/internal/display/metadata/text/push.go index a258d374e..317345a63 100644 --- a/cmd/oras/internal/display/metadata/text/push.go +++ b/cmd/oras/internal/display/metadata/text/push.go @@ -51,7 +51,7 @@ func (h *PushHandler) OnCopied(opts *option.Target, root ocispec.Descriptor) err return h.printer.Println("Pushed", opts.AnnotatedReference()) } -// Render is called after the push is completed. +// Render implements PushHandler. func (h *PushHandler) Render() error { err := h.printer.Println("ArtifactType:", h.root.ArtifactType) if err != nil { From fc9f24c99cb0d62b803a50f2e1027e5cf85b0d9d Mon Sep 17 00:00:00 2001 From: Xiaoxuan Wang Date: Mon, 16 Dec 2024 09:48:05 +0800 Subject: [PATCH 3/4] renamed variables Signed-off-by: Xiaoxuan Wang --- cmd/oras/root/push.go | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/cmd/oras/root/push.go b/cmd/oras/root/push.go index cb9a47789..1b7396aa2 100644 --- a/cmd/oras/root/push.go +++ b/cmd/oras/root/push.go @@ -218,11 +218,11 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { } memoryStore := memory.New() union := contentutil.MultiReadOnlyTarget(memoryStore, store) - displayStatus, displayMetadata, err := display.NewPushHandler(opts.Printer, opts.Format, opts.TTY, union) + statusHandler, metadataHandler, err := display.NewPushHandler(opts.Printer, opts.Format, opts.TTY, union) if err != nil { return err } - descs, err := loadFiles(ctx, store, opts.Annotations, opts.FileRefs, displayStatus) + descs, err := loadFiles(ctx, store, opts.Annotations, opts.FileRefs, statusHandler) if err != nil { return err } @@ -243,15 +243,15 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { if err != nil { return err } - dst, stopTrack, err := displayStatus.TrackTarget(originalDst) + dst, stopTrack, err := statusHandler.TrackTarget(originalDst) if err != nil { return err } copyOptions := oras.DefaultCopyOptions copyOptions.Concurrency = opts.concurrency - copyOptions.CopyGraphOptions.OnCopySkipped = displayStatus.OnCopySkipped - copyOptions.CopyGraphOptions.PreCopy = displayStatus.PreCopy - copyOptions.CopyGraphOptions.PostCopy = displayStatus.PostCopy + copyOptions.CopyGraphOptions.OnCopySkipped = statusHandler.OnCopySkipped + copyOptions.CopyGraphOptions.PreCopy = statusHandler.PreCopy + copyOptions.CopyGraphOptions.PostCopy = statusHandler.PostCopy copyWithScopeHint := func(root ocispec.Descriptor) error { // add both pull and push scope hints for dst repository // to save potential push-scope token requests during copy @@ -270,7 +270,7 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { if err != nil { return err } - err = displayMetadata.OnCopied(&opts.Target, root) + err = metadataHandler.OnCopied(&opts.Target, root) if err != nil { return err } @@ -282,13 +282,13 @@ func runPush(cmd *cobra.Command, opts *pushOptions) error { } tagBytesNOpts := oras.DefaultTagBytesNOptions tagBytesNOpts.Concurrency = opts.concurrency - dst := listener.NewTagListener(originalDst, nil, displayMetadata.OnTagged) + dst := listener.NewTagListener(originalDst, nil, metadataHandler.OnTagged) if _, err = oras.TagBytesN(ctx, dst, root.MediaType, contentBytes, opts.extraRefs, tagBytesNOpts); err != nil { return err } } - err = displayMetadata.Render() + err = metadataHandler.Render() if err != nil { return err } From 7f81405186a4040510a370a333713e8ebd460c74 Mon Sep 17 00:00:00 2001 From: Xiaoxuan Wang Date: Mon, 16 Dec 2024 10:50:33 +0800 Subject: [PATCH 4/4] resolved comment Signed-off-by: Xiaoxuan Wang --- cmd/oras/internal/display/metadata/interface.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmd/oras/internal/display/metadata/interface.go b/cmd/oras/internal/display/metadata/interface.go index 814e24289..71c26de5f 100644 --- a/cmd/oras/internal/display/metadata/interface.go +++ b/cmd/oras/internal/display/metadata/interface.go @@ -28,9 +28,9 @@ type Renderer interface { // PushHandler handles metadata output for push events. type PushHandler interface { TaggedHandler + Renderer OnCopied(opts *option.Target, root ocispec.Descriptor) error - Renderer } // AttachHandler handles metadata output for attach events.