mirror of
https://github.com/zitadel/zitadel.git
synced 2024-12-15 04:18:01 +00:00
250f2344c8
# Which Problems Are Solved Add a cache implementation using Redis single mode. This does not add support for Redis Cluster or sentinel. # How the Problems Are Solved Added the `internal/cache/redis` package. All operations occur atomically, including setting of secondary indexes, using LUA scripts where needed. The [`miniredis`](https://github.com/alicebob/miniredis) package is used to run unit tests. # Additional Changes - Move connector code to `internal/cache/connector/...` and remove duplicate code from `query` and `command` packages. - Fix a missed invalidation on the restrictions projection # Additional Context Closes #8130
44 lines
811 B
Go
44 lines
811 B
Go
package cache
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/jonboulle/clockwork"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
type testPruner struct {
|
|
called chan struct{}
|
|
}
|
|
|
|
func (p *testPruner) Prune(context.Context) error {
|
|
p.called <- struct{}{}
|
|
return nil
|
|
}
|
|
|
|
func TestAutoPruneConfig_startAutoPrune(t *testing.T) {
|
|
c := AutoPruneConfig{
|
|
Interval: time.Second,
|
|
Timeout: time.Millisecond,
|
|
}
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
|
|
defer cancel()
|
|
|
|
pruner := testPruner{
|
|
called: make(chan struct{}),
|
|
}
|
|
clock := clockwork.NewFakeClock()
|
|
close := c.startAutoPrune(ctx, &pruner, PurposeAuthzInstance, clock)
|
|
defer close()
|
|
clock.Advance(time.Second)
|
|
|
|
select {
|
|
case _, ok := <-pruner.called:
|
|
assert.True(t, ok)
|
|
case <-ctx.Done():
|
|
t.Fatal(ctx.Err())
|
|
}
|
|
}
|