Skip to content

Conversation

@avara1986
Copy link
Member

Description

LLMObs and CIVisibility are currently using evp_proxy, and in the coming days, the new OpenFeature functionality will also need the proxy.
This PR consolidates in the ddtrace/internal/evp_proxy namespace the constants common to this proxy.

Next steps:

  • Check if the calls to the endpoint can be unified. It looks like at least LLMObs and OpenFeature can be.
  • Integrate evp_proxy with OpenFeature.

@avara1986 avara1986 added the changelog/no-changelog A changelog entry is not required for this PR. label Oct 28, 2025
@github-actions
Copy link
Contributor

CODEOWNERS have been resolved as:

ddtrace/internal/evp_proxy/constants.py                                 @DataDog/apm-core-python
ddtrace/internal/ci_visibility/_api_client.py                           @DataDog/ci-app-libraries
ddtrace/internal/ci_visibility/constants.py                             @DataDog/ci-app-libraries
ddtrace/internal/ci_visibility/git_client.py                            @DataDog/ci-app-libraries
ddtrace/internal/ci_visibility/recorder.py                              @DataDog/ci-app-libraries
ddtrace/internal/ci_visibility/writer.py                                @DataDog/ci-app-libraries
ddtrace/llmobs/_constants.py                                            @DataDog/ml-observability
ddtrace/llmobs/_writer.py                                               @DataDog/ml-observability
tests/ci_visibility/api_client/_util.py                                 @DataDog/ci-app-libraries
tests/ci_visibility/api_client/test_ci_visibility_api_client.py         @DataDog/ci-app-libraries
tests/ci_visibility/test_ci_visibility.py                               @DataDog/ci-app-libraries
tests/integration/test_integration_civisibility.py                      @DataDog/ci-app-libraries
tests/llmobs/test_llmobs_eval_metric_agent_writer.py                    @DataDog/ml-observability
tests/llmobs/test_llmobs_span_agent_writer.py                           @DataDog/ml-observability
tests/llmobs/test_llmobs_span_truncation.py                             @DataDog/ml-observability

@github-actions
Copy link
Contributor

github-actions bot commented Oct 28, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

The average import time from this PR is: 237 ± 2 ms.

The average import time from base is: 239 ± 2 ms.

The import time difference between this PR and base is: -2.16 ± 0.08 ms.

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 1.960 ms (0.83%)
ddtrace.bootstrap.sitecustomize 1.280 ms (0.54%)
ddtrace.bootstrap.preload 1.280 ms (0.54%)
ddtrace.internal.remoteconfig.client 0.632 ms (0.27%)
ddtrace 0.680 ms (0.29%)
ddtrace.internal._unpatched 0.029 ms (0.01%)
json 0.029 ms (0.01%)
json.decoder 0.029 ms (0.01%)
re 0.029 ms (0.01%)
enum 0.029 ms (0.01%)
types 0.029 ms (0.01%)

@avara1986 avara1986 marked this pull request as ready for review October 28, 2025 13:08
@avara1986 avara1986 requested review from a team as code owners October 28, 2025 13:08
@pr-commenter
Copy link

pr-commenter bot commented Oct 28, 2025

Performance SLOs

Comparing candidate avara/refactor_env_proxy (ad23935) with baseline main (e4d2c2f)

📈 Performance Regressions (2 suites)
📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 5.314µs (SLO: <10.000µs 📉 -46.9%) vs baseline: 📈 +24.7%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.7%


✅ ospathbasename_noaspect

Time: ✅ 1.089µs (SLO: <10.000µs 📉 -89.1%) vs baseline: ~same

Memory: ✅ 37.356MB (SLO: <39.000MB -4.2%) vs baseline: +4.7%


✅ ospathjoin_aspect

Time: ✅ 6.481µs (SLO: <10.000µs 📉 -35.2%) vs baseline: +4.7%

Memory: ✅ 37.375MB (SLO: <39.000MB -4.2%) vs baseline: +4.8%


✅ ospathjoin_noaspect

Time: ✅ 2.288µs (SLO: <10.000µs 📉 -77.1%) vs baseline: -0.9%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.8%


✅ ospathnormcase_aspect

Time: ✅ 3.527µs (SLO: <10.000µs 📉 -64.7%) vs baseline: -0.8%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.9%


✅ ospathnormcase_noaspect

Time: ✅ 0.570µs (SLO: <10.000µs 📉 -94.3%) vs baseline: -0.8%

Memory: ✅ 37.434MB (SLO: <39.000MB -4.0%) vs baseline: +4.9%


✅ ospathsplit_aspect

Time: ✅ 4.836µs (SLO: <10.000µs 📉 -51.6%) vs baseline: -0.2%

Memory: ✅ 37.434MB (SLO: <39.000MB -4.0%) vs baseline: +5.0%


✅ ospathsplit_noaspect

Time: ✅ 1.590µs (SLO: <10.000µs 📉 -84.1%) vs baseline: +0.3%

Memory: ✅ 37.473MB (SLO: <39.000MB -3.9%) vs baseline: +5.0%


✅ ospathsplitdrive_aspect

Time: ✅ 3.745µs (SLO: <10.000µs 📉 -62.6%) vs baseline: +1.3%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.7%


✅ ospathsplitdrive_noaspect

Time: ✅ 0.710µs (SLO: <10.000µs 📉 -92.9%) vs baseline: +1.1%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.8%


✅ ospathsplitext_aspect

Time: ✅ 4.625µs (SLO: <10.000µs 📉 -53.8%) vs baseline: +1.3%

Memory: ✅ 37.473MB (SLO: <39.000MB -3.9%) vs baseline: +4.9%


✅ ospathsplitext_noaspect

Time: ✅ 1.374µs (SLO: <10.000µs 📉 -86.3%) vs baseline: -0.7%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.8%


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 2.906µs (SLO: <20.000µs 📉 -85.5%) vs baseline: -0.7%

Memory: ✅ 31.968MB (SLO: <34.000MB -6.0%) vs baseline: +5.2%


✅ 1-count-metrics-100-times

Time: ✅ 197.185µs (SLO: <220.000µs 📉 -10.4%) vs baseline: -0.5%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +4.9%


✅ 1-distribution-metric-1-times

Time: ✅ 3.310µs (SLO: <20.000µs 📉 -83.4%) vs baseline: +1.6%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ 1-distribution-metrics-100-times

Time: ✅ 211.149µs (SLO: <220.000µs -4.0%) vs baseline: -0.3%

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.7%


✅ 1-gauge-metric-1-times

Time: ✅ 2.180µs (SLO: <20.000µs 📉 -89.1%) vs baseline: ~same

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.9%


✅ 1-gauge-metrics-100-times

Time: ✅ 137.439µs (SLO: <150.000µs -8.4%) vs baseline: +0.8%

Memory: ✅ 31.870MB (SLO: <34.000MB -6.3%) vs baseline: +4.9%


✅ 1-rate-metric-1-times

