(t *testing.T)
| 1353 | } |
| 1354 | |
| 1355 | func 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 |
nothing calls this directly
no test coverage detected