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