(t *testing.T)
| 23 | const tenantID = "tenant-id" |
| 24 | |
| 25 | func TestForwarder(t *testing.T) { |
| 26 | oCfg := overrides.Config{} |
| 27 | oCfg.RegisterFlagsAndApplyDefaults(&flag.FlagSet{}) |
| 28 | |
| 29 | id, err := util.HexStringToTraceID("1234567890abcdef") |
| 30 | require.NoError(t, err) |
| 31 | |
| 32 | b := test.MakeBatch(10, id) |
| 33 | keys, rebatchedTraces, _, _, err := requestsByTraceID([]*v1.ResourceSpans{b}, tenantID, 10, 1000) |
| 34 | require.NoError(t, err) |
| 35 | |
| 36 | o, err := overrides.NewOverrides(oCfg, nil, prometheus.DefaultRegisterer) |
| 37 | require.NoError(t, err) |
| 38 | |
| 39 | noGenerateMetricsRequestCount := 0 |
| 40 | |
| 41 | wg := sync.WaitGroup{} |
| 42 | f := newGeneratorForwarder( |
| 43 | log.NewNopLogger(), |
| 44 | func(_ context.Context, userID string, k []uint32, traces []*rebatchedTrace, noGenerateMetrics bool) error { |
| 45 | assert.Equal(t, tenantID, userID) |
| 46 | assert.Equal(t, keys, k) |
| 47 | assert.Equal(t, rebatchedTraces, traces) |
| 48 | if noGenerateMetrics { |
| 49 | noGenerateMetricsRequestCount++ |
| 50 | } |
| 51 | wg.Done() |
| 52 | return nil |
| 53 | }, |
| 54 | o, |
| 55 | ) |
| 56 | require.NoError(t, f.start(context.Background())) |
| 57 | defer func() { |
| 58 | require.NoError(t, f.stop(nil)) |
| 59 | }() |
| 60 | |
| 61 | wg.Add(1) |
| 62 | // Mark this request as "to-be-ignored" for metrics generation. |
| 63 | ctx = metadata.NewIncomingContext(ctx, metadata.Pairs(generator.NoGenerateMetricsContextKey, "")) |
| 64 | f.SendTraces(ctx, tenantID, keys, rebatchedTraces) |
| 65 | wg.Wait() |
| 66 | |
| 67 | wg.Add(1) |
| 68 | f.SendTraces(context.Background(), tenantID, keys, rebatchedTraces) |
| 69 | wg.Wait() |
| 70 | |
| 71 | // Expect to receive one request for which no metrics should be generated in metrics-generator. |
| 72 | require.Equal(t, 1, noGenerateMetricsRequestCount) |
| 73 | } |
| 74 | |
| 75 | func TestForwarder_shutdown(t *testing.T) { |
| 76 | oCfg := overrides.Config{} |
nothing calls this directly
no test coverage detected