consul: Adding PendingExpiration

pull/577/head
Armon Dadgar 2014-12-15 14:22:32 -08:00
parent 10604a6fa8
commit 3bcf957d95
2 changed files with 23 additions and 0 deletions

View File

@ -102,6 +102,13 @@ func (t *TombstoneGC) Hint(index uint64) {
}
}
// PendingExpiration is used to check if any expirations are pending
func (t *TombstoneGC) PendingExpiration() bool {
t.expiresLock.Lock()
defer t.expiresLock.Unlock()
return len(t.expires) > 0
}
// nextExpires is used to calculate the next experation time
func (t *TombstoneGC) nextExpires() time.Time {
expires := time.Now().Add(t.ttl)

View File

@ -30,6 +30,10 @@ func TestTombstoneGC(t *testing.T) {
t.Fatalf("should fail")
}
if gc.PendingExpiration() {
t.Fatalf("should not be pending")
}
start := time.Now()
gc.Hint(100)
@ -38,6 +42,10 @@ func TestTombstoneGC(t *testing.T) {
gc.Hint(120)
gc.Hint(125)
if !gc.PendingExpiration() {
t.Fatalf("should be pending")
}
select {
case index := <-gc.ExpireCh():
end := time.Now()
@ -75,9 +83,17 @@ func TestTombstoneGC_Expire(t *testing.T) {
t.Fatalf("should fail")
}
if gc.PendingExpiration() {
t.Fatalf("should not be pending")
}
gc.Hint(100)
gc.Reset()
if gc.PendingExpiration() {
t.Fatalf("should not be pending")
}
select {
case <-gc.ExpireCh():
t.Fatalf("shoudl be reset")