本文整理匯總了Golang中github.com/cloudfoundry/bosh-agent/internal/github.com/pivotal-golang/clock/fakeclock.FakeClock.Increment方法的典型用法代碼示例。如果您正苦於以下問題:Golang FakeClock.Increment方法的具體用法?Golang FakeClock.Increment怎麽用?Golang FakeClock.Increment使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/cloudfoundry/bosh-agent/internal/github.com/pivotal-golang/clock/fakeclock.FakeClock
的用法示例。
在下文中一共展示了FakeClock.Increment方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: sleepForIncrements
func sleepForIncrements(timeService *fakeclock.FakeClock, attempts int, delay time.Duration) {
for i := 0; i < attempts; i++ {
Eventually(timeService.WatcherCount).Should(Equal(1))
timeService.Increment(delay)
Eventually(timeService.WatcherCount).Should(Equal(0))
}
}
示例2: incrementSleepInBackground
func incrementSleepInBackground(fakeTimeService *fakeclock.FakeClock, delay time.Duration) chan struct{} {
doneChan := make(chan struct{})
go func() {
for {
select {
case <-doneChan:
return
default:
if fakeTimeService.WatcherCount() > 0 {
fakeTimeService.Increment(delay)
Eventually(fakeTimeService.WatcherCount).Should(Equal(0))
}
}
}
}()
return doneChan
}
示例3:
var _ = Describe("FakeClock", func() {
const Δ time.Duration = 10 * time.Millisecond
var (
fakeClock *fakeclock.FakeClock
initialTime time.Time
)
BeforeEach(func() {
initialTime = time.Date(2014, 1, 1, 3, 0, 30, 0, time.UTC)
fakeClock = fakeclock.NewFakeClock(initialTime)
})
Describe("Now", func() {
It("returns the current time, w/o race conditions", func() {
go fakeClock.Increment(time.Minute)
Eventually(fakeClock.Now).Should(Equal(initialTime.Add(time.Minute)))
})
})
Describe("Sleep", func() {
It("blocks until the given interval elapses", func() {
doneSleeping := make(chan struct{})
go func() {
fakeClock.Sleep(10 * time.Second)
close(doneSleeping)
}()
Consistently(doneSleeping, Δ).ShouldNot(BeClosed())
fakeClock.Increment(5 * time.Second)
示例4:
const Δ = 10 * time.Millisecond
var (
fakeClock *fakeclock.FakeClock
initialTime time.Time
)
BeforeEach(func() {
initialTime = time.Date(2014, 1, 1, 3, 0, 30, 0, time.UTC)
fakeClock = fakeclock.NewFakeClock(initialTime)
})
It("proivdes a channel that receives after the given interval has elapsed", func() {
timer := fakeClock.NewTimer(10 * time.Second)
timeChan := timer.C()
Consistently(timeChan, Δ).ShouldNot(Receive())
fakeClock.Increment(5 * time.Second)
Consistently(timeChan, Δ).ShouldNot(Receive())
fakeClock.Increment(4 * time.Second)
Consistently(timeChan, Δ).ShouldNot(Receive())
fakeClock.Increment(1 * time.Second)
Eventually(timeChan).Should(Receive(Equal(initialTime.Add(10 * time.Second))))
fakeClock.Increment(10 * time.Second)
Consistently(timeChan, Δ).ShouldNot(Receive())
})
})
示例5:
Expect(retryable.Response().Body.(ClosedChecker).Closed()).To(BeTrue())
})
})
})
It("waits for retry delay between retries", func() {
for i := 0; i < maxUnavailableAttempts+maxOtherAttempts; i++ {
retryable.AddAttemptBehavior(unavailable, true, nil)
}
go func() {
monitRetryStrategy.Try()
}()
Eventually(retryable.Attempts).Should(Equal(1))
timeService.Increment(delay - time.Millisecond)
Consistently(retryable.Attempts).Should(Equal(1))
timeService.Increment(2 * time.Millisecond)
Eventually(retryable.Attempts).Should(Equal(2))
})
Context("when error is not due to failed response", func() {
It("retries until maxOtherAttempts are exhausted", func() {
for i := 0; i < maxOtherAttempts-1; i++ {
retryable.AddAttemptBehavior(nil, true, errors.New("request error"))
}
retryable.AddAttemptBehavior(nil, true, lastError)
errChan := tryInBackground(monitRetryStrategy)
sleepForIncrements(timeService, maxOtherAttempts, delay)