From b4acde50331f67594aca3312a70421a658a09ea9 Mon Sep 17 00:00:00 2001 From: "Lixia (Sylvia) Lei" Date: Tue, 3 Dec 2024 14:34:29 +0800 Subject: [PATCH] blob push e2e Signed-off-by: Lixia (Sylvia) Lei --- test/e2e/suite/command/blob.go | 25 +++++++++++++++++++++++++ test/e2e/suite/command/manifest.go | 4 ++-- 2 files changed, 27 insertions(+), 2 deletions(-) diff --git a/test/e2e/suite/command/blob.go b/test/e2e/suite/command/blob.go index ab9815ff1..f001f0307 100644 --- a/test/e2e/suite/command/blob.go +++ b/test/e2e/suite/command/blob.go @@ -26,6 +26,7 @@ import ( "github.com/onsi/gomega/gbytes" "oras.land/oras/test/e2e/internal/testdata/foobar" . "oras.land/oras/test/e2e/internal/utils" + "oras.land/oras/test/e2e/internal/utils/match" ) const ( @@ -39,6 +40,30 @@ var _ = Describe("ORAS beginners:", func() { repoFmt := fmt.Sprintf("command/blob/%%s/%d/%%s", GinkgoRandomSeed()) When("running blob command", func() { When("running `blob push`", func() { + It("should not show --verbose in help doc", func() { + out := ORAS("push", "--help").MatchKeyWords(ExampleDesc).Exec().Out + gomega.Expect(out).ShouldNot(gbytes.Say("--verbose")) + }) + + It("should show deprecation message and print unnamed status output for --verbose", func() { + repo := fmt.Sprintf(repoFmt, "push", "test-verbose") + ORAS("blob", "push", RegistryRef(ZOTHost, repo, pushDigest), "-", "--size", strconv.Itoa(len(pushContent)), "--verbose"). + WithInput(strings.NewReader(pushContent)). + MatchErrKeyWords(DeprecationMessageVerboseFlag). + MatchStatus([]match.StateKey{{Digest: "e1ca41574914", Name: "application/vnd.oci.image.layer.v1.tar"}}, true, 1). + Exec() + }) + + It("should show deprecation message and should NOT print unnamed status output for --verbose=false", func() { + repo := fmt.Sprintf(repoFmt, "push", "test-verbose-false") + out := ORAS("blob", "push", RegistryRef(ZOTHost, repo, pushDigest), "-", "--size", strconv.Itoa(len(pushContent)), "--verbose=false"). + WithInput(strings.NewReader(pushContent)). + MatchErrKeyWords(DeprecationMessageVerboseFlag). + Exec() + // should not print status output for unnamed blobs + gomega.Expect(out).ShouldNot(gbytes.Say("application/vnd.oci.image.layer.v1.tar")) + }) + It("should fail to read blob content and password from stdin at the same time", func() { repo := fmt.Sprintf(repoFmt, "push", "password-stdin") ORAS("blob", "push", RegistryRef(ZOTHost, repo, ""), "--password-stdin", "-"). diff --git a/test/e2e/suite/command/manifest.go b/test/e2e/suite/command/manifest.go index 3dbb3f8a7..467de92b7 100644 --- a/test/e2e/suite/command/manifest.go +++ b/test/e2e/suite/command/manifest.go @@ -72,10 +72,10 @@ var _ = Describe("ORAS beginners:", func() { tag := "test-verbose" ORAS("manifest", "push", RegistryRef(ZOTHost, ImageRepo, tag), "-", "--verbose"). + WithInput(strings.NewReader(manifest)). MatchErrKeyWords(DeprecationMessageVerboseFlag). MatchKeyWords("Pushed", RegistryRef(ZOTHost, ImageRepo, tag), "Digest:", manifestDigest). MatchStatus([]match.StateKey{{Digest: "bc1a59d49fc7", Name: "application/vnd.oci.image.manifest.v1+json"}}, true, 1). - WithInput(strings.NewReader(manifest)). Exec() }) @@ -85,9 +85,9 @@ var _ = Describe("ORAS beginners:", func() { tag := "test-verbose-false" out := ORAS("manifest", "push", RegistryRef(ZOTHost, ImageRepo, tag), "-", "--verbose=false"). + WithInput(strings.NewReader(manifest)). MatchErrKeyWords(DeprecationMessageVerboseFlag). MatchKeyWords("Pushed", RegistryRef(ZOTHost, ImageRepo, tag), "Digest:", manifestDigest). - WithInput(strings.NewReader(manifest)). Exec() // should not print status output for unnamed blobs gomega.Expect(out).ShouldNot(gbytes.Say("application/vnd.oci.image.manifest.v1+json"))