MCPcopy
hub / github.com/grafana/tempo / TestMinOverTimeForSpanAttribute

Function TestMinOverTimeForSpanAttribute

pkg/traceql/engine_metrics_test.go:1355–1425  ·  view source on GitHub ↗
(t *testing.T)

Source from the content-addressed store, hash-verified

1353}
1354
1355func TestMinOverTimeForSpanAttribute(t *testing.T) {
1356 req := &tempopb.QueryRangeRequest{
1357 Start: 1,
1358 End: uint64(3 * time.Second),
1359 Step: uint64(1 * time.Second),
1360 Query: "{ } | min_over_time(span.http.status_code) by (span.foo)",
1361 }
1362
1363 // A variety of spans across times, durations, and series. All durations are powers of 2 for simplicity
1364 in := []Span{
1365 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(128),
1366 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 404).WithDuration(256),
1367 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(512),
1368
1369 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(256),
1370 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(64),
1371 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(256),
1372 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(8),
1373
1374 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 201).WithDuration(512),
1375 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 401).WithDuration(1024),
1376 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 500).WithDuration(512),
1377 }
1378
1379 in2 := []Span{
1380 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 100).WithDuration(128),
1381 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 200).WithDuration(256),
1382 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 300).WithDuration(512),
1383 newMockSpan(nil).WithStartTime(uint64(1*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 204).WithDuration(512),
1384
1385 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 400).WithDuration(256),
1386 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 401).WithDuration(64),
1387 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 402).WithDuration(256),
1388 newMockSpan(nil).WithStartTime(uint64(2*time.Second)).WithSpanString("foo", "bar").WithSpanInt("http.status_code", 403).WithDuration(8),
1389
1390 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 200).WithDuration(512),
1391 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 300).WithDuration(1024),
1392 newMockSpan(nil).WithStartTime(uint64(3*time.Second)).WithSpanString("foo", "baz").WithSpanInt("http.status_code", 400).WithDuration(512),
1393 }
1394
1395 result, seriesCount, err := runTraceQLMetric(req, in, in2)
1396 require.NoError(t, err)
1397
1398 fooBaz := result[LabelsFromArgs("span.foo", "baz").MapKey()]
1399 fooBar := result[LabelsFromArgs("span.foo", "bar").MapKey()]
1400
1401 // Alas,we cannot compare with require.Equal because NaN != NaN
1402 // foo.baz = (204, NaN, 200)
1403 assert.Equal(t, 204.0, fooBaz.Values[0])
1404 assert.True(t, math.IsNaN(fooBaz.Values[1]))
1405 assert.Equal(t, 200.0, fooBaz.Values[2])
1406 require.Equal(t, len(result), seriesCount)
1407
1408 // foo.bar = (100,200, NaN)
1409 assert.Equal(t, 100.0, fooBar.Values[0])
1410 assert.Equal(t, 200.0, fooBar.Values[1])
1411 assert.True(t, math.IsNaN(fooBar.Values[2]))
1412

Callers

nothing calls this directly

Calls 12

newMockSpanFunction · 0.85
runTraceQLMetricFunction · 0.85
LabelsFromArgsFunction · 0.85
LabelsFromProtoFunction · 0.85
WithDurationMethod · 0.80
WithSpanIntMethod · 0.80
WithSpanStringMethod · 0.80
WithStartTimeMethod · 0.80
ToProtoMethod · 0.80
MapKeyMethod · 0.45
EqualMethod · 0.45
StringMethod · 0.45

Tested by

no test coverage detected