2019-07-11 07:51:55 +03:00
|
|
|
package memory
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-01-30 14:39:00 +03:00
|
|
|
"github.com/micro/go-micro/v2/store"
|
2019-07-11 07:51:55 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestReadRecordExpire(t *testing.T) {
|
|
|
|
s := NewStore()
|
|
|
|
|
|
|
|
var (
|
|
|
|
key = "foo"
|
|
|
|
expire = 100 * time.Millisecond
|
|
|
|
)
|
|
|
|
rec := &store.Record{
|
|
|
|
Key: key,
|
|
|
|
Value: nil,
|
|
|
|
Expiry: expire,
|
|
|
|
}
|
|
|
|
s.Write(rec)
|
|
|
|
|
|
|
|
rrec, err := s.Read(key)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2019-10-11 16:08:50 +03:00
|
|
|
if rrec[0].Expiry >= expire {
|
2019-07-11 07:51:55 +03:00
|
|
|
t.Fatal("expiry of read record is not changed")
|
|
|
|
}
|
|
|
|
|
|
|
|
time.Sleep(expire)
|
|
|
|
|
|
|
|
if _, err := s.Read(key); err != store.ErrNotFound {
|
|
|
|
t.Fatal("expire elapsed, but key still accessable")
|
|
|
|
}
|
|
|
|
}
|