github.com/mook-as/cf-cli@v7.0.0-beta.28.0.20200120190804-b91c115fae48+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/v7action"
     8  	"code.cloudfoundry.org/cli/api/cloudcontroller/ccerror"
     9  	"code.cloudfoundry.org/cli/api/cloudcontroller/ccv3/constant"
    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("droplets Command", func() {
    25  	var (
    26  		cmd             DropletsCommand
    27  		testUI          *ui.UI
    28  		fakeConfig      *commandfakes.FakeConfig
    29  		fakeSharedActor *commandfakes.FakeSharedActor
    30  		fakeActor       *v7fakes.FakeDropletsActor
    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.FakeDropletsActor)
    40  
    41  		binaryName = "faceman"
    42  		fakeConfig.BinaryNameReturns(binaryName)
    43  
    44  		cmd = DropletsCommand{
    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 application droplets returns an error", func() {
    97  		var expectedErr error
    98  
    99  		BeforeEach(func() {
   100  			expectedErr = ccerror.RequestError{}
   101  			fakeActor.GetApplicationDropletsReturns([]v7action.Droplet{}, 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 droplets 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 droplets returns some droplets", func() {
   115  		var createdAtOne, createdAtTwo string
   116  		BeforeEach(func() {
   117  			createdAtOne = "2017-08-14T21:16:42Z"
   118  			createdAtTwo = "2017-08-16T00:18:24Z"
   119  			droplets := []v7action.Droplet{
   120  				{
   121  					GUID:      "some-droplet-guid-1",
   122  					State:     constant.DropletStaged,
   123  					CreatedAt: createdAtOne,
   124  				},
   125  				{
   126  					GUID:      "some-droplet-guid-2",
   127  					State:     constant.DropletFailed,
   128  					CreatedAt: createdAtTwo,
   129  				},
   130  			}
   131  			fakeActor.GetApplicationDropletsReturns(droplets, v7action.Warnings{"warning-1", "warning-2"}, nil)
   132  		})
   133  
   134  		It("prints the application droplets and outputs warnings", func() {
   135  			Expect(executeErr).ToNot(HaveOccurred())
   136  
   137  			Expect(testUI.Out).To(Say(`Getting droplets of app some-app in org some-org / space some-space as steve\.\.\.\n`))
   138  			Expect(testUI.Out).To(Say("\n"))
   139  
   140  			createdAtOneParsed, err := time.Parse(time.RFC3339, createdAtOne)
   141  			Expect(err).ToNot(HaveOccurred())
   142  			createdAtTwoParsed, err := time.Parse(time.RFC3339, createdAtTwo)
   143  			Expect(err).ToNot(HaveOccurred())
   144  
   145  			Expect(testUI.Out).To(Say(`guid\s+state\s+created\n`))
   146  			Expect(testUI.Out).To(Say(`some-droplet-guid-1\s+staged\s+%s\n`, testUI.UserFriendlyDate(createdAtOneParsed)))
   147  			Expect(testUI.Out).To(Say(`some-droplet-guid-2\s+failed\s+%s\n`, testUI.UserFriendlyDate(createdAtTwoParsed)))
   148  
   149  			Expect(testUI.Err).To(Say("warning-1"))
   150  			Expect(testUI.Err).To(Say("warning-2"))
   151  
   152  			Expect(fakeActor.GetApplicationDropletsCallCount()).To(Equal(1))
   153  			appName, spaceGUID := fakeActor.GetApplicationDropletsArgsForCall(0)
   154  			Expect(appName).To(Equal("some-app"))
   155  			Expect(spaceGUID).To(Equal("some-space-guid"))
   156  		})
   157  	})
   158  
   159  	When("getting the application droplets returns no droplets", func() {
   160  		BeforeEach(func() {
   161  			fakeActor.GetApplicationDropletsReturns([]v7action.Droplet{}, v7action.Warnings{"warning-1", "warning-2"}, nil)
   162  		})
   163  
   164  		It("displays there are no droplets", func() {
   165  			Expect(executeErr).ToNot(HaveOccurred())
   166  
   167  			Expect(testUI.Out).To(Say(`Getting droplets of app some-app in org some-org / space some-space as steve\.\.\.`))
   168  			Expect(testUI.Out).To(Say("No droplets found"))
   169  
   170  			Expect(testUI.Err).To(Say("warning-1"))
   171  			Expect(testUI.Err).To(Say("warning-2"))
   172  		})
   173  	})
   174  })