- 引入 LogicalConn/TransportConn 分层,ClientConn 保留兼容适配层 - 新增 Stream、Bulk、RecordStream 三条数据面能力及对应控制路径 - 完成 transfer/file 传输内核与状态快照、诊断能力 - 补齐 reconnect、inbound dispatcher、modern psk 等基础模块 - 增加大规模回归、并发与基准测试覆盖 - 更新依赖库
33 lines
998 B
Go
33 lines
998 B
Go
package notify
|
|
|
|
import "testing"
|
|
|
|
func TestReceivedSignalCacheDetectsDuplicateAndScopeIsolation(t *testing.T) {
|
|
cache := newReceivedSignalCache(4)
|
|
|
|
if duplicate := cache.seenOrRemember("client", 1); duplicate {
|
|
t.Fatal("first signal should not be duplicate")
|
|
}
|
|
if duplicate := cache.seenOrRemember("client", 1); !duplicate {
|
|
t.Fatal("second signal with same scope/id should be duplicate")
|
|
}
|
|
if duplicate := cache.seenOrRemember("server:client-a", 1); duplicate {
|
|
t.Fatal("same signal id in another scope should not be duplicate")
|
|
}
|
|
}
|
|
|
|
func TestReceivedSignalCacheEvictsOldest(t *testing.T) {
|
|
cache := newReceivedSignalCache(2)
|
|
|
|
cache.seenOrRemember("client", 1)
|
|
cache.seenOrRemember("client", 2)
|
|
cache.seenOrRemember("client", 3)
|
|
|
|
if duplicate := cache.seenOrRemember("client", 1); duplicate {
|
|
t.Fatal("oldest signal should have been evicted from cache")
|
|
}
|
|
if duplicate := cache.seenOrRemember("client", 3); !duplicate {
|
|
t.Fatal("latest signal should still be cached")
|
|
}
|
|
}
|