當前位置: 首頁>>代碼示例>>Golang>>正文


Golang fake_routing_api.FakeEventSource類代碼示例

本文整理匯總了Golang中github.com/cloudfoundry-incubator/routing-api/fake_routing_api.FakeEventSource的典型用法代碼示例。如果您正苦於以下問題:Golang FakeEventSource類的具體用法?Golang FakeEventSource怎麽用?Golang FakeEventSource使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了FakeEventSource類的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1:

				fetcher.StartEventCycle()

				Eventually(func() string {
					if len(sink.Records()) > 0 {
						return sink.Records()[0].Message
					} else {
						return ""
					}
				}).Should(Equal("failed to get the token"))
				Eventually(tokenFetcher.FetchTokenCallCount).Should(BeNumerically(">=", 2))
			})
		})

		Context("and the event source successfully subscribes", func() {
			It("responds to events", func() {
				eventSource := fake_routing_api.FakeEventSource{}
				client.SubscribeToEventsReturns(&eventSource, nil)

				eventSource.NextStub = func() (routing_api.Event, error) {
					event := routing_api.Event{
						Action: "Delete",
						Route: db.Route{
							Route:           "z.a.k",
							Port:            63,
							IP:              "42.42.42.42",
							TTL:             1,
							LogGuid:         "Tomato",
							RouteServiceUrl: "route-service-url",
						}}
					return event, nil
				}
開發者ID:krumts,項目名稱:gorouter,代碼行數:31,代碼來源:route_fetcher_test.go

示例2:

		cfg = config.DefaultConfig()
		cfg.PruneStaleDropletsInterval = 2 * time.Second

		retryInterval := 0
		uaaClient = &testUaaClient.FakeClient{}
		registry = &testRegistry.FakeRegistryInterface{}

		token = &schema.Token{
			AccessToken: "access_token",
			ExpiresIn:   5,
		}
		client = &fake_routing_api.FakeClient{}

		eventChannel = make(chan routing_api.Event)
		errorChannel = make(chan error)
		eventSource := fake_routing_api.FakeEventSource{}
		client.SubscribeToEventsWithMaxRetriesReturns(&eventSource, nil)

		localEventChannel := eventChannel
		localErrorChannel := errorChannel

		eventSource.NextStub = func() (routing_api.Event, error) {
			select {
			case e := <-localErrorChannel:
				return routing_api.Event{}, e
			case event := <-localEventChannel:
				return event, nil
			}
		}

		clock = fakeclock.NewFakeClock(time.Now())
開發者ID:nagyistge,項目名稱:gorouter,代碼行數:31,代碼來源:route_fetcher_test.go

示例3:

					return nil, errors.New("failed to get the token")
				}
				fetcher.StartEventCycle()

				Eventually(received).Should(Receive())
				Eventually(received).Should(Receive())

				Expect(sink.Records()).ToNot(BeNil())
				Expect(sink.Records()[0].Message).To(Equal("failed to get the token"))
				Expect(tokenFetcher.FetchTokenCallCount()).To(Equal(2))
			})
		})

		Context("and the event source successfully subscribes", func() {
			It("responds to events", func() {
				eventSource := fake_routing_api.FakeEventSource{}
				client.SubscribeToEventsReturns(&eventSource, nil)

				received := make(chan struct{})

				eventSource.NextStub = func() (routing_api.Event, error) {
					received <- struct{}{}
					event := routing_api.Event{
						Action: "Delete",
						Route: db.Route{
							Route:   "z.a.k",
							Port:    63,
							IP:      "42.42.42.42",
							TTL:     1,
							LogGuid: "Tomato",
						}}
開發者ID:trainchou,項目名稱:gorouter,代碼行數:31,代碼來源:route_fetcher_test.go


注:本文中的github.com/cloudfoundry-incubator/routing-api/fake_routing_api.FakeEventSource類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。