fire the timer twice, if reset to the same deadline

This commit is contained in:
Marten Seemann 2018-01-21 14:09:45 +11:00
parent 15bcc2579f
commit c3cc35363b
2 changed files with 25 additions and 1 deletions

View file

@ -21,7 +21,7 @@ func (t *Timer) Chan() <-chan time.Time {
// Reset the timer, no matter whether the value was read or not
func (t *Timer) Reset(deadline time.Time) {
if deadline.Equal(t.deadline) {
if deadline.Equal(t.deadline) && !t.read {
// No need to reset the timer
return
}

View file

@ -42,4 +42,28 @@ var _ = Describe("Timer", func() {
t.Reset(time.Now().Add(d))
Eventually(t.Chan()).Should(Receive())
})
It("immediately fires the timer, if the deadlines has already passed", func() {
t := NewTimer()
t.Reset(time.Now().Add(-time.Second))
Eventually(t.Chan()).Should(Receive())
})
It("fires the timer twice, if reset to the same deadline", func() {
deadline := time.Now().Add(-time.Millisecond)
t := NewTimer()
t.Reset(deadline)
Eventually(t.Chan()).Should(Receive())
t.SetRead()
t.Reset(deadline)
Eventually(t.Chan()).Should(Receive())
})
It("only fires the timer once, if it is reset to the same deadline, but not read in between", func() {
deadline := time.Now().Add(-time.Millisecond)
t := NewTimer()
t.Reset(deadline)
Eventually(t.Chan()).Should(Receive())
Consistently(t.Chan()).ShouldNot(Receive())
})
})