Time: ✅ 3.357µs (SLO: <20.000µs 📉 -83.2%) vs baseline: 📈 +10.1%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.7%


✅ 1-rate-metrics-100-times

Time: ✅ 210.713µs (SLO: <250.000µs 📉 -15.7%) vs baseline: -0.6%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.0%


✅ 100-count-metrics-100-times

Time: ✅ 19.937ms (SLO: <22.000ms -9.4%) vs baseline: ~same

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.7%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.209ms (SLO: <2.300ms -3.9%) vs baseline: -1.2%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.1%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.410ms (SLO: <1.550ms -9.0%) vs baseline: +0.6%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.9%


✅ 100-rate-metrics-100-times

Time: ✅ 2.191ms (SLO: <2.550ms 📉 -14.1%) vs baseline: +0.6%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.1%


✅ flush-1-metric

Time: ✅ 4.684µs (SLO: <20.000µs 📉 -76.6%) vs baseline: +1.1%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.1%


✅ flush-100-metrics

Time: ✅ 173.707µs (SLO: <250.000µs 📉 -30.5%) vs baseline: -0.2%

Memory: ✅ 31.870MB (SLO: <34.000MB -6.3%) vs baseline: +4.9%


✅ flush-1000-metrics

Time: ✅ 2.107ms (SLO: <2.500ms 📉 -15.7%) vs baseline: -0.7%

Memory: ✅ 32.657MB (SLO: <34.500MB -5.3%) vs baseline: +4.9%

🟡 Near SLO Breach (4 suites)
🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 20.540ms (SLO: <22.300ms -7.9%) vs baseline: +0.7%

Memory: ✅ 66.100MB (SLO: <67.000MB 🟡 -1.3%) vs baseline: +4.9%


✅ exception-replay-enabled

Time: ✅ 1.338ms (SLO: <1.450ms -7.7%) vs baseline: ~same

Memory: ✅ 64.136MB (SLO: <67.000MB -4.3%) vs baseline: +4.9%


✅ iast

Time: ✅ 20.429ms (SLO: <22.250ms -8.2%) vs baseline: -0.5%

Memory: ✅ 66.080MB (SLO: <67.000MB 🟡 -1.4%) vs baseline: +4.9%


✅ profiler

Time: ✅ 15.560ms (SLO: <16.550ms -6.0%) vs baseline: +0.6%

Memory: ✅ 53.752MB (SLO: <54.500MB 🟡 -1.4%) vs baseline: +4.9%


✅ resource-renaming

Time: ✅ 20.578ms (SLO: <21.750ms -5.4%) vs baseline: +0.5%

Memory: ✅ 65.974MB (SLO: <67.000MB 🟡 -1.5%) vs baseline: +4.8%


✅ span-code-origin

Time: ✅ 25.376ms (SLO: <28.200ms 📉 -10.0%) vs baseline: ~same

Memory: ✅ 67.091MB (SLO: <69.500MB -3.5%) vs baseline: +4.7%


✅ tracer

Time: ✅ 20.442ms (SLO: <21.750ms -6.0%) vs baseline: -0.2%

Memory: ✅ 66.060MB (SLO: <67.000MB 🟡 -1.4%) vs baseline: +4.9%


✅ tracer-and-profiler

Time: ✅ 22.663ms (SLO: <23.500ms -3.6%) vs baseline: ~same

Memory: ✅ 67.279MB (SLO: <68.000MB 🟡 -1.1%) vs baseline: +4.9%


✅ tracer-dont-create-db-spans

Time: ✅ 19.362ms (SLO: <21.500ms -9.9%) vs baseline: +0.3%

Memory: ✅ 66.041MB (SLO: <67.000MB 🟡 -1.4%) vs baseline: +4.9%


✅ tracer-minimal

Time: ✅ 16.532ms (SLO: <17.500ms -5.5%) vs baseline: -0.4%

