github.com/DaAlbrecht/cf-cli@v0.0.0-20231128151943-1fe19bb400b9/command/v7/packages_command_test.go (about) 1 package v7_test 2 3 import ( 4 "errors" 5 "time" 6 7 "code.cloudfoundry.org/cli/actor/actionerror" 8 "code.cloudfoundry.org/cli/actor/v7action" 9 "code.cloudfoundry.org/cli/api/cloudcontroller/ccerror" 10 "code.cloudfoundry.org/cli/api/cloudcontroller/ccv3/constant" 11 "code.cloudfoundry.org/cli/command/commandfakes" 12 "code.cloudfoundry.org/cli/command/flag" 13 v7 "code.cloudfoundry.org/cli/command/v7" 14 "code.cloudfoundry.org/cli/command/v7/v7fakes" 15 "code.cloudfoundry.org/cli/resources" 16 "code.cloudfoundry.org/cli/util/configv3" 17 "code.cloudfoundry.org/cli/util/ui" 18 . "github.com/onsi/ginkgo" 19 . "github.com/onsi/gomega" 20 . "github.com/onsi/gomega/gbytes" 21 ) 22 23 var _ = Describe("packages Command", func() { 24 var ( 25 cmd v7.PackagesCommand 26 testUI *ui.UI 27 fakeConfig *commandfakes.FakeConfig 28 fakeSharedActor *commandfakes.FakeSharedActor 29 fakeActor *v7fakes.FakeActor 30 binaryName string 31 executeErr error 32 ) 33 34 BeforeEach(func() { 35 testUI = ui.NewTestUI(nil, NewBuffer(), NewBuffer()) 36 fakeConfig = new(commandfakes.FakeConfig) 37 fakeSharedActor = new(commandfakes.FakeSharedActor) 38 fakeActor = new(v7fakes.FakeActor) 39 40 binaryName = "faceman" 41 fakeConfig.BinaryNameReturns(binaryName) 42 43 cmd = v7.PackagesCommand{ 44 RequiredArgs: flag.AppName{AppName: "some-app"}, 45 BaseCommand: v7.BaseCommand{ 46 UI: testUI, 47 Config: fakeConfig, 48 Actor: fakeActor, 49 SharedActor: fakeSharedActor, 50 }, 51 } 52 53 fakeConfig.TargetedOrganizationReturns(configv3.Organization{ 54 Name: "some-org", 55 GUID: "some-org-guid", 56 }) 57 fakeConfig.TargetedSpaceReturns(configv3.Space{ 58 Name: "some-space", 59 GUID: "some-space-guid", 60 }) 61 62 fakeActor.GetCurrentUserReturns(configv3.User{Name: "steve"}, nil) 63 }) 64 65 JustBeforeEach(func() { 66 executeErr = cmd.Execute(nil) 67 }) 68 69 When("checking target fails", func() { 70 BeforeEach(func() { 71 fakeSharedActor.CheckTargetReturns(actionerror.NoOrganizationTargetedError{BinaryName: binaryName}) 72 }) 73 74 It("returns an error", func() { 75 Expect(executeErr).To(MatchError(actionerror.NoOrganizationTargetedError{BinaryName: binaryName})) 76 77 Expect(fakeSharedActor.CheckTargetCallCount()).To(Equal(1)) 78 checkTargetedOrg, checkTargetedSpace := fakeSharedActor.CheckTargetArgsForCall(0) 79 Expect(checkTargetedOrg).To(BeTrue()) 80 Expect(checkTargetedSpace).To(BeTrue()) 81 }) 82 }) 83 84 When("the user is not logged in", func() { 85 var expectedErr error 86 87 BeforeEach(func() { 88 expectedErr = errors.New("some current user error") 89 fakeActor.GetCurrentUserReturns(configv3.User{}, expectedErr) 90 }) 91 92 It("return an error", func() { 93 Expect(executeErr).To(Equal(expectedErr)) 94 }) 95 }) 96 97 When("getting the application packages returns an error", func() { 98 var expectedErr error 99 100 BeforeEach(func() { 101 expectedErr = ccerror.RequestError{} 102 fakeActor.GetApplicationPackagesReturns([]resources.Package{}, v7action.Warnings{"warning-1", "warning-2"}, expectedErr) 103 }) 104 105 It("returns the error and prints warnings", func() { 106 Expect(executeErr).To(Equal(ccerror.RequestError{})) 107 108 Expect(testUI.Out).To(Say(`Getting packages of app some-app in org some-org / space some-space as steve\.\.\.`)) 109 110 Expect(testUI.Err).To(Say("warning-1")) 111 Expect(testUI.Err).To(Say("warning-2")) 112 }) 113 }) 114 115 When("getting the application packages returns some packages", func() { 116 var package1UTC, package2UTC string 117 118 BeforeEach(func() { 119 package1UTC = "2017-08-14T21:16:42Z" 120 package2UTC = "2017-08-16T00:18:24Z" 121 122 packages := []resources.Package{ 123 { 124 GUID: "some-package-guid-1", 125 State: constant.PackageReady, 126 CreatedAt: package1UTC, 127 }, 128 { 129 GUID: "some-package-guid-2", 130 State: constant.PackageFailed, 131 CreatedAt: package2UTC, 132 }, 133 } 134 fakeActor.GetApplicationPackagesReturns(packages, v7action.Warnings{"warning-1", "warning-2"}, nil) 135 }) 136 137 It("prints the application packages and outputs warnings", func() { 138 Expect(executeErr).ToNot(HaveOccurred()) 139 140 Expect(testUI.Out).To(Say(`Getting packages of app some-app in org some-org / space some-space as steve\.\.\.`)) 141 142 Expect(testUI.Out).To(Say(`guid\s+state\s+created`)) 143 package1UTCTime, err := time.Parse(time.RFC3339, package1UTC) 144 Expect(err).ToNot(HaveOccurred()) 145 package2UTCTime, err := time.Parse(time.RFC3339, package2UTC) 146 Expect(err).ToNot(HaveOccurred()) 147 148 Expect(testUI.Out).To(Say(`some-package-guid-1\s+ready\s+%s`, testUI.UserFriendlyDate(package1UTCTime))) 149 Expect(testUI.Out).To(Say(`some-package-guid-2\s+failed\s+%s`, testUI.UserFriendlyDate(package2UTCTime))) 150 151 Expect(testUI.Err).To(Say("warning-1")) 152 Expect(testUI.Err).To(Say("warning-2")) 153 154 Expect(fakeActor.GetApplicationPackagesCallCount()).To(Equal(1)) 155 appName, spaceGUID := fakeActor.GetApplicationPackagesArgsForCall(0) 156 Expect(appName).To(Equal("some-app")) 157 Expect(spaceGUID).To(Equal("some-space-guid")) 158 }) 159 }) 160 161 When("getting the application packages returns no packages", func() { 162 BeforeEach(func() { 163 fakeActor.GetApplicationPackagesReturns([]resources.Package{}, v7action.Warnings{"warning-1", "warning-2"}, nil) 164 }) 165 166 It("displays there are no packages", func() { 167 Expect(executeErr).ToNot(HaveOccurred()) 168 169 Expect(testUI.Out).To(Say(`Getting packages of app some-app in org some-org / space some-space as steve\.\.\.`)) 170 Expect(testUI.Out).To(Say(`No packages found\.`)) 171 172 Expect(testUI.Err).To(Say("warning-1")) 173 Expect(testUI.Err).To(Say("warning-2")) 174 }) 175 }) 176 })