github.com/franc20/ayesa_sap@v7.0.0-beta.28.0.20200124003224-302d4d52fa6c+incompatible/command/v6/v3_packages_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-packages Command", func() { 23 var ( 24 cmd V3PackagesCommand 25 testUI *ui.UI 26 fakeConfig *commandfakes.FakeConfig 27 fakeSharedActor *commandfakes.FakeSharedActor 28 fakeActor *v6fakes.FakeV3PackagesActor 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.FakeV3PackagesActor) 38 39 binaryName = "faceman" 40 fakeConfig.BinaryNameReturns(binaryName) 41 42 cmd = V3PackagesCommand{ 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 packages returns an error", func() { 99 var expectedErr error 100 101 BeforeEach(func() { 102 expectedErr = ccerror.RequestError{} 103 fakeActor.GetApplicationPackagesReturns([]v3action.Package{}, 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 packages 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 packages returns some packages", func() { 117 var package1UTC, package2UTC string 118 119 BeforeEach(func() { 120 package1UTC = "2017-08-14T21:16:42Z" 121 package2UTC = "2017-08-16T00:18:24Z" 122 123 packages := []v3action.Package{ 124 { 125 GUID: "some-package-guid-1", 126 State: constant.PackageReady, 127 CreatedAt: package1UTC, 128 }, 129 { 130 GUID: "some-package-guid-2", 131 State: constant.PackageFailed, 132 CreatedAt: package2UTC, 133 }, 134 } 135 fakeActor.GetApplicationPackagesReturns(packages, v3action.Warnings{"warning-1", "warning-2"}, nil) 136 }) 137 138 It("prints the application packages and outputs warnings", func() { 139 Expect(executeErr).ToNot(HaveOccurred()) 140 141 Expect(testUI.Out).To(Say(`Listing packages of app some-app in org some-org / space some-space as steve\.\.\.`)) 142 143 Expect(testUI.Out).To(Say(`guid\s+state\s+created`)) 144 package1UTCTime, err := time.Parse(time.RFC3339, package1UTC) 145 Expect(err).ToNot(HaveOccurred()) 146 package2UTCTime, err := time.Parse(time.RFC3339, package2UTC) 147 Expect(err).ToNot(HaveOccurred()) 148 Expect(testUI.Out).To(Say(`some-package-guid-1\s+ready\s+%s`, testUI.UserFriendlyDate(package1UTCTime))) 149 Expect(testUI.Out).To(Say(`some-package-guid-2\s+failed\s+%s`, testUI.UserFriendlyDate(package2UTCTime))) 150 151 Expect(testUI.Err).To(Say("warning-1")) 152 Expect(testUI.Err).To(Say("warning-2")) 153 154 Expect(fakeActor.GetApplicationPackagesCallCount()).To(Equal(1)) 155 appName, spaceGUID := fakeActor.GetApplicationPackagesArgsForCall(0) 156 Expect(appName).To(Equal("some-app")) 157 Expect(spaceGUID).To(Equal("some-space-guid")) 158 }) 159 }) 160 161 When("getting the application packages returns no packages", func() { 162 BeforeEach(func() { 163 fakeActor.GetApplicationPackagesReturns([]v3action.Package{}, v3action.Warnings{"warning-1", "warning-2"}, nil) 164 }) 165 166 It("displays there are no packages", func() { 167 Expect(executeErr).ToNot(HaveOccurred()) 168 169 Expect(testUI.Out).To(Say(`Listing packages of app some-app in org some-org / space some-space as steve\.\.\.`)) 170 Expect(testUI.Out).To(Say("No packages found")) 171 172 Expect(testUI.Err).To(Say("warning-1")) 173 Expect(testUI.Err).To(Say("warning-2")) 174 }) 175 }) 176 })