github.com/nimakaviani/cli@v6.37.1-0.20180619223813-e734901a73fa+incompatible/command/v3/v3_packages_command_test.go (about)

     1  package v3_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/api/cloudcontroller/ccversion"
    12  	"code.cloudfoundry.org/cli/command/commandfakes"
    13  	"code.cloudfoundry.org/cli/command/flag"
    14  	"code.cloudfoundry.org/cli/command/translatableerror"
    15  	"code.cloudfoundry.org/cli/command/v3"
    16  	"code.cloudfoundry.org/cli/command/v3/v3fakes"
    17  	"code.cloudfoundry.org/cli/util/configv3"
    18  	"code.cloudfoundry.org/cli/util/ui"
    19  	. "github.com/onsi/ginkgo"
    20  	. "github.com/onsi/gomega"
    21  	. "github.com/onsi/gomega/gbytes"
    22  )
    23  
    24  var _ = Describe("v3-packages Command", func() {
    25  	var (
    26  		cmd             v3.V3PackagesCommand
    27  		testUI          *ui.UI
    28  		fakeConfig      *commandfakes.FakeConfig
    29  		fakeSharedActor *commandfakes.FakeSharedActor
    30  		fakeActor       *v3fakes.FakeV3PackagesActor
    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(v3fakes.FakeV3PackagesActor)
    40  
    41  		binaryName = "faceman"
    42  		fakeConfig.BinaryNameReturns(binaryName)
    43  
    44  		cmd = v3.V3PackagesCommand{
    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  		fakeActor.CloudControllerAPIVersionReturns(ccversion.MinVersionV3)
    63  	})
    64  
    65  	JustBeforeEach(func() {
    66  		executeErr = cmd.Execute(nil)
    67  	})
    68  
    69  	Context("when the API version is below the minimum", func() {
    70  		BeforeEach(func() {
    71  			fakeActor.CloudControllerAPIVersionReturns("0.0.0")
    72  		})
    73  
    74  		It("returns a MinimumAPIVersionNotMetError", func() {
    75  			Expect(executeErr).To(MatchError(translatableerror.MinimumAPIVersionNotMetError{
    76  				CurrentVersion: "0.0.0",
    77  				MinimumVersion: ccversion.MinVersionV3,
    78  			}))
    79  		})
    80  
    81  		It("displays the experimental warning", func() {
    82  			Expect(testUI.Err).To(Say("This command is in EXPERIMENTAL stage and may change without notice"))
    83  		})
    84  	})
    85  
    86  	Context("when checking target fails", func() {
    87  		BeforeEach(func() {
    88  			fakeSharedActor.CheckTargetReturns(actionerror.NoOrganizationTargetedError{BinaryName: binaryName})
    89  		})
    90  
    91  		It("returns an error", func() {
    92  			Expect(executeErr).To(MatchError(actionerror.NoOrganizationTargetedError{BinaryName: binaryName}))
    93  
    94  			Expect(fakeSharedActor.CheckTargetCallCount()).To(Equal(1))
    95  			checkTargetedOrg, checkTargetedSpace := fakeSharedActor.CheckTargetArgsForCall(0)
    96  			Expect(checkTargetedOrg).To(BeTrue())
    97  			Expect(checkTargetedSpace).To(BeTrue())
    98  		})
    99  	})
   100  
   101  	Context("when the user is not logged in", func() {
   102  		var expectedErr error
   103  
   104  		BeforeEach(func() {
   105  			expectedErr = errors.New("some current user error")
   106  			fakeConfig.CurrentUserReturns(configv3.User{}, expectedErr)
   107  		})
   108  
   109  		It("return an error", func() {
   110  			Expect(executeErr).To(Equal(expectedErr))
   111  		})
   112  	})
   113  
   114  	Context("when getting the application packages returns an error", func() {
   115  		var expectedErr error
   116  
   117  		BeforeEach(func() {
   118  			expectedErr = ccerror.RequestError{}
   119  			fakeActor.GetApplicationPackagesReturns([]v3action.Package{}, v3action.Warnings{"warning-1", "warning-2"}, expectedErr)
   120  		})
   121  
   122  		It("returns the error and prints warnings", func() {
   123  			Expect(executeErr).To(Equal(ccerror.RequestError{}))
   124  
   125  			Expect(testUI.Out).To(Say("Listing packages of app some-app in org some-org / space some-space as steve\\.\\.\\."))
   126  
   127  			Expect(testUI.Err).To(Say("warning-1"))
   128  			Expect(testUI.Err).To(Say("warning-2"))
   129  		})
   130  	})
   131  
   132  	Context("when getting the application packages returns some packages", func() {
   133  		var package1UTC, package2UTC string
   134  
   135  		BeforeEach(func() {
   136  			package1UTC = "2017-08-14T21:16:42Z"
   137  			package2UTC = "2017-08-16T00:18:24Z"
   138  
   139  			packages := []v3action.Package{
   140  				{
   141  					GUID:      "some-package-guid-1",
   142  					State:     constant.PackageReady,
   143  					CreatedAt: package1UTC,
   144  				},
   145  				{
   146  					GUID:      "some-package-guid-2",
   147  					State:     constant.PackageFailed,
   148  					CreatedAt: package2UTC,
   149  				},
   150  			}
   151  			fakeActor.GetApplicationPackagesReturns(packages, v3action.Warnings{"warning-1", "warning-2"}, nil)
   152  		})
   153  
   154  		It("prints the application packages and outputs warnings", func() {
   155  			Expect(executeErr).ToNot(HaveOccurred())
   156  
   157  			Expect(testUI.Out).To(Say("Listing packages of app some-app in org some-org / space some-space as steve\\.\\.\\."))
   158  
   159  			Expect(testUI.Out).To(Say("guid\\s+state\\s+created"))
   160  			package1UTCTime, err := time.Parse(time.RFC3339, package1UTC)
   161  			Expect(err).ToNot(HaveOccurred())
   162  			package2UTCTime, err := time.Parse(time.RFC3339, package2UTC)
   163  			Expect(err).ToNot(HaveOccurred())
   164  			Expect(testUI.Out).To(Say("some-package-guid-1\\s+ready\\s+%s", testUI.UserFriendlyDate(package1UTCTime)))
   165  			Expect(testUI.Out).To(Say("some-package-guid-2\\s+failed\\s+%s", testUI.UserFriendlyDate(package2UTCTime)))
   166  
   167  			Expect(testUI.Err).To(Say("warning-1"))
   168  			Expect(testUI.Err).To(Say("warning-2"))
   169  
   170  			Expect(fakeActor.GetApplicationPackagesCallCount()).To(Equal(1))
   171  			appName, spaceGUID := fakeActor.GetApplicationPackagesArgsForCall(0)
   172  			Expect(appName).To(Equal("some-app"))
   173  			Expect(spaceGUID).To(Equal("some-space-guid"))
   174  		})
   175  	})
   176  
   177  	Context("when getting the application packages returns no packages", func() {
   178  		BeforeEach(func() {
   179  			fakeActor.GetApplicationPackagesReturns([]v3action.Package{}, v3action.Warnings{"warning-1", "warning-2"}, nil)
   180  		})
   181  
   182  		It("displays there are no packages", func() {
   183  			Expect(executeErr).ToNot(HaveOccurred())
   184  
   185  			Expect(testUI.Out).To(Say("Listing packages of app some-app in org some-org / space some-space as steve\\.\\.\\."))
   186  			Expect(testUI.Out).To(Say("No packages found"))
   187  
   188  			Expect(testUI.Err).To(Say("warning-1"))
   189  			Expect(testUI.Err).To(Say("warning-2"))
   190  		})
   191  	})
   192  })