mirror of https://github.com/status-im/consul.git
34 lines
695 B
Go
34 lines
695 B
Go
package state
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestDelay(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("too slow for testing.Short")
|
|
}
|
|
|
|
d := NewDelay()
|
|
|
|
// An unknown key should have a time in the past.
|
|
if exp := d.GetExpiration("nope", nil); !exp.Before(time.Now()) {
|
|
t.Fatalf("bad: %v", exp)
|
|
}
|
|
|
|
// Add a key and set a short expiration.
|
|
now := time.Now()
|
|
delay := 250 * time.Millisecond
|
|
d.SetExpiration("bye", now, delay, nil)
|
|
if exp := d.GetExpiration("bye", nil); !exp.After(now) {
|
|
t.Fatalf("bad: %v", exp)
|
|
}
|
|
|
|
// Wait for the key to expire and check again.
|
|
time.Sleep(2 * delay)
|
|
if exp := d.GetExpiration("bye", nil); !exp.Before(now) {
|
|
t.Fatalf("bad: %v", exp)
|
|
}
|
|
}
|