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