code.cloudfoundry.org/cli@v7.1.0+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.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 = EventsCommand{
    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 events returns an error", func() {
    99  		var expectedErr error
   100  
   101  		BeforeEach(func() {
   102  			expectedErr = ccerror.RequestError{}
   103  			fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns(nil, 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 events for 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 events returns some events", func() {
   117  		var (
   118  			createdAtOne, createdAtTwo time.Time
   119  			errOne, errTwo             error
   120  		)
   121  
   122  		BeforeEach(func() {
   123  			createdAtOne, errOne = time.Parse(time.RFC3339, "2017-08-14T21:16:42Z")
   124  			createdAtTwo, errTwo = time.Parse(time.RFC3339, "2017-08-16T00:18:24Z")
   125  			events := []v7action.Event{
   126  				{
   127  					GUID:      "some-event-guid-1",
   128  					Type:      "audit.app.wow",
   129  					ActorName: "user1",
   130  					Time:      createdAtOne,
   131  				},
   132  				{
   133  					GUID:        "some-event-guid-2",
   134  					Type:        "audit.app.cool",
   135  					ActorName:   "user2",
   136  					Time:        createdAtTwo,
   137  					Description: `"hello": "world"`,
   138  				},
   139  			}
   140  
   141  			fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns(events, v7action.Warnings{"warning-1", "warning-2"}, nil)
   142  		})
   143  
   144  		It("prints the events and outputs warnings", func() {
   145  			Expect(executeErr).ToNot(HaveOccurred())
   146  			Expect(errOne).ToNot(HaveOccurred())
   147  			Expect(errTwo).ToNot(HaveOccurred())
   148  
   149  			Expect(testUI.Out).To(Say(`Getting events for app some-app in org some-org / space some-space as steve\.\.\.`))
   150  			Expect(testUI.Out).To(Say("\n"))
   151  
   152  			Expect(testUI.Out).To(Say(`time\s+event\s+actor\s+description`))
   153  			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"))))
   154  			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"))))
   155  			Expect(testUI.Out).To(Say(`"hello": "world"`))
   156  
   157  			Expect(testUI.Err).To(Say("warning-1"))
   158  			Expect(testUI.Err).To(Say("warning-2"))
   159  
   160  			Expect(fakeActor.GetRecentEventsByApplicationNameAndSpaceCallCount()).To(Equal(1))
   161  			appName, spaceGUID := fakeActor.GetRecentEventsByApplicationNameAndSpaceArgsForCall(0)
   162  			Expect(appName).To(Equal("some-app"))
   163  			Expect(spaceGUID).To(Equal("some-space-guid"))
   164  		})
   165  	})
   166  
   167  	When("getting the application events returns no events", func() {
   168  		BeforeEach(func() {
   169  			fakeActor.GetRecentEventsByApplicationNameAndSpaceReturns([]v7action.Event{}, v7action.Warnings{"warning-1", "warning-2"}, nil)
   170  		})
   171  
   172  		It("displays there are no events", func() {
   173  			Expect(executeErr).ToNot(HaveOccurred())
   174  
   175  			Expect(testUI.Out).To(Say(`Getting events for app some-app in org some-org / space some-space as steve\.\.\.`))
   176  			Expect(testUI.Out).To(Say("No events found"))
   177  
   178  			Expect(testUI.Err).To(Say("warning-1"))
   179  			Expect(testUI.Err).To(Say("warning-2"))
   180  		})
   181  	})
   182  })