Expect(err).NotTo(HaveOccurred()) Expect(config.AuthorizationEndpoint).To(Equal("https://login.example.com")) Expect(config.LoggregatorEndpoint).To(Equal("wss://loggregator.foo.example.org:4443")) Expect(endpoint).To(Equal(testServer.URL)) Expect(config.SSHOAuthClient).To(Equal("ssh-client-id")) Expect(config.APIVersion).To(Equal("42.0.0")) Expect(config.MinCLIVersion).To(Equal("6.5.0")) Expect(config.MinRecommendedCLIVersion).To(Equal("6.7.0")) Expect(config.RoutingAPIEndpoint).To(Equal("http://api.example.com/routing")) }) }) Context("when the API request fails", func() { BeforeEach(func() { coreConfig.SetAPIEndpoint("example.com") }) It("returns a failure response when the server has a bad certificate", func() { testServer.TLS.Certificates = []tls.Certificate{testnet.MakeExpiredTLSCert()} _, _, apiErr := repo.GetCCInfo(testServer.URL) Expect(apiErr).NotTo(BeNil()) }) It("returns a failure response when the API request fails", func() { testServerFn = func(w http.ResponseWriter, r *http.Request) { w.WriteHeader(http.StatusNotFound) } _, _, apiErr := repo.GetCCInfo(testServer.URL)
config.SetAPIVersion("2.2.0") }) JustBeforeEach(func() { strategy := strategy.NewEndpointStrategy(config.APIVersion()) gateway := net.NewCloudControllerGateway(config, time.Now, new(terminalfakes.FakeUI), new(tracefakes.FakePrinter), "") repo = NewCloudControllerAppEventsRepository(config, gateway, strategy) }) AfterEach(func() { server.Close() }) setupTestServer := func(requests ...testnet.TestRequest) { server, handler = testnet.NewServer(requests) config.SetAPIEndpoint(server.URL) } Describe("list recent events", func() { It("returns the most recent events", func() { setupTestServer(eventsRequest) list, err := repo.RecentEvents("my-app-guid", 2) Expect(err).ToNot(HaveOccurred()) timestamp, err := time.Parse(eventTimestampFormat, "2014-01-21T00:20:11+00:00") Expect(err).ToNot(HaveOccurred()) Expect(list).To(ConsistOf([]models.EventFields{ { GUID: "event-1-guid", Name: "audit.app.update",
. "github.com/onsi/gomega" ) var _ = Describe("Service Keys Repo", func() { var ( ccServer *ghttp.Server configRepo coreconfig.ReadWriter repo ServiceKeyRepository ) BeforeEach(func() { configRepo = testconfig.NewRepositoryWithDefaults() configRepo.SetAccessToken("BEARER my_access_token") ccServer = ghttp.NewServer() configRepo.SetAPIEndpoint(ccServer.URL()) gateway := net.NewCloudControllerGateway(configRepo, time.Now, new(terminalfakes.FakeUI), new(tracefakes.FakePrinter), "") repo = NewCloudControllerServiceKeyRepository(configRepo, gateway) }) AfterEach(func() { ccServer.Close() }) Describe("CreateServiceKey", func() { It("tries to create the service key", func() { ccServer.AppendHandlers( ghttp.CombineHandlers( ghttp.VerifyRequest("POST", "/v2/service_keys"), ghttp.RespondWith(http.StatusCreated, nil),
"code.cloudfoundry.org/cli/cf/trace/tracefakes" . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" ) var _ = Describe("CopyApplicationSource", func() { var ( repo Repository testServer *httptest.Server configRepo coreconfig.ReadWriter ) setupTestServer := func(reqs ...testnet.TestRequest) { testServer, _ = testnet.NewServer(reqs) configRepo.SetAPIEndpoint(testServer.URL) } BeforeEach(func() { configRepo = testconfig.NewRepositoryWithDefaults() gateway := net.NewCloudControllerGateway(configRepo, time.Now, new(terminalfakes.FakeUI), new(tracefakes.FakePrinter), "") repo = NewCloudControllerCopyApplicationSourceRepository(configRepo, gateway) }) AfterEach(func() { testServer.Close() }) Describe(".CopyApplication", func() { BeforeEach(func() { setupTestServer(apifakes.NewCloudControllerTestRequest(testnet.TestRequest{
config = testconfig.NewRepositoryWithDefaults() }) JustBeforeEach(func() { gateway := net.NewCloudControllerGateway(config, time.Now, new(terminalfakes.FakeUI), new(tracefakes.FakePrinter), "") strategy := strategy.NewEndpointStrategy(config.APIVersion()) repo = NewCloudControllerDomainRepository(config, gateway, strategy) }) AfterEach(func() { ts.Close() }) var setupTestServer = func(reqs ...testnet.TestRequest) { ts, handler = testnet.NewServer(reqs) config.SetAPIEndpoint(ts.URL) } Describe("listing domains", func() { BeforeEach(func() { config.SetAPIVersion("2.2.0") setupTestServer(firstPagePrivateDomainsRequest, secondPagePrivateDomainsRequest, firstPageSharedDomainsRequest, secondPageSharedDomainsRequest) }) It("uses the organization-scoped domains endpoints", func() { receivedDomains := []models.DomainFields{} apiErr := repo.ListDomainsForOrg("my-org-guid", func(d models.DomainFields) bool { receivedDomains = append(receivedDomains, d) return true })
Expect(output).ToNot(ContainSubstrings([]string{"API endpoint:"})) Expect(output).To(ContainSubstrings([]string{"Not logged in", "Use", "log in"})) }) }) Context("when an api endpoint is set and the user logged in", func() { var config coreconfig.ReadWriter BeforeEach(func() { accessToken := coreconfig.TokenInfo{ UserGUID: "my-user-guid", Username: "******", Email: "my-user-email", } config = testconfig.NewRepositoryWithAccessToken(accessToken) config.SetAPIEndpoint("https://test.example.org") config.SetAPIVersion("☃☃☃") }) Describe("tells the user what is set in the config", func() { var output []string JustBeforeEach(func() { output = io_helpers.CaptureOutput(func() { ui := NewUI(os.Stdin, os.Stdout, NewTeePrinter(os.Stdout), fakeLogger) ui.ShowConfiguration(config) }) }) It("tells the user which api endpoint is set", func() { Expect(output).To(ContainSubstrings([]string{"API endpoint:", "https://test.example.org"}))