Memory: ✅ 65.687MB (SLO: <67.000MB 🟡 -2.0%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 20.398ms (SLO: <21.750ms -6.2%) vs baseline: -0.4%

Memory: ✅ 71.413MB (SLO: <72.500MB 🟡 -1.5%) vs baseline: +4.8%


✅ tracer-no-caches

Time: ✅ 18.468ms (SLO: <19.650ms -6.0%) vs baseline: -0.1%

Memory: ✅ 65.737MB (SLO: <67.000MB 🟡 -1.9%) vs baseline: +4.7%


✅ tracer-no-databases

Time: ✅ 18.787ms (SLO: <20.100ms -6.5%) vs baseline: ~same

Memory: ✅ 65.667MB (SLO: <67.000MB 🟡 -2.0%) vs baseline: +4.8%


✅ tracer-no-middleware

Time: ✅ 20.212ms (SLO: <21.500ms -6.0%) vs baseline: +0.2%

Memory: ✅ 66.072MB (SLO: <67.000MB 🟡 -1.4%) vs baseline: +4.9%


✅ tracer-no-templates

Time: ✅ 20.292ms (SLO: <22.000ms -7.8%) vs baseline: +0.1%

Memory: ✅ 66.159MB (SLO: <67.000MB 🟡 -1.3%) vs baseline: +5.0%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 18.051ms (SLO: <19.850ms -9.1%) vs baseline: ~same

Memory: ✅ 65.667MB (SLO: <66.500MB 🟡 -1.3%) vs baseline: +4.8%


✅ errortracking-enabled-user

Time: ✅ 18.074ms (SLO: <19.400ms -6.8%) vs baseline: ~same

Memory: ✅ 65.687MB (SLO: <66.500MB 🟡 -1.2%) vs baseline: +4.8%


✅ tracer-enabled

Time: ✅ 18.053ms (SLO: <19.450ms -7.2%) vs baseline: -0.2%

Memory: ✅ 65.661MB (SLO: <66.500MB 🟡 -1.3%) vs baseline: +4.8%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 4.595ms (SLO: <4.750ms -3.3%) vs baseline: +0.2%

Memory: ✅ 62.271MB (SLO: <65.000MB -4.2%) vs baseline: +4.7%


✅ appsec-post

Time: ✅ 6.620ms (SLO: <6.750ms 🟡 -1.9%) vs baseline: -0.1%

Memory: ✅ 62.213MB (SLO: <65.000MB -4.3%) vs baseline: +4.8%


✅ appsec-telemetry

Time: ✅ 4.588ms (SLO: <4.750ms -3.4%) vs baseline: +0.2%

Memory: ✅ 62.345MB (SLO: <65.000MB -4.1%) vs baseline: +4.8%


✅ debugger

Time: ✅ 1.857ms (SLO: <2.000ms -7.2%) vs baseline: ~same

Memory: ✅ 45.164MB (SLO: <47.000MB -3.9%) vs baseline: +4.8%


✅ iast-get

Time: ✅ 1.858ms (SLO: <2.000ms -7.1%) vs baseline: +0.3%

Memory: ✅ 42.119MB (SLO: <49.000MB 📉 -14.0%) vs baseline: +4.9%


✅ profiler

Time: ✅ 1.913ms (SLO: <2.100ms -8.9%) vs baseline: +0.2%

Memory: ✅ 46.158MB (SLO: <47.000MB 🟡 -1.8%) vs baseline: +4.6%


✅ resource-renaming

Time: ✅ 3.365ms (SLO: <3.650ms -7.8%) vs baseline: ~same

Memory: ✅ 52.521MB (SLO: <53.500MB 🟡 -1.8%) vs baseline: +4.7%


✅ tracer

Time: ✅ 3.356ms (SLO: <3.650ms -8.1%) vs baseline: ~same

Memory: ✅ 52.542MB (SLO: <53.500MB 🟡 -1.8%) vs baseline: +4.8%


✅ tracer-native

Time: ✅ 3.347ms (SLO: <3.650ms -8.3%) vs baseline: ~same

Memory: ✅ 58.117MB (SLO: <60.000MB -3.1%) vs baseline: +5.0%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 3.979ms (SLO: <4.200ms -5.3%) vs baseline: -0.4%

Memory: ✅ 62.325MB (SLO: <66.000MB -5.6%) vs baseline: +5.0%


✅ iast-enabled

Time: ✅ 2.440ms (SLO: <2.800ms 📉 -12.9%) vs baseline: -0.5%

Memory: ✅ 59.061MB (SLO: <60.000MB 🟡 -1.6%) vs baseline: +4.9%


✅ tracer-enabled

Time: ✅ 2.058ms (SLO: <2.250ms -8.5%) vs baseline: ~same

Memory: ✅ 52.455MB (SLO: <54.500MB -3.8%) vs baseline: +4.8%

⚠️ Unstable Tests (1 suite)
⚠️ coreapiscenario - 10/10 (1 unstable)

⚠️ context_with_data_listeners

Time: ⚠️ 13.155µs (SLO: <20.000µs 📉 -34.2%) vs baseline: -1.0%

Memory: ✅ 31.457MB (SLO: <33.500MB -6.1%) vs baseline: +4.7%


✅ context_with_data_no_listeners

Time: ✅ 3.231µs (SLO: <10.000µs 📉 -67.7%) vs baseline: -1.7%

Memory: ✅ 31.516MB (SLO: <33.500MB -5.9%) vs baseline: +4.9%


✅ get_item_exists

Time: ✅ 0.582µs (SLO: <10.000µs 📉 -94.2%) vs baseline: +0.8%

Memory: ✅ 31.477MB (SLO: <33.500MB -6.0%) vs baseline: +4.8%


✅ get_item_missing

Time: ✅ 0.641µs (SLO: <10.000µs 📉 -93.6%) vs baseline: +0.8%

Memory: ✅ 31.516MB (SLO: <33.500MB -5.9%) vs baseline: +5.0%


✅ set_item

Time: ✅ 24.195µs (SLO: <30.000µs 📉 -19.4%) vs baseline: +0.6%

Memory: ✅ 31.497MB (SLO: <33.500MB -6.0%) vs baseline: +4.9%

✅ All Tests Passing (17 suites)
errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.074ms (SLO: <2.300ms -9.8%) vs baseline: +0.2%

Memory: ✅ 52.337MB (SLO: <53.500MB -2.2%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 2.071ms (SLO: <2.250ms -8.0%) vs baseline: +0.4%

Memory: ✅ 52.278MB (SLO: <53.500MB -2.3%) vs baseline: +4.5%


✅ tracer-enabled

Time: ✅ 2.074ms (SLO: <2.300ms -9.8%) vs baseline: ~same

Memory: ✅ 52.258MB (SLO: <53.500MB -2.3%) vs baseline: +4.5%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.311µs (SLO: <100.000µs 📉 -18.7%) vs baseline: ~same

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ b3_headers

Time: ✅ 14.847µs (SLO: <20.000µs 📉 -25.8%) vs baseline: +5.1%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.9%


✅ b3_single_headers

Time: ✅ 13.386µs (SLO: <20.000µs 📉 -33.1%) vs baseline: +0.8%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.5%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 65.737µs (SLO: <80.000µs 📉 -17.8%) vs baseline: +3.3%

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 65.835µs (SLO: <80.000µs 📉 -17.7%) vs baseline: ~same

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ empty_headers

Time: ✅ 1.604µs (SLO: <10.000µs 📉 -84.0%) vs baseline: -0.3%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +5.0%


✅ full_t_id_datadog_headers

Time: ✅ 23.045µs (SLO: <30.000µs 📉 -23.2%) vs baseline: +0.3%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.7%


✅ invalid_priority_header

Time: ✅ 6.564µs (SLO: <10.000µs 📉 -34.4%) vs baseline: ~same

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.5%


✅ invalid_span_id_header

Time: ✅ 6.643µs (SLO: <10.000µs 📉 -33.6%) vs baseline: +1.0%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ invalid_tags_header

Time: ✅ 6.567µs (SLO: <10.000µs 📉 -34.3%) vs baseline: +0.6%

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.1%


✅ invalid_trace_id_header

Time: ✅ 6.549µs (SLO: <10.000µs 📉 -34.5%) vs baseline: -0.3%

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.7%


✅ large_header_no_matches

Time: ✅ 27.603µs (SLO: <30.000µs -8.0%) vs baseline: -0.3%

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +5.0%


✅ large_valid_headers_all

Time: ✅ 28.715µs (SLO: <40.000µs 📉 -28.2%) vs baseline: ~same

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +5.1%


✅ medium_header_no_matches

Time: ✅ 9.907µs (SLO: <20.000µs 📉 -50.5%) vs baseline: +0.4%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +5.0%


✅ medium_valid_headers_all

Time: ✅ 11.264µs (SLO: <20.000µs 📉 -43.7%) vs baseline: +0.1%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ none_propagation_style

Time: ✅ 1.705µs (SLO: <10.000µs 📉 -83.0%) vs baseline: ~same

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.5%


✅ tracecontext_headers

Time: ✅ 34.614µs (SLO: <40.000µs 📉 -13.5%) vs baseline: +0.3%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ valid_headers_all

Time: ✅ 6.548µs (SLO: <10.000µs 📉 -34.5%) vs baseline: ~same

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ valid_headers_basic

Time: ✅ 6.127µs (SLO: <10.000µs 📉 -38.7%) vs baseline: ~same

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.8%


✅ wsgi_empty_headers

Time: ✅ 1.622µs (SLO: <10.000µs 📉 -83.8%) vs baseline: +0.8%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.8%


✅ wsgi_invalid_priority_header

Time: ✅ 6.559µs (SLO: <10.000µs 📉 -34.4%) vs baseline: ~same

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.7%


✅ wsgi_invalid_span_id_header

Time: ✅ 1.605µs (SLO: <10.000µs 📉 -84.0%) vs baseline: +0.5%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ wsgi_invalid_tags_header

Time: ✅ 6.660µs (SLO: <10.000µs 📉 -33.4%) vs baseline: +1.2%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ wsgi_invalid_trace_id_header

Time: ✅ 6.561µs (SLO: <10.000µs 📉 -34.4%) vs baseline: ~same

Memory: ✅ 31.870MB (SLO: <33.500MB -4.9%) vs baseline: +4.6%


✅ wsgi_large_header_no_matches

Time: ✅ 28.652µs (SLO: <40.000µs 📉 -28.4%) vs baseline: -0.5%

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.7%


✅ wsgi_large_valid_headers_all

Time: ✅ 29.902µs (SLO: <40.000µs 📉 -25.2%) vs baseline: +0.3%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ wsgi_medium_header_no_matches

Time: ✅ 10.094µs (SLO: <20.000µs 📉 -49.5%) vs baseline: -0.4%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.8%


✅ wsgi_medium_valid_headers_all

Time: ✅ 11.649µs (SLO: <20.000µs 📉 -41.8%) vs baseline: +0.7%

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ wsgi_valid_headers_all

Time: ✅ 6.630µs (SLO: <10.000µs 📉 -33.7%) vs baseline: +0.1%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +5.0%


✅ wsgi_valid_headers_basic

Time: ✅ 6.235µs (SLO: <10.000µs 📉 -37.7%) vs baseline: +1.8%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.9%


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 21.041µs (SLO: <30.000µs 📉 -29.9%) vs baseline: -0.1%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ with_all

Time: ✅ 28.656µs (SLO: <40.000µs 📉 -28.4%) vs baseline: +1.0%

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.0%


✅ with_dd_origin

Time: ✅ 24.847µs (SLO: <30.000µs 📉 -17.2%) vs baseline: -0.1%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ with_priority_and_origin

Time: ✅ 24.435µs (SLO: <40.000µs 📉 -38.9%) vs baseline: +0.7%

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.8%


✅ with_sampling_priority

Time: ✅ 21.157µs (SLO: <30.000µs 📉 -29.5%) vs baseline: -0.2%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ with_tags

Time: ✅ 26.633µs (SLO: <40.000µs 📉 -33.4%) vs baseline: -0.6%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ with_tags_invalid

Time: ✅ 28.476µs (SLO: <40.000µs 📉 -28.8%) vs baseline: +1.5%

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.8%


✅ with_tags_max_size

Time: ✅ 26.991µs (SLO: <40.000µs 📉 -32.5%) vs baseline: +0.1%

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.1%


iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 32.100µs (SLO: <40.000µs 📉 -19.8%) vs baseline: ~same

Memory: ✅ 37.375MB (SLO: <39.000MB -4.2%) vs baseline: +4.5%


✅ re_expand_noaspect

Time: ✅ 28.631µs (SLO: <40.000µs 📉 -28.4%) vs baseline: +0.4%

Memory: ✅ 37.434MB (SLO: <39.000MB -4.0%) vs baseline: +4.8%


✅ re_findall_aspect

Time: ✅ 2.883µs (SLO: <10.000µs 📉 -71.2%) vs baseline: ~same

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +5.0%


✅ re_findall_noaspect

Time: ✅ 1.420µs (SLO: <10.000µs 📉 -85.8%) vs baseline: ~same

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +5.0%


✅ re_finditer_aspect

Time: ✅ 4.638µs (SLO: <10.000µs 📉 -53.6%) vs baseline: +4.1%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ re_finditer_noaspect

Time: ✅ 1.411µs (SLO: <10.000µs 📉 -85.9%) vs baseline: -0.5%

Memory: ✅ 37.473MB (SLO: <39.000MB -3.9%) vs baseline: +4.9%


✅ re_fullmatch_aspect

Time: ✅ 2.637µs (SLO: <10.000µs 📉 -73.6%) vs baseline: ~same

Memory: ✅ 37.375MB (SLO: <39.000MB -4.2%) vs baseline: +4.7%


✅ re_fullmatch_noaspect

Time: ✅ 1.295µs (SLO: <10.000µs 📉 -87.0%) vs baseline: -0.2%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ re_group_aspect

Time: ✅ 2.930µs (SLO: <10.000µs 📉 -70.7%) vs baseline: -2.8%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.8%


✅ re_group_noaspect

Time: ✅ 1.614µs (SLO: <10.000µs 📉 -83.9%) vs baseline: +0.8%

Memory: ✅ 37.434MB (SLO: <39.000MB -4.0%) vs baseline: +4.9%


✅ re_groups_aspect

Time: ✅ 3.057µs (SLO: <10.000µs 📉 -69.4%) vs baseline: -2.0%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ re_groups_noaspect

Time: ✅ 1.710µs (SLO: <10.000µs 📉 -82.9%) vs baseline: +0.9%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.8%


✅ re_match_aspect

Time: ✅ 2.659µs (SLO: <10.000µs 📉 -73.4%) vs baseline: -2.6%

Memory: ✅ 37.473MB (SLO: <39.000MB -3.9%) vs baseline: +5.1%


✅ re_match_noaspect

Time: ✅ 1.289µs (SLO: <10.000µs 📉 -87.1%) vs baseline: -1.2%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +5.0%


✅ re_search_aspect

Time: ✅ 2.550µs (SLO: <10.000µs 📉 -74.5%) vs baseline: -0.2%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ re_search_noaspect

Time: ✅ 1.201µs (SLO: <10.000µs 📉 -88.0%) vs baseline: +0.6%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.8%


✅ re_sub_aspect

Time: ✅ 3.383µs (SLO: <10.000µs 📉 -66.2%) vs baseline: -1.2%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.5%


✅ re_sub_noaspect

Time: ✅ 1.535µs (SLO: <10.000µs 📉 -84.6%) vs baseline: +0.5%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ re_subn_aspect

Time: ✅ 3.688µs (SLO: <10.000µs 📉 -63.1%) vs baseline: -0.3%

Memory: ✅ 37.415MB (SLO: <39.000MB -4.1%) vs baseline: +4.8%


✅ re_subn_noaspect

Time: ✅ 1.613µs (SLO: <10.000µs 📉 -83.9%) vs baseline: -0.6%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.9%


iastaspects - 118/118

✅ add_aspect

Time: ✅ 0.405µs (SLO: <10.000µs 📉 -95.9%) vs baseline: -0.4%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.1%


✅ add_inplace_aspect

Time: ✅ 0.412µs (SLO: <10.000µs 📉 -95.9%) vs baseline: +0.7%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ add_inplace_noaspect

Time: ✅ 0.319µs (SLO: <10.000µs 📉 -96.8%) vs baseline: +1.5%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ add_noaspect

Time: ✅ 0.278µs (SLO: <10.000µs 📉 -97.2%) vs baseline: +1.0%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.6%


✅ bytearray_aspect

Time: ✅ 1.326µs (SLO: <10.000µs 📉 -86.7%) vs baseline: +1.5%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.7%


✅ bytearray_extend_aspect

Time: ✅ 1.559µs (SLO: <10.000µs 📉 -84.4%) vs baseline: -0.2%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.8%


✅ bytearray_extend_noaspect

Time: ✅ 0.618µs (SLO: <10.000µs 📉 -93.8%) vs baseline: ~same

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ bytearray_noaspect

Time: ✅ 0.482µs (SLO: <10.000µs 📉 -95.2%) vs baseline: ~same

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.7%


✅ bytes_aspect

Time: ✅ 1.362µs (SLO: <10.000µs 📉 -86.4%) vs baseline: +7.2%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.1%


✅ bytes_noaspect

Time: ✅ 0.491µs (SLO: <10.000µs 📉 -95.1%) vs baseline: ~same

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.6%


✅ bytesio_aspect

Time: ✅ 1.301µs (SLO: <10.000µs 📉 -87.0%) vs baseline: -0.7%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +4.9%


✅ bytesio_noaspect

Time: ✅ 0.492µs (SLO: <10.000µs 📉 -95.1%) vs baseline: -0.2%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.8%


✅ capitalize_aspect

Time: ✅ 0.738µs (SLO: <10.000µs 📉 -92.6%) vs baseline: +0.1%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ capitalize_noaspect

Time: ✅ 0.440µs (SLO: <10.000µs 📉 -95.6%) vs baseline: +2.0%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +4.8%


✅ casefold_aspect

Time: ✅ 0.737µs (SLO: <10.000µs 📉 -92.6%) vs baseline: -0.2%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +4.9%


✅ casefold_noaspect

Time: ✅ 0.374µs (SLO: <10.000µs 📉 -96.3%) vs baseline: +1.2%

Memory: ✅ 37.906MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ decode_aspect

Time: ✅ 0.726µs (SLO: <10.000µs 📉 -92.7%) vs baseline: ~same

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.7%


✅ decode_noaspect

Time: ✅ 0.423µs (SLO: <10.000µs 📉 -95.8%) vs baseline: ~same

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.1%


✅ encode_aspect

Time: ✅ 0.709µs (SLO: <10.000µs 📉 -92.9%) vs baseline: ~same

Memory: ✅ 37.788MB (SLO: <39.000MB -3.1%) vs baseline: +4.7%


✅ encode_noaspect

Time: ✅ 0.401µs (SLO: <10.000µs 📉 -96.0%) vs baseline: ~same

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.0%


✅ format_aspect

Time: ✅ 3.409µs (SLO: <10.000µs 📉 -65.9%) vs baseline: +1.2%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.6%


✅ format_map_aspect

Time: ✅ 3.678µs (SLO: <10.000µs 📉 -63.2%) vs baseline: +1.1%

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +4.9%


✅ format_map_noaspect

Time: ✅ 0.777µs (SLO: <10.000µs 📉 -92.2%) vs baseline: +0.5%

Memory: ✅ 37.788MB (SLO: <39.000MB -3.1%) vs baseline: +4.8%


✅ format_noaspect

Time: ✅ 0.597µs (SLO: <10.000µs 📉 -94.0%) vs baseline: +0.1%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.6%


✅ index_aspect

Time: ✅ 0.358µs (SLO: <10.000µs 📉 -96.4%) vs baseline: +0.4%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.1%


✅ index_noaspect

Time: ✅ 0.277µs (SLO: <10.000µs 📉 -97.2%) vs baseline: -1.7%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ join_aspect

Time: ✅ 1.366µs (SLO: <10.000µs 📉 -86.3%) vs baseline: +0.8%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.1%


✅ join_noaspect

Time: ✅ 0.497µs (SLO: <10.000µs 📉 -95.0%) vs baseline: +1.4%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ ljust_aspect

Time: ✅ 2.550µs (SLO: <20.000µs 📉 -87.2%) vs baseline: ~same

Memory: ✅ 37.788MB (SLO: <39.000MB -3.1%) vs baseline: +4.5%


✅ ljust_noaspect

Time: ✅ 0.407µs (SLO: <10.000µs 📉 -95.9%) vs baseline: +1.3%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ lower_aspect

Time: ✅ 2.227µs (SLO: <10.000µs 📉 -77.7%) vs baseline: +1.3%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.7%


✅ lower_noaspect

Time: ✅ 0.371µs (SLO: <10.000µs 📉 -96.3%) vs baseline: +1.3%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ lstrip_aspect

Time: ✅ 2.209µs (SLO: <20.000µs 📉 -89.0%) vs baseline: +0.5%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +5.0%


✅ lstrip_noaspect

Time: ✅ 0.383µs (SLO: <10.000µs 📉 -96.2%) vs baseline: ~same

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ modulo_aspect

Time: ✅ 1.053µs (SLO: <10.000µs 📉 -89.5%) vs baseline: +1.0%

Memory: ✅ 37.788MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 1.684µs (SLO: <10.000µs 📉 -83.2%) vs baseline: +7.3%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +4.9%


✅ modulo_aspect_for_bytes

Time: ✅ 0.986µs (SLO: <10.000µs 📉 -90.1%) vs baseline: +0.7%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 1.270µs (SLO: <10.000µs 📉 -87.3%) vs baseline: -0.4%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ modulo_noaspect

Time: ✅ 0.634µs (SLO: <10.000µs 📉 -93.7%) vs baseline: +1.2%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +4.9%


✅ replace_aspect

Time: ✅ 5.428µs (SLO: <10.000µs 📉 -45.7%) vs baseline: +9.4%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.5%


✅ replace_noaspect

Time: ✅ 0.463µs (SLO: <10.000µs 📉 -95.4%) vs baseline: +0.4%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ repr_aspect

Time: ✅ 0.904µs (SLO: <10.000µs 📉 -91.0%) vs baseline: -0.3%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +4.8%


✅ repr_noaspect

Time: ✅ 0.419µs (SLO: <10.000µs 📉 -95.8%) vs baseline: +1.8%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.7%


✅ rstrip_aspect

Time: ✅ 1.925µs (SLO: <20.000µs 📉 -90.4%) vs baseline: +1.9%

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ rstrip_noaspect

Time: ✅ 0.381µs (SLO: <10.000µs 📉 -96.2%) vs baseline: +1.5%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.8%


✅ slice_aspect

Time: ✅ 0.495µs (SLO: <10.000µs 📉 -95.1%) vs baseline: +1.0%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ slice_noaspect

Time: ✅ 0.448µs (SLO: <10.000µs 📉 -95.5%) vs baseline: +0.3%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +5.0%


✅ stringio_aspect

Time: ✅ 1.582µs (SLO: <10.000µs 📉 -84.2%) vs baseline: +2.4%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ stringio_noaspect

Time: ✅ 0.719µs (SLO: <10.000µs 📉 -92.8%) vs baseline: +1.3%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ strip_aspect

Time: ✅ 2.209µs (SLO: <20.000µs 📉 -89.0%) vs baseline: +0.7%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ strip_noaspect

Time: ✅ 0.387µs (SLO: <10.000µs 📉 -96.1%) vs baseline: +0.2%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.8%


✅ swapcase_aspect

Time: ✅ 2.398µs (SLO: <10.000µs 📉 -76.0%) vs baseline: -0.4%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ swapcase_noaspect

Time: ✅ 0.535µs (SLO: <10.000µs 📉 -94.6%) vs baseline: ~same

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +4.9%


✅ title_aspect

Time: ✅ 2.331µs (SLO: <10.000µs 📉 -76.7%) vs baseline: +0.6%

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.8%


✅ title_noaspect

Time: ✅ 0.498µs (SLO: <10.000µs 📉 -95.0%) vs baseline: -1.0%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +4.7%


✅ translate_aspect

Time: ✅ 3.214µs (SLO: <10.000µs 📉 -67.9%) vs baseline: ~same

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.0%


✅ translate_noaspect

Time: ✅ 1.044µs (SLO: <10.000µs 📉 -89.6%) vs baseline: ~same

Memory: ✅ 37.827MB (SLO: <39.000MB -3.0%) vs baseline: +4.8%


✅ upper_aspect

Time: ✅ 2.206µs (SLO: <10.000µs 📉 -77.9%) vs baseline: -0.2%

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.0%


✅ upper_noaspect

Time: ✅ 0.370µs (SLO: <10.000µs 📉 -96.3%) vs baseline: -0.5%

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.8%


iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 1.483µs (SLO: <10.000µs 📉 -85.2%) vs baseline: +1.6%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.9%


✅ rsplit_noaspect

Time: ✅ 0.589µs (SLO: <10.000µs 📉 -94.1%) vs baseline: +0.3%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.6%


✅ split_aspect

Time: ✅ 1.451µs (SLO: <10.000µs 📉 -85.5%) vs baseline: +3.4%

Memory: ✅ 37.532MB (SLO: <39.000MB -3.8%) vs baseline: +5.0%


✅ split_noaspect

Time: ✅ 0.568µs (SLO: <10.000µs 📉 -94.3%) vs baseline: -0.5%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.9%


✅ splitlines_aspect

Time: ✅ 1.399µs (SLO: <10.000µs 📉 -86.0%) vs baseline: -0.2%

Memory: ✅ 37.473MB (SLO: <39.000MB -3.9%) vs baseline: +5.0%


✅ splitlines_noaspect

Time: ✅ 0.586µs (SLO: <10.000µs 📉 -94.1%) vs baseline: -0.1%

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +4.7%


iastpropagation - 2/2

✅ no-propagation

Time: ✅ 48.782µs (SLO: <60.000µs 📉 -18.7%) vs baseline: ~same

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.7%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.488ms (SLO: <42.000ms -3.6%) vs baseline: ~same

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.0%


✅ add-link

Time: ✅ 36.451ms (SLO: <38.550ms -5.4%) vs baseline: -0.2%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 217.670ms (SLO: <232.000ms -6.2%) vs baseline: -1.3%

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.8%


✅ add-tags

Time: ✅ 212.018ms (SLO: <221.600ms -4.3%) vs baseline: -0.8%

Memory: ✅ 34.269MB (SLO: <39.000MB 📉 -12.1%) vs baseline: +4.4%


✅ get-context

Time: ✅ 29.286ms (SLO: <31.300ms -6.4%) vs baseline: +0.3%

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.9%


✅ is-recording

Time: ✅ 29.300ms (SLO: <31.000ms -5.5%) vs baseline: +0.9%

Memory: ✅ 34.387MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +5.2%


✅ record-exception

Time: ✅ 63.221ms (SLO: <65.850ms -4.0%) vs baseline: -0.1%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


✅ set-status

Time: ✅ 32.281ms (SLO: <34.150ms -5.5%) vs baseline: +0.9%

Memory: ✅ 34.269MB (SLO: <39.000MB 📉 -12.1%) vs baseline: +4.6%


✅ start

Time: ✅ 29.365ms (SLO: <30.150ms -2.6%) vs baseline: +1.1%

Memory: ✅ 34.308MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.7%


✅ start-finish

Time: ✅ 33.983ms (SLO: <35.350ms -3.9%) vs baseline: +0.3%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.1%


✅ start-finish-telemetry

Time: ✅ 33.991ms (SLO: <35.450ms -4.1%) vs baseline: +0.4%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.7%


✅ update-name

Time: ✅ 31.036ms (SLO: <33.400ms -7.1%) vs baseline: -0.5%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


otelspan - 22/22

✅ add-event

Time: ✅ 40.216ms (SLO: <47.150ms 📉 -14.7%) vs baseline: ~same

Memory: ✅ 43.453MB (SLO: <47.000MB -7.5%) vs baseline: +4.6%


✅ add-metrics

Time: ✅ 316.294ms (SLO: <344.800ms -8.3%) vs baseline: ~same

Memory: ✅ 651.719MB (SLO: <675.000MB -3.4%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 288.520ms (SLO: <314.000ms -8.1%) vs baseline: +0.6%

Memory: ✅ 652.845MB (SLO: <675.000MB -3.3%) vs baseline: +4.9%


✅ get-context

Time: ✅ 80.352ms (SLO: <92.350ms 📉 -13.0%) vs baseline: +0.5%

Memory: ✅ 39.400MB (SLO: <46.500MB 📉 -15.3%) vs baseline: +4.9%


✅ is-recording

Time: ✅ 38.044ms (SLO: <44.500ms 📉 -14.5%) vs baseline: -0.2%

Memory: ✅ 42.808MB (SLO: <47.500MB -9.9%) vs baseline: +4.6%


✅ record-exception

Time: ✅ 57.931ms (SLO: <67.650ms 📉 -14.4%) vs baseline: ~same

Memory: ✅ 39.699MB (SLO: <47.000MB 📉 -15.5%) vs baseline: +4.7%


✅ set-status

Time: ✅ 43.958ms (SLO: <50.400ms 📉 -12.8%) vs baseline: +0.4%

Memory: ✅ 42.936MB (SLO: <47.000MB -8.6%) vs baseline: +4.8%


✅ start

Time: ✅ 37.336ms (SLO: <43.450ms 📉 -14.1%) vs baseline: +0.4%

Memory: ✅ 42.877MB (SLO: <47.000MB -8.8%) vs baseline: +4.7%


✅ start-finish

Time: ✅ 81.273ms (SLO: <88.000ms -7.6%) vs baseline: ~same

Memory: ✅ 34.367MB (SLO: <46.500MB 📉 -26.1%) vs baseline: +4.6%


✅ start-finish-telemetry

Time: ✅ 82.797ms (SLO: <89.000ms -7.0%) vs baseline: -0.2%

Memory: ✅ 34.367MB (SLO: <46.500MB 📉 -26.1%) vs baseline: +4.8%


✅ update-name

Time: ✅ 38.900ms (SLO: <45.150ms 📉 -13.8%) vs baseline: +0.4%

Memory: ✅ 43.283MB (SLO: <47.000MB -7.9%) vs baseline: +5.0%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 343.924ms (SLO: <354.300ms -2.9%) vs baseline: -0.5%

Memory: ✅ 37.227MB (SLO: <40.000MB -6.9%) vs baseline: +3.5%


✅ cache_on

Time: ✅ 0.384µs (SLO: <10.000µs 📉 -96.2%) vs baseline: +0.4%

Memory: ✅ 35.826MB (SLO: <39.000MB -8.1%) vs baseline: +5.8%


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 155.700µs (SLO: <170.000µs -8.4%) vs baseline: ~same

Memory: ✅ 36.727MB (SLO: <38.500MB -4.6%) vs baseline: +5.0%


✅ import_many_cached

Time: ✅ 121.011µs (SLO: <130.000µs -6.9%) vs baseline: ~same

Memory: ✅ 36.784MB (SLO: <38.500MB -4.5%) vs baseline: +5.5%


✅ import_many_stdlib

Time: ✅ 1.620ms (SLO: <1.750ms -7.4%) vs baseline: -0.1%

Memory: ✅ 36.915MB (SLO: <38.500MB -4.1%) vs baseline: +4.5%


✅ import_many_stdlib_cached

Time: ✅ 0.980ms (SLO: <1.100ms 📉 -10.9%) vs baseline: +0.9%

Memory: ✅ 36.789MB (SLO: <38.500MB -4.4%) vs baseline: +5.1%


✅ import_many_unknown

Time: ✅ 831.376µs (SLO: <890.000µs -6.6%) vs baseline: -0.7%

Memory: ✅ 36.818MB (SLO: <38.500MB -4.4%) vs baseline: +4.2%


✅ import_many_unknown_cached

Time: ✅ 788.211µs (SLO: <870.000µs -9.4%) vs baseline: -0.9%

Memory: ✅ 36.845MB (SLO: <38.500MB -4.3%) vs baseline: +4.6%


✅ import_one

Time: ✅ 20.006µs (SLO: <30.000µs 📉 -33.3%) vs baseline: +1.2%

Memory: ✅ 36.740MB (SLO: <39.000MB -5.8%) vs baseline: +5.1%


✅ import_one_cache

Time: ✅ 6.270µs (SLO: <10.000µs 📉 -37.3%) vs baseline: -0.5%

Memory: ✅ 36.775MB (SLO: <38.500MB -4.5%) vs baseline: +5.2%


✅ import_one_stdlib

Time: ✅ 18.883µs (SLO: <20.000µs -5.6%) vs baseline: +0.9%

Memory: ✅ 36.691MB (SLO: <38.500MB -4.7%) vs baseline: +5.0%


✅ import_one_stdlib_cache

Time: ✅ 6.284µs (SLO: <10.000µs 📉 -37.2%) vs baseline: +0.5%

Memory: ✅ 36.720MB (SLO: <38.500MB -4.6%) vs baseline: +4.9%


✅ import_one_unknown

Time: ✅ 45.675µs (SLO: <50.000µs -8.6%) vs baseline: +0.3%

Memory: ✅ 36.435MB (SLO: <38.500MB -5.4%) vs baseline: +3.8%


✅ import_one_unknown_cache

Time: ✅ 6.250µs (SLO: <10.000µs 📉 -37.5%) vs baseline: -0.5%

Memory: ✅ 36.708MB (SLO: <38.500MB -4.7%) vs baseline: +5.1%


ratelimiter - 12/12

✅ defaults

Time: ✅ 2.344µs (SLO: <10.000µs 📉 -76.6%) vs baseline: +0.1%

Memory: ✅ 31.477MB (SLO: <34.000MB -7.4%) vs baseline: +5.1%


✅ high_rate_limit

Time: ✅ 2.409µs (SLO: <10.000µs 📉 -75.9%) vs baseline: -0.4%

Memory: ✅ 31.457MB (SLO: <34.000MB -7.5%) vs baseline: +4.9%


✅ long_window

Time: ✅ 2.346µs (SLO: <10.000µs 📉 -76.5%) vs baseline: -0.7%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +5.0%


✅ low_rate_limit

Time: ✅ 2.349µs (SLO: <10.000µs 📉 -76.5%) vs baseline: ~same

Memory: ✅ 31.497MB (SLO: <34.000MB -7.4%) vs baseline: +5.1%


✅ no_rate_limit

Time: ✅ 0.828µs (SLO: <10.000µs 📉 -91.7%) vs baseline: +0.4%

Memory: ✅ 31.438MB (SLO: <34.000MB -7.5%) vs baseline: +4.7%


✅ short_window

Time: ✅ 2.485µs (SLO: <10.000µs 📉 -75.2%) vs baseline: -1.1%

Memory: ✅ 31.457MB (SLO: <34.000MB -7.5%) vs baseline: +4.9%


recursivecomputation - 8/8

✅ deep

Time: ✅ 309.612ms (SLO: <320.950ms -3.5%) vs baseline: +0.4%

Memory: ✅ 32.696MB (SLO: <34.500MB -5.2%) vs baseline: +4.7%


✅ deep-profiled

Time: ✅ 327.393ms (SLO: <359.150ms -8.8%) vs baseline: -0.5%

Memory: ✅ 37.327MB (SLO: <39.000MB -4.3%) vs baseline: +5.2%


✅ medium

Time: ✅ 7.003ms (SLO: <7.400ms -5.4%) vs baseline: ~same

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +5.0%


✅ shallow

Time: ✅ 0.945ms (SLO: <1.050ms 📉 -10.0%) vs baseline: +0.5%

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.5%


samplingrules - 8/8

✅ average_match

Time: ✅ 137.526µs (SLO: <290.000µs 📉 -52.6%) vs baseline: ~same

Memory: ✅ 31.595MB (SLO: <34.000MB -7.1%) vs baseline: +3.8%


✅ high_match

Time: ✅ 173.495µs (SLO: <480.000µs 📉 -63.9%) vs baseline: -0.5%

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.7%


✅ low_match

Time: ✅ 98.748µs (SLO: <120.000µs 📉 -17.7%) vs baseline: ~same

Memory: ✅ 600.551MB (SLO: <700.000MB 📉 -14.2%) vs baseline: +4.9%


✅ very_low_match

Time: ✅ 2.669ms (SLO: <8.500ms 📉 -68.6%) vs baseline: ~same

Memory: ✅ 67.905MB (SLO: <75.000MB -9.5%) vs baseline: +4.8%


sethttpmeta - 32/32

✅ all-disabled

Time: ✅ 10.665µs (SLO: <20.000µs 📉 -46.7%) vs baseline: +1.8%

Memory: ✅ 32.401MB (SLO: <34.000MB -4.7%) vs baseline: +4.9%


✅ all-enabled

Time: ✅ 40.721µs (SLO: <50.000µs 📉 -18.6%) vs baseline: +2.1%

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +4.9%


✅ collectipvariant_exists

Time: ✅ 40.736µs (SLO: <50.000µs 📉 -18.5%) vs baseline: -0.2%

Memory: ✅ 32.401MB (SLO: <34.000MB -4.7%) vs baseline: +5.0%


✅ no-collectipvariant

Time: ✅ 39.908µs (SLO: <50.000µs 📉 -20.2%) vs baseline: ~same

Memory: ✅ 32.362MB (SLO: <34.000MB -4.8%) vs baseline: +4.7%


✅ no-useragentvariant

Time: ✅ 38.760µs (SLO: <50.000µs 📉 -22.5%) vs baseline: -0.2%

Memory: ✅ 32.322MB (SLO: <34.000MB -4.9%) vs baseline: +4.9%


✅ obfuscation-no-query

Time: ✅ 40.611µs (SLO: <50.000µs 📉 -18.8%) vs baseline: +0.5%

Memory: ✅ 32.362MB (SLO: <34.000MB -4.8%) vs baseline: +4.9%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 75.771µs (SLO: <90.000µs 📉 -15.8%) vs baseline: +0.4%

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +4.0%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 76.247µs (SLO: <90.000µs 📉 -15.3%) vs baseline: +0.2%

Memory: ✅ 32.480MB (SLO: <34.000MB -4.5%) vs baseline: +3.9%


✅ obfuscation-send-querystring-disabled

Time: ✅ 154.174µs (SLO: <170.000µs -9.3%) vs baseline: ~same

Memory: ✅ 32.775MB (SLO: <34.500MB -5.0%) vs baseline: +5.0%


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.187µs (SLO: <160.000µs -7.4%) vs baseline: -0.1%

Memory: ✅ 32.735MB (SLO: <34.500MB -5.1%) vs baseline: +4.7%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 154.734µs (SLO: <170.000µs -9.0%) vs baseline: ~same

Memory: ✅ 32.735MB (SLO: <34.500MB -5.1%) vs baseline: +4.9%


✅ useragentvariant_exists_1

Time: ✅ 39.515µs (SLO: <50.000µs 📉 -21.0%) vs baseline: +0.6%

Memory: ✅ 32.440MB (SLO: <34.000MB -4.6%) vs baseline: +5.2%


✅ useragentvariant_exists_2

Time: ✅ 40.444µs (SLO: <50.000µs 📉 -19.1%) vs baseline: ~same

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +4.6%


✅ useragentvariant_exists_3

Time: ✅ 39.910µs (SLO: <50.000µs 📉 -20.2%) vs baseline: ~same

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +5.0%


✅ useragentvariant_not_exists_1

Time: ✅ 39.723µs (SLO: <50.000µs 📉 -20.6%) vs baseline: +0.8%

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +4.9%


✅ useragentvariant_not_exists_2

Time: ✅ 40.312µs (SLO: <50.000µs 📉 -19.4%) vs baseline: +2.3%

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +5.1%


span - 26/26

✅ add-event

Time: ✅ 19.866ms (SLO: <22.500ms 📉 -11.7%) vs baseline: ~same

Memory: ✅ 48.365MB (SLO: <53.000MB -8.7%) vs baseline: +4.8%


✅ add-metrics

Time: ✅ 89.992ms (SLO: <93.500ms -3.8%) vs baseline: ~same

Memory: ✅ 735.732MB (SLO: <961.000MB 📉 -23.4%) vs baseline: +4.8%


✅ add-tags

Time: ✅ 146.697ms (SLO: <155.000ms -5.4%) vs baseline: -0.4%

Memory: ✅ 735.633MB (SLO: <962.500MB 📉 -23.6%) vs baseline: +4.8%


✅ get-context

Time: ✅ 18.245ms (SLO: <20.500ms 📉 -11.0%) vs baseline: -0.6%

Memory: ✅ 47.251MB (SLO: <53.000MB 📉 -10.8%) vs baseline: +4.8%


✅ is-recording

Time: ✅ 18.594ms (SLO: <20.500ms -9.3%) vs baseline: -0.6%

Memory: ✅ 47.237MB (SLO: <53.000MB 📉 -10.9%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 37.769ms (SLO: <40.000ms -5.6%) vs baseline: +0.9%

Memory: ✅ 41.620MB (SLO: <53.000MB 📉 -21.5%) vs baseline: +4.9%


✅ set-status

Time: ✅ 20.388ms (SLO: <22.000ms -7.3%) vs baseline: +1.5%

Memory: ✅ 47.270MB (SLO: <53.000MB 📉 -10.8%) vs baseline: +5.0%


✅ start

Time: ✅ 18.301ms (SLO: <20.500ms 📉 -10.7%) vs baseline: +0.9%

Memory: ✅ 47.247MB (SLO: <53.000MB 📉 -10.9%) vs baseline: +4.8%


✅ start-finish

Time: ✅ 51.145ms (SLO: <52.500ms -2.6%) vs baseline: +0.9%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +5.0%


✅ start-finish-telemetry

Time: ✅ 52.109ms (SLO: <54.500ms -4.4%) vs baseline: +0.6%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 53.497ms (SLO: <57.000ms -6.1%) vs baseline: -0.3%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +5.0%


✅ start-traceid128

Time: ✅ 18.912ms (SLO: <22.500ms 📉 -15.9%) vs baseline: +3.0%

Memory: ✅ 47.298MB (SLO: <53.000MB 📉 -10.8%) vs baseline: +4.9%


✅ update-name

Time: ✅ 18.792ms (SLO: <22.000ms 📉 -14.6%) vs baseline: -0.2%

Memory: ✅ 47.845MB (SLO: <53.000MB -9.7%) vs baseline: +4.9%


tracer - 6/6

✅ large

Time: ✅ 29.458ms (SLO: <32.950ms 📉 -10.6%) vs baseline: +1.2%

Memory: ✅ 32.676MB (SLO: <34.500MB -5.3%) vs baseline: +4.9%


✅ medium

Time: ✅ 2.879ms (SLO: <3.200ms 📉 -10.0%) vs baseline: +0.2%

Memory: ✅ 31.477MB (SLO: <34.000MB -7.4%) vs baseline: +4.7%


✅ small

Time: ✅ 326.041µs (SLO: <370.000µs 📉 -11.9%) vs baseline: +0.3%

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +5.0%

ℹ️ Scenarios Missing SLO Configuration (9 scenarios)

The following scenarios exist in candidate data but have no SLO thresholds configured:

  • coreapiscenario-core_dispatch_listeners
  • coreapiscenario-core_dispatch_no_listeners
  • coreapiscenario-core_dispatch_with_results_listeners
  • coreapiscenario-core_dispatch_with_results_no_listeners
  • djangosimple-baseline
  • errortrackingdjangosimple-baseline
  • errortrackingflasksqli-baseline
  • flasksimple-baseline
  • flasksqli-baseline

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

changelog/no-changelog A changelog entry is not required for this PR.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants