(t *testing.T)
| 22 | } |
| 23 | |
| 24 | func TestCryptoKeyCache(t *testing.T) { |
| 25 | t.Parallel() |
| 26 | |
| 27 | t.Run("Signing", func(t *testing.T) { |
| 28 | t.Parallel() |
| 29 | |
| 30 | t.Run("HitsCache", func(t *testing.T) { |
| 31 | t.Parallel() |
| 32 | var ( |
| 33 | ctx = testutil.Context(t, testutil.WaitShort) |
| 34 | logger = testutil.Logger(t) |
| 35 | clock = quartz.NewMock(t) |
| 36 | ) |
| 37 | |
| 38 | now := clock.Now().UTC() |
| 39 | expected := codersdk.CryptoKey{ |
| 40 | Feature: codersdk.CryptoKeyFeatureTailnetResume, |
| 41 | Secret: generateKey(t, 64), |
| 42 | Sequence: 2, |
| 43 | StartsAt: now, |
| 44 | } |
| 45 | olderKey := codersdk.CryptoKey{ |
| 46 | Feature: codersdk.CryptoKeyFeatureTailnetResume, |
| 47 | Secret: generateKey(t, 64), |
| 48 | Sequence: 1, |
| 49 | StartsAt: now, |
| 50 | } |
| 51 | |
| 52 | ff := &fakeFetcher{ |
| 53 | keys: []codersdk.CryptoKey{expected, olderKey}, |
| 54 | } |
| 55 | |
| 56 | cache, err := cryptokeys.NewSigningCache(ctx, logger, ff, codersdk.CryptoKeyFeatureTailnetResume, cryptokeys.WithCacheClock(clock)) |
| 57 | require.NoError(t, err) |
| 58 | |
| 59 | id, got, err := cache.SigningKey(ctx) |
| 60 | require.NoError(t, err) |
| 61 | require.Equal(t, keyID(expected), id) |
| 62 | require.Equal(t, decodedSecret(t, expected), got) |
| 63 | require.Equal(t, 1, ff.called) |
| 64 | }) |
| 65 | |
| 66 | t.Run("MissesCache", func(t *testing.T) { |
| 67 | t.Parallel() |
| 68 | var ( |
| 69 | ctx = testutil.Context(t, testutil.WaitShort) |
| 70 | logger = testutil.Logger(t) |
| 71 | clock = quartz.NewMock(t) |
| 72 | ) |
| 73 | |
| 74 | ff := &fakeFetcher{ |
| 75 | keys: []codersdk.CryptoKey{}, |
| 76 | } |
| 77 | |
| 78 | cache, err := cryptokeys.NewSigningCache(ctx, logger, ff, codersdk.CryptoKeyFeatureTailnetResume, cryptokeys.WithCacheClock(clock)) |
| 79 | require.NoError(t, err) |
| 80 | |
| 81 | expected := codersdk.CryptoKey{ |
nothing calls this directly
no test coverage detected