github.com/mook-as/cf-cli@v7.0.0-beta.28.0.20200120190804-b91c115fae48+incompatible/command/v7/events_command_test.go (about) 1 package v7_test 2 3 import ( 4 "errors" 5 "regexp" 6 "time" 7 8 "code.cloudfoundry.org/cli/actor/v7action" 9 "code.cloudfoundry.org/cli/api/cloudcontroller/ccerror" 10 "code.cloudfoundry.org/cli/command/flag" 11 12 "code.cloudfoundry.org/cli/actor/actionerror" 13 "code.cloudfoundry.org/cli/command/commandfakes" 14 . "code.cloudfoundry.org/cli/command/v7" 15 "code.cloudfoundry.org/cli/command/v7/v7fakes" 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("events Command", func() { 25 var ( 26 cmd EventsCommand 27 testUI *ui.UI 28 fakeConfig *commandfakes.FakeConfig 29 fakeSharedActor *commandfakes.FakeSharedActor 30 fakeActor *v7fakes.FakeEventsActor 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.FakeEventsActor) 40 41 binaryName = "faceman" 42 fakeConfig.BinaryNameReturns(binaryName) 43 44 cmd = EventsCommand{ 45 RequiredArgs: flag.AppName{AppName: "some-app"}, 46 UI: testUI, 47 Config: fakeConfig, 48 Actor: fakeActor, 49 SharedActor: fakeSharedActor, 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 events returns an error", func() { 97 var expectedErr error 98 99 BeforeEach(func() { 100 expectedErr = ccerror.RequestError{} 101 fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns(nil, 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 events for 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 events returns some events", func() { 115 var ( 116 createdAtOne, createdAtTwo time.Time 117 errOne, errTwo error 118 ) 119 120 BeforeEach(func() { 121 createdAtOne, errOne = time.Parse(time.RFC3339, "2017-08-14T21:16:42Z") 122 createdAtTwo, errTwo = time.Parse(time.RFC3339, "2017-08-16T00:18:24Z") 123 events := []v7action.Event{ 124 { 125 GUID: "some-event-guid-1", 126 Type: "audit.app.wow", 127 ActorName: "user1", 128 Time: createdAtOne, 129 }, 130 { 131 GUID: "some-event-guid-2", 132 Type: "audit.app.cool", 133 ActorName: "user2", 134 Time: createdAtTwo, 135 Description: `"hello": "world"`, 136 }, 137 } 138 139 fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns(events, v7action.Warnings{"warning-1", "warning-2"}, nil) 140 }) 141 142 It("prints the events and outputs warnings", func() { 143 Expect(executeErr).ToNot(HaveOccurred()) 144 Expect(errOne).ToNot(HaveOccurred()) 145 Expect(errTwo).ToNot(HaveOccurred()) 146 147 Expect(testUI.Out).To(Say(`Getting events for app some-app in org some-org / space some-space as steve\.\.\.`)) 148 Expect(testUI.Out).To(Say("\n")) 149 150 Expect(testUI.Out).To(Say(`time\s+event\s+actor\s+description`)) 151 Expect(testUI.Out).To(Say(`%s\s+audit.app.wow\s+user1\s+`, regexp.QuoteMeta(createdAtOne.Local().Format("2006-01-02T15:04:05.00-0700")))) 152 Expect(testUI.Out).To(Say(`%s\s+audit.app.cool\s+user2\s+`, regexp.QuoteMeta(createdAtTwo.Local().Format("2006-01-02T15:04:05.00-0700")))) 153 Expect(testUI.Out).To(Say(`"hello": "world"`)) 154 155 Expect(testUI.Err).To(Say("warning-1")) 156 Expect(testUI.Err).To(Say("warning-2")) 157 158 Expect(fakeActor.GetRecentEventsByApplicationNameAndSpaceCallCount()).To(Equal(1)) 159 appName, spaceGUID := fakeActor.GetRecentEventsByApplicationNameAndSpaceArgsForCall(0) 160 Expect(appName).To(Equal("some-app")) 161 Expect(spaceGUID).To(Equal("some-space-guid")) 162 }) 163 }) 164 165 When("getting the application events returns no events", func() { 166 BeforeEach(func() { 167 fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns([]v7action.Event{}, v7action.Warnings{"warning-1", "warning-2"}, nil) 168 }) 169 170 It("displays there are no events", func() { 171 Expect(executeErr).ToNot(HaveOccurred()) 172 173 Expect(testUI.Out).To(Say(`Getting events for app some-app in org some-org / space some-space as steve\.\.\.`)) 174 Expect(testUI.Out).To(Say("No events found")) 175 176 Expect(testUI.Err).To(Say("warning-1")) 177 Expect(testUI.Err).To(Say("warning-2")) 178 }) 179 }) 180 })