github.com/mook-as/cf-cli@v7.0.0-beta.28.0.20200120190804-b91c115fae48+incompatible/command/v6/v3_droplets_command_test.go (about)

     1  package v6_test
     2  
     3  import (
     4  	"errors"
     5  	"time"
     6  
     7  	"code.cloudfoundry.org/cli/actor/actionerror"
     8  	"code.cloudfoundry.org/cli/actor/v3action"
     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/v6"
    14  	"code.cloudfoundry.org/cli/command/v6/v6fakes"
    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("v3-droplets Command", func() {
    23  	var (
    24  		cmd             V3DropletsCommand
    25  		testUI          *ui.UI
    26  		fakeConfig      *commandfakes.FakeConfig
    27  		fakeSharedActor *commandfakes.FakeSharedActor
    28  		fakeActor       *v6fakes.FakeV3DropletsActor
    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(v6fakes.FakeV3DropletsActor)
    38  
    39  		binaryName = "faceman"
    40  		fakeConfig.BinaryNameReturns(binaryName)
    41  
    42  		cmd = V3DropletsCommand{
    43  			RequiredArgs: flag.AppName{AppName: "some-app"},
    44  			UI:           testUI,
    45  			Config:       fakeConfig,
    46  			Actor:        fakeActor,
    47  			SharedActor:  fakeSharedActor,
    48  		}
    49  
    50  		fakeConfig.TargetedOrganizationReturns(configv3.Organization{
    51  			Name: "some-org",
    52  			GUID: "some-org-guid",
    53  		})
    54  		fakeConfig.TargetedSpaceReturns(configv3.Space{
    55  			Name: "some-space",
    56  			GUID: "some-space-guid",
    57  		})
    58  
    59  		fakeConfig.CurrentUserReturns(configv3.User{Name: "steve"}, nil)
    60  	})
    61  
    62  	JustBeforeEach(func() {
    63  		executeErr = cmd.Execute(nil)
    64  	})
    65  
    66  	It("displays the experimental warning", func() {
    67  		Expect(testUI.Err).To(Say("This command is in EXPERIMENTAL stage and may change without notice"))
    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([]v3action.Droplet{}, v3action.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(`Listing 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 := []v3action.Droplet{
   122  				{
   123  					GUID:      "some-droplet-guid-1",
   124  					State:     constant.DropletStaged,
   125  					CreatedAt: createdAtOne,
   126  				},
   127  				{
   128  					GUID:      "some-droplet-guid-2",
   129  					State:     constant.DropletFailed,
   130  					CreatedAt: createdAtTwo,
   131  				},
   132  			}
   133  			fakeActor.GetApplicationDropletsReturns(droplets, v3action.Warnings{"warning-1", "warning-2"}, nil)
   134  		})
   135  
   136  		It("prints the application droplets and outputs warnings", func() {
   137  			Expect(executeErr).ToNot(HaveOccurred())
   138  
   139  			Expect(testUI.Out).To(Say(`Listing droplets of app some-app in org some-org / space some-space as steve\.\.\.\n`))
   140  			Expect(testUI.Out).To(Say("\n"))
   141  
   142  			createdAtOneParsed, err := time.Parse(time.RFC3339, createdAtOne)
   143  			Expect(err).ToNot(HaveOccurred())
   144  			createdAtTwoParsed, err := time.Parse(time.RFC3339, createdAtTwo)
   145  			Expect(err).ToNot(HaveOccurred())
   146  
   147  			Expect(testUI.Out).To(Say(`guid\s+state\s+created\n`))
   148  			Expect(testUI.Out).To(Say(`some-droplet-guid-1\s+staged\s+%s\n`, testUI.UserFriendlyDate(createdAtOneParsed)))
   149  			Expect(testUI.Out).To(Say(`some-droplet-guid-2\s+failed\s+%s\n`, testUI.UserFriendlyDate(createdAtTwoParsed)))
   150  
   151  			Expect(testUI.Err).To(Say("warning-1"))
   152  			Expect(testUI.Err).To(Say("warning-2"))
   153  
   154  			Expect(fakeActor.GetApplicationDropletsCallCount()).To(Equal(1))
   155  			appName, spaceGUID := fakeActor.GetApplicationDropletsArgsForCall(0)
   156  			Expect(appName).To(Equal("some-app"))
   157  			Expect(spaceGUID).To(Equal("some-space-guid"))
   158  		})
   159  	})
   160  
   161  	When("getting the application droplets returns no droplets", func() {
   162  		BeforeEach(func() {
   163  			fakeActor.GetApplicationDropletsReturns([]v3action.Droplet{}, v3action.Warnings{"warning-1", "warning-2"}, nil)
   164  		})
   165  
   166  		It("displays there are no droplets", func() {
   167  			Expect(executeErr).ToNot(HaveOccurred())
   168  
   169  			Expect(testUI.Out).To(Say(`Listing droplets of app some-app in org some-org / space some-space as steve\.\.\.`))
   170  			Expect(testUI.Out).To(Say("No droplets found"))
   171  
   172  			Expect(testUI.Err).To(Say("warning-1"))
   173  			Expect(testUI.Err).To(Say("warning-2"))
   174  		})
   175  	})
   176  })