Go中测试缓存需接口抽象、可控时间与内存实现:定义Cache接口,注入nowFunc控制过期逻辑,用MemCache+sync.RWMutex实现可测内存缓存,覆盖存取一致性、TTL刷新、并发安全等场景。

在 Go 中测试缓存操作,核心是隔离外部依赖、控制时间、验证行为是否符合预期——尤其是存取一致性与过期逻辑。不需要真实 Redis 或内存缓存实例,用可 mock 的接口 + 可控时钟就能覆盖关键路径。
定义统一缓存接口,让业务代码不绑定具体实现:
type Cache interface {
Set(key string, value interface{}, ttl time.Duration) error
Get(key string, dst interface{}) error
Delete(key string) error
}这样测试时可用内存缓存(如 map + sync.RWMutex)或专为测试设计的 FakeCache,甚至注入带时间戳记录的调试版。
Go 标准库的 time.Now 无法直接 mock,推荐用依赖注入方式传入 time.Now 函数:
立即学习“go语言免费学习笔记(深入)”;
nowFunc func() time.Time 参数now := time.Date(2024, 1, 1, 12, 0, 0, 0, time.UTC)<br>nowFunc := func() time.Time { return now }Set("k", "v", 5*time.Second),然后把 now 推进到 +6s 后调用 Get,应返回缓存未命中错误每个测试聚焦一个行为,命名体现意图(如 TestCache_GetReturnsValueWhenNotExpired):
cache.ErrNotFound 或类似语义错误sync.WaitGroup 启多个 goroutine 同时 Set/Get 同 key,不 panic、结果一致写一个轻量 MemCache 用于测试(非生产用),自带时间感知:
type MemCache struct {
mu sync.RWMutex
items map[string]cacheItem
nowFn func() time.Time
}
type cacheItem struct {
value interface{}
exp time.Time
}
func (m *MemCache) Set(key string, value interface{}, ttl time.Duration) error {
m.mu.Lock()
defer m.mu.Unlock()
m.items[key] = cacheItem{
value: value,
exp: m.nowFn().Add(ttl),
}
return nil
}
func (m *MemCache) Get(key string, dst interface{}) error {
m.mu.RLock()
defer m.mu.RUnlock()
item, ok := m.items[key]
if !ok || m.nowFn().After(item.exp) {
return errors.New("not found or expired")
}
// 类型拷贝逻辑(简化版)
reflect.ValueOf(dst).Elem().Set(reflect.ValueOf(item.value))
return nil
}测试时初始化它并传入可控 nowFn,所有时间敏感逻辑都变得确定可断言。
以上就是如何在Golang中测试缓存操作_验证存取和过期逻辑的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号