Skip to content

Conversation

@KowalskiThomas
Copy link
Contributor

Description

Testing

Risks

Additional Notes

@github-actions
Copy link
Contributor

github-actions bot commented Dec 22, 2025

CODEOWNERS have been resolved as:

ddtrace/internal/datadog/profiling/stack/echion/test/CMakeLists.txt     @DataDog/profiling-python
ddtrace/internal/datadog/profiling/stack/echion/test/test_stack_frame.cpp  @DataDog/profiling-python
ddtrace/internal/datadog/profiling/stack/echion/test/valgrind.supp      @DataDog/profiling-python
ddtrace/internal/datadog/profiling/stack/CMakeLists.txt                 @DataDog/profiling-python
ddtrace/internal/datadog/profiling/stack/echion/echion/stacks.h         @DataDog/profiling-python

@KowalskiThomas KowalskiThomas added changelog/no-changelog A changelog entry is not required for this PR. Profiling Continous Profling labels Dec 22, 2025
@KowalskiThomas KowalskiThomas force-pushed the kowalski/refactor-profiling-use-custom-std-deque-like-data-structure branch from c87face to 64dd39d Compare December 22, 2025 09:22
@pr-commenter
Copy link

pr-commenter bot commented Dec 22, 2025

Performance SLOs

Comparing candidate kowalski/refactor-profiling-use-custom-std-deque-like-data-structure (1ff46f5) with baseline main (3841a70)

📈 Performance Regressions (3 suites)
📈 iastaspects - 118/118

✅ add_aspect

Time: ✅ 17.785µs (SLO: <20.000µs 📉 -11.1%) vs baseline: 📈 +20.1%

Memory: ✅ 42.959MB (SLO: <43.250MB 🟡 -0.7%) vs baseline: +4.9%


✅ add_inplace_aspect

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

Memory: ✅ 43.037MB (SLO: <43.250MB 🟡 -0.5%) vs baseline: +5.0%


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

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


✅ bytearray_aspect

Time: ✅ 17.959µs (SLO: <30.000µs 📉 -40.1%) vs baseline: -0.4%

Memory: ✅ 43.037MB (SLO: <43.500MB 🟡 -1.1%) vs baseline: +5.0%


✅ bytearray_extend_aspect

Time: ✅ 24.021µs (SLO: <30.000µs 📉 -19.9%) vs baseline: +1.0%

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


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

Memory: ✅ 42.998MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ bytes_aspect

Time: ✅ 16.711µs (SLO: <20.000µs 📉 -16.4%) vs baseline: +0.6%

Memory: ✅ 42.900MB (SLO: <43.500MB 🟡 -1.4%) vs baseline: +4.7%


✅ bytes_noaspect

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

Memory: ✅ 42.920MB (SLO: <43.500MB 🟡 -1.3%) vs baseline: +4.7%


✅ bytesio_aspect

Time: ✅ 55.539µs (SLO: <70.000µs 📉 -20.7%) vs baseline: +0.4%

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ bytesio_noaspect

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

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


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

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


✅ casefold_aspect

Time: ✅ 14.462µs (SLO: <20.000µs 📉 -27.7%) vs baseline: -0.6%

Memory: ✅ 43.057MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +5.0%


✅ casefold_noaspect

Time: ✅ 3.124µs (SLO: <10.000µs 📉 -68.8%) vs baseline: -1.9%

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


✅ decode_aspect

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

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


✅ decode_noaspect

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

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


✅ encode_aspect

Time: ✅ 18.125µs (SLO: <30.000µs 📉 -39.6%) vs baseline: 📈 +22.4%

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ encode_noaspect

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

Memory: ✅ 43.037MB (SLO: <43.500MB 🟡 -1.1%) vs baseline: +5.0%


✅ format_aspect

Time: ✅ 171.004µs (SLO: <200.000µs 📉 -14.5%) vs baseline: -0.1%

Memory: ✅ 43.155MB (SLO: <43.250MB 🟡 -0.2%) vs baseline: +4.9%


✅ format_map_aspect

Time: ✅ 190.865µs (SLO: <200.000µs -4.6%) vs baseline: ~same

Memory: ✅ 43.077MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +4.8%


✅ format_map_noaspect

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

Memory: ✅ 42.979MB (SLO: <43.250MB 🟡 -0.6%) vs baseline: +4.8%


✅ format_noaspect

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

Memory: ✅ 43.057MB (SLO: <43.250MB 🟡 -0.4%) vs baseline: +5.0%


✅ index_aspect

Time: ✅ 15.291µs (SLO: <20.000µs 📉 -23.5%) vs baseline: +0.3%

Memory: ✅ 42.900MB (SLO: <43.250MB 🟡 -0.8%) vs baseline: +4.7%


✅ index_noaspect

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

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


✅ join_aspect

Time: ✅ 17.059µs (SLO: <20.000µs 📉 -14.7%) vs baseline: -0.5%

Memory: ✅ 43.077MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +5.1%


✅ join_noaspect

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

Memory: ✅ 43.037MB (SLO: <43.250MB 🟡 -0.5%) vs baseline: +5.0%


✅ ljust_aspect

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

Memory: ✅ 43.018MB (SLO: <43.250MB 🟡 -0.5%) vs baseline: +4.9%


✅ ljust_noaspect

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

Memory: ✅ 42.939MB (SLO: <43.250MB 🟡 -0.7%) vs baseline: +4.7%


✅ lower_aspect

Time: ✅ 17.861µs (SLO: <30.000µs 📉 -40.5%) vs baseline: +0.4%

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


✅ lower_noaspect

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

Memory: ✅ 43.037MB (SLO: <43.250MB 🟡 -0.5%) vs baseline: +5.0%


✅ lstrip_aspect

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

Memory: ✅ 42.939MB (SLO: <43.250MB 🟡 -0.7%) vs baseline: +4.7%


✅ lstrip_noaspect

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

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ modulo_aspect

Time: ✅ 166.176µs (SLO: <200.000µs 📉 -16.9%) vs baseline: ~same

Memory: ✅ 43.116MB (SLO: <43.500MB 🟡 -0.9%) vs baseline: +4.7%


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 174.386µs (SLO: <200.000µs 📉 -12.8%) vs baseline: ~same

Memory: ✅ 43.077MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +4.7%


✅ modulo_aspect_for_bytes

Time: ✅ 168.636µs (SLO: <200.000µs 📉 -15.7%) vs baseline: ~same

Memory: ✅ 43.136MB (SLO: <43.500MB 🟡 -0.8%) vs baseline: +5.0%


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 172.404µs (SLO: <200.000µs 📉 -13.8%) vs baseline: +0.3%

Memory: ✅ 43.175MB (SLO: <43.500MB 🟡 -0.7%) vs baseline: +5.0%


✅ modulo_noaspect

Time: ✅ 3.759µs (SLO: <10.000µs 📉 -62.4%) vs baseline: +2.3%

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


✅ replace_aspect

Time: ✅ 212.265µs (SLO: <300.000µs 📉 -29.2%) vs baseline: ~same

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


✅ replace_noaspect

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

Memory: ✅ 43.037MB (SLO: <43.500MB 🟡 -1.1%) vs baseline: +5.0%


✅ repr_aspect

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

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


✅ repr_noaspect

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

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +5.0%


✅ rstrip_aspect

Time: ✅ 19.013µs (SLO: <30.000µs 📉 -36.6%) vs baseline: ~same

Memory: ✅ 43.057MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +5.0%


✅ rstrip_noaspect

Time: ✅ 2.021µs (SLO: <10.000µs 📉 -79.8%) vs baseline: +4.5%

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ slice_aspect

Time: ✅ 15.831µs (SLO: <20.000µs 📉 -20.8%) vs baseline: -0.2%

Memory: ✅ 42.979MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +4.5%


✅ slice_noaspect

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

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


✅ stringio_aspect

Time: ✅ 53.689µs (SLO: <80.000µs 📉 -32.9%) vs baseline: -0.6%

Memory: ✅ 43.057MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +5.1%


✅ stringio_noaspect

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

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


✅ strip_aspect

Time: ✅ 17.605µs (SLO: <20.000µs 📉 -12.0%) vs baseline: -0.3%

Memory: ✅ 43.037MB (SLO: <43.500MB 🟡 -1.1%) vs baseline: +5.1%


✅ strip_noaspect

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

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


✅ swapcase_aspect

Time: ✅ 18.499µs (SLO: <30.000µs 📉 -38.3%) vs baseline: ~same

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


✅ swapcase_noaspect

Time: ✅ 2.790µs (SLO: <10.000µs 📉 -72.1%) vs baseline: -1.3%

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


✅ title_aspect

Time: ✅ 22.053µs (SLO: <30.000µs 📉 -26.5%) vs baseline: 📈 +20.8%

Memory: ✅ 42.939MB (SLO: <43.000MB 🟡 -0.1%) vs baseline: +4.8%


✅ title_noaspect

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

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


✅ translate_aspect

Time: ✅ 20.546µs (SLO: <30.000µs 📉 -31.5%) vs baseline: +0.5%

Memory: ✅ 42.998MB (SLO: <43.500MB 🟡 -1.2%) vs baseline: +5.0%


✅ translate_noaspect

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

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


✅ upper_aspect

Time: ✅ 17.947µs (SLO: <30.000µs 📉 -40.2%) vs baseline: +0.2%

Memory: ✅ 43.037MB (SLO: <43.500MB 🟡 -1.1%) vs baseline: +5.0%


✅ upper_noaspect

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

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


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 5.185µs (SLO: <10.000µs 📉 -48.2%) vs baseline: 📈 +22.3%

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ ospathbasename_noaspect

Time: ✅ 4.274µs (SLO: <10.000µs 📉 -57.3%) vs baseline: -1.3%

Memory: ✅ 41.484MB (SLO: <43.500MB -4.6%) vs baseline: +5.0%


✅ ospathjoin_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.6%


✅ ospathjoin_noaspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ ospathnormcase_aspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ ospathnormcase_noaspect

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

Memory: ✅ 41.347MB (SLO: <43.500MB -5.0%) vs baseline: +4.7%


✅ ospathsplit_aspect

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

Memory: ✅ 41.484MB (SLO: <43.500MB -4.6%) vs baseline: +5.1%


✅ ospathsplit_noaspect

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

Memory: ✅ 41.484MB (SLO: <43.500MB -4.6%) vs baseline: +5.1%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.1%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.6%


✅ ospathsplitext_aspect

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

Memory: ✅ 41.543MB (SLO: <43.500MB -4.5%) vs baseline: +5.3%


✅ ospathsplitext_noaspect

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

Memory: ✅ 41.504MB (SLO: <43.500MB -4.6%) vs baseline: +5.1%


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

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

Memory: ✅ 34.741MB (SLO: <35.500MB -2.1%) vs baseline: +4.4%


✅ 1-count-metrics-100-times

Time: ✅ 198.316µs (SLO: <220.000µs -9.9%) vs baseline: -0.6%

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


✅ 1-distribution-metric-1-times

Time: ✅ 3.291µs (SLO: <20.000µs 📉 -83.5%) vs baseline: -1.1%

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.6%


✅ 1-distribution-metrics-100-times

Time: ✅ 214.102µs (SLO: <230.000µs -6.9%) vs baseline: -0.2%

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.9%


✅ 1-gauge-metric-1-times

Time: ✅ 2.160µs (SLO: <20.000µs 📉 -89.2%) vs baseline: -1.5%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.0%


✅ 1-gauge-metrics-100-times

Time: ✅ 136.100µs (SLO: <150.000µs -9.3%) vs baseline: -0.2%

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.5%


✅ 1-rate-metric-1-times

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

Memory: ✅ 34.918MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +5.2%


✅ 1-rate-metrics-100-times

Time: ✅ 211.632µs (SLO: <250.000µs 📉 -15.3%) vs baseline: -0.9%

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.4%


✅ 100-count-metrics-100-times

Time: ✅ 19.966ms (SLO: <22.000ms -9.2%) vs baseline: -0.1%

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +5.2%


✅ 100-distribution-metrics-100-times

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

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.9%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.406ms (SLO: <1.550ms -9.3%) vs baseline: +0.4%

Memory: ✅ 34.918MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.7%


✅ 100-rate-metrics-100-times

Time: ✅ 2.224ms (SLO: <2.550ms 📉 -12.8%) vs baseline: +2.0%

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.6%


✅ flush-1-metric

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

Memory: ✅ 35.232MB (SLO: <35.500MB 🟡 -0.8%) vs baseline: +4.9%


✅ flush-100-metrics

Time: ✅ 174.662µs (SLO: <250.000µs 📉 -30.1%) vs baseline: +0.2%

Memory: ✅ 35.173MB (SLO: <35.500MB 🟡 -0.9%) vs baseline: +4.6%


✅ flush-1000-metrics

Time: ✅ 2.178ms (SLO: <2.500ms 📉 -12.9%) vs baseline: +0.4%

Memory: ✅ 36.117MB (SLO: <36.500MB 🟡 -1.0%) vs baseline: +5.0%

🟡 Near SLO Breach (14 suites)
🟡 coreapiscenario - 10/10 (1 unstable)

⚠️ context_with_data_listeners

Time: ⚠️ 13.278µs (SLO: <20.000µs 📉 -33.6%) vs baseline: ~same

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.5%


✅ context_with_data_no_listeners

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

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +5.4%


✅ get_item_exists

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

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


✅ get_item_missing

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

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.9%


✅ set_item

Time: ✅ 24.551µs (SLO: <30.000µs 📉 -18.2%) vs baseline: +2.7%

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.6%


🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 19.645ms (SLO: <22.300ms 📉 -11.9%) vs baseline: +0.6%

Memory: ✅ 68.192MB (SLO: <70.500MB -3.3%) vs baseline: +4.6%


✅ exception-replay-enabled

Time: ✅ 1.360ms (SLO: <1.450ms -6.2%) vs baseline: -0.2%

Memory: ✅ 66.456MB (SLO: <67.500MB 🟡 -1.5%) vs baseline: +5.0%


✅ iast

Time: ✅ 19.574ms (SLO: <22.250ms 📉 -12.0%) vs baseline: ~same

Memory: ✅ 68.267MB (SLO: <70.000MB -2.5%) vs baseline: +4.7%


✅ profiler

Time: ✅ 14.752ms (SLO: <16.550ms 📉 -10.9%) vs baseline: -0.3%

Memory: ✅ 56.161MB (SLO: <57.500MB -2.3%) vs baseline: +5.1%


✅ resource-renaming

Time: ✅ 19.468ms (SLO: <21.750ms 📉 -10.5%) vs baseline: -0.2%

Memory: ✅ 68.226MB (SLO: <70.500MB -3.2%) vs baseline: +4.7%


✅ span-code-origin

Time: ✅ 19.934ms (SLO: <28.200ms 📉 -29.3%) vs baseline: +0.8%

Memory: ✅ 68.333MB (SLO: <71.000MB -3.8%) vs baseline: +4.9%


✅ tracer

Time: ✅ 19.597ms (SLO: <21.750ms -9.9%) vs baseline: -0.4%

Memory: ✅ 68.212MB (SLO: <70.000MB -2.6%) vs baseline: +4.6%


✅ tracer-and-profiler

Time: ✅ 20.904ms (SLO: <23.500ms 📉 -11.0%) vs baseline: ~same

Memory: ✅ 69.673MB (SLO: <71.000MB 🟡 -1.9%) vs baseline: +5.1%


✅ tracer-dont-create-db-spans

Time: ✅ 19.660ms (SLO: <21.500ms -8.6%) vs baseline: -0.1%

Memory: ✅ 68.248MB (SLO: <70.000MB -2.5%) vs baseline: +4.7%


✅ tracer-minimal

Time: ✅ 16.715ms (SLO: <17.500ms -4.5%) vs baseline: -0.4%

Memory: ✅ 68.278MB (SLO: <70.000MB -2.5%) vs baseline: +5.2%


✅ tracer-native

Time: ✅ 19.529ms (SLO: <21.750ms 📉 -10.2%) vs baseline: +0.2%

Memory: ✅ 68.222MB (SLO: <72.500MB -5.9%) vs baseline: +4.6%


✅ tracer-no-caches

Time: ✅ 17.621ms (SLO: <19.650ms 📉 -10.3%) vs baseline: ~same

Memory: ✅ 68.212MB (SLO: <70.000MB -2.6%) vs baseline: +4.8%


✅ tracer-no-databases

Time: ✅ 19.127ms (SLO: <20.100ms -4.8%) vs baseline: +0.2%

Memory: ✅ 68.134MB (SLO: <70.000MB -2.7%) vs baseline: +5.0%


✅ tracer-no-middleware

Time: ✅ 19.339ms (SLO: <21.500ms 📉 -10.1%) vs baseline: +0.2%

Memory: ✅ 68.189MB (SLO: <70.000MB -2.6%) vs baseline: +4.7%


✅ tracer-no-templates

Time: ✅ 19.566ms (SLO: <22.000ms 📉 -11.1%) vs baseline: +1.5%

Memory: ✅ 68.207MB (SLO: <70.500MB -3.3%) vs baseline: +4.5%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.281ms (SLO: <19.850ms 📉 -18.0%) vs baseline: -0.5%

Memory: ✅ 69.855MB (SLO: <70.000MB 🟡 -0.2%) vs baseline: +4.8%


✅ errortracking-enabled-user

Time: ✅ 16.295ms (SLO: <19.400ms 📉 -16.0%) vs baseline: ~same

Memory: ✅ 69.914MB (SLO: <70.000MB 🟡 -0.1%) vs baseline: +4.9%


✅ tracer-enabled

Time: ✅ 16.236ms (SLO: <19.450ms 📉 -16.5%) vs baseline: -0.3%

Memory: ✅ 69.874MB (SLO: <70.000MB 🟡 -0.2%) vs baseline: +4.9%


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.066ms (SLO: <2.300ms 📉 -10.2%) vs baseline: -0.1%

Memory: ✅ 55.915MB (SLO: <56.500MB 🟡 -1.0%) vs baseline: +5.0%


✅ errortracking-enabled-user

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

Memory: ✅ 55.935MB (SLO: <56.500MB 🟡 -1.0%) vs baseline: +5.0%


✅ tracer-enabled

Time: ✅ 2.066ms (SLO: <2.300ms 📉 -10.2%) vs baseline: ~same

Memory: ✅ 55.935MB (SLO: <56.500MB 🟡 -1.0%) vs baseline: +4.8%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.395ms (SLO: <4.750ms 📉 -28.5%) vs baseline: +0.6%

Memory: ✅ 55.959MB (SLO: <66.500MB 📉 -15.9%) vs baseline: +5.0%


✅ appsec-post

Time: ✅ 2.855ms (SLO: <6.750ms 📉 -57.7%) vs baseline: ~same

Memory: ✅ 55.961MB (SLO: <66.500MB 📉 -15.8%) vs baseline: +5.0%


✅ appsec-telemetry

Time: ✅ 3.389ms (SLO: <4.750ms 📉 -28.7%) vs baseline: +0.5%

Memory: ✅ 56.032MB (SLO: <66.500MB 📉 -15.7%) vs baseline: +5.1%


✅ debugger

Time: ✅ 1.868ms (SLO: <2.000ms -6.6%) vs baseline: ~same

Memory: ✅ 47.857MB (SLO: <49.500MB -3.3%) vs baseline: +5.0%


✅ iast-get

Time: ✅ 1.861ms (SLO: <2.000ms -7.0%) vs baseline: +0.3%

Memory: ✅ 44.905MB (SLO: <49.000MB -8.4%) vs baseline: +4.9%


✅ profiler

Time: ✅ 1.857ms (SLO: <2.100ms 📉 -11.6%) vs baseline: -0.2%

Memory: ✅ 48.761MB (SLO: <50.000MB -2.5%) vs baseline: +5.0%


✅ resource-renaming

Time: ✅ 3.354ms (SLO: <3.650ms -8.1%) vs baseline: -0.1%

Memory: ✅ 55.836MB (SLO: <56.000MB 🟡 -0.3%) vs baseline: +4.8%


✅ tracer

Time: ✅ 3.371ms (SLO: <3.650ms -7.7%) vs baseline: ~same

Memory: ✅ 56.013MB (SLO: <56.500MB 🟡 -0.9%) vs baseline: +5.1%


✅ tracer-native

Time: ✅ 3.364ms (SLO: <3.650ms -7.8%) vs baseline: -0.1%

Memory: ✅ 55.861MB (SLO: <60.000MB -6.9%) vs baseline: +4.9%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.058ms (SLO: <4.200ms 📉 -51.0%) vs baseline: -0.4%

Memory: ✅ 55.837MB (SLO: <66.000MB 📉 -15.4%) vs baseline: +4.8%


✅ iast-enabled

Time: ✅ 2.067ms (SLO: <2.800ms 📉 -26.2%) vs baseline: -0.2%

Memory: ✅ 55.856MB (SLO: <62.500MB 📉 -10.6%) vs baseline: +4.7%


✅ tracer-enabled

Time: ✅ 2.059ms (SLO: <2.250ms -8.5%) vs baseline: -0.1%

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 82.037µs (SLO: <100.000µs 📉 -18.0%) vs baseline: -0.2%

Memory: ✅ 35.075MB (SLO: <35.500MB 🟡 -1.2%) vs baseline: +4.1%


✅ b3_headers

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

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


✅ b3_single_headers

Time: ✅ 13.455µs (SLO: <20.000µs 📉 -32.7%) vs baseline: -0.6%

Memory: ✅ 34.918MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.5%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 63.912µs (SLO: <80.000µs 📉 -20.1%) vs baseline: -0.3%

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +3.6%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 69.916µs (SLO: <80.000µs 📉 -12.6%) vs baseline: +4.9%

Memory: ✅ 35.016MB (SLO: <35.500MB 🟡 -1.4%) vs baseline: +4.1%


✅ empty_headers

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

Memory: ✅ 35.036MB (SLO: <35.500MB 🟡 -1.3%) vs baseline: +5.3%


✅ full_t_id_datadog_headers

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

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.7%


✅ invalid_priority_header

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.4%


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.6%


✅ invalid_trace_id_header

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

Memory: ✅ 34.977MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.7%


✅ large_header_no_matches

Time: ✅ 27.627µs (SLO: <30.000µs -7.9%) vs baseline: -0.2%

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.6%


✅ large_valid_headers_all

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

Memory: ✅ 34.977MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.7%


✅ medium_header_no_matches

Time: ✅ 9.846µs (SLO: <20.000µs 📉 -50.8%) vs baseline: +0.2%

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.6%


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

Memory: ✅ 34.918MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.6%


✅ tracecontext_headers

Time: ✅ 34.678µs (SLO: <40.000µs 📉 -13.3%) vs baseline: -0.4%

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.3%


✅ valid_headers_all

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

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.6%


✅ valid_headers_basic

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

Memory: ✅ 34.996MB (SLO: <35.500MB 🟡 -1.4%) vs baseline: +5.1%


✅ wsgi_empty_headers

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

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.7%


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 34.918MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.8%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +4.6%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +4.4%


✅ wsgi_large_header_no_matches

Time: ✅ 28.717µs (SLO: <40.000µs 📉 -28.2%) vs baseline: -0.4%

Memory: ✅ 35.134MB (SLO: <35.500MB 🟡 -1.0%) vs baseline: +4.3%


✅ wsgi_large_valid_headers_all

Time: ✅ 29.759µs (SLO: <40.000µs 📉 -25.6%) vs baseline: -0.8%

Memory: ✅ 35.271MB (SLO: <35.500MB 🟡 -0.6%) vs baseline: +4.8%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 35.016MB (SLO: <35.500MB 🟡 -1.4%) vs baseline: +5.2%


✅ wsgi_medium_valid_headers_all

Time: ✅ 11.583µs (SLO: <20.000µs 📉 -42.1%) vs baseline: -0.2%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.4%


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +4.6%


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 22.106µs (SLO: <30.000µs 📉 -26.3%) vs baseline: +6.1%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.0%


✅ with_all

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.5%


✅ with_dd_origin

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +4.6%


✅ with_priority_and_origin

Time: ✅ 24.046µs (SLO: <40.000µs 📉 -39.9%) vs baseline: +0.2%

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


✅ with_sampling_priority

Time: ✅ 20.949µs (SLO: <30.000µs 📉 -30.2%) vs baseline: +0.8%

Memory: ✅ 34.937MB (SLO: <35.500MB 🟡 -1.6%) vs baseline: +5.1%


✅ with_tags

Time: ✅ 26.031µs (SLO: <40.000µs 📉 -34.9%) vs baseline: +0.8%

Memory: ✅ 34.977MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.9%


✅ with_tags_invalid

Time: ✅ 27.525µs (SLO: <40.000µs 📉 -31.2%) vs baseline: +0.2%

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.0%


✅ with_tags_max_size

Time: ✅ 26.431µs (SLO: <40.000µs 📉 -33.9%) vs baseline: +0.2%

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.6%


🟡 otelspan - 22/22

✅ add-event

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

Memory: ✅ 39.467MB (SLO: <47.000MB 📉 -16.0%) vs baseline: +4.4%


✅ add-metrics

Time: ✅ 260.205ms (SLO: <344.800ms 📉 -24.5%) vs baseline: -0.2%

Memory: ✅ 43.868MB (SLO: <47.500MB -7.6%) vs baseline: +5.0%


✅ add-tags

Time: ✅ 316.747ms (SLO: <321.000ms 🟡 -1.3%) vs baseline: ~same

Memory: ✅ 43.877MB (SLO: <47.500MB -7.6%) vs baseline: +5.1%


✅ get-context

Time: ✅ 80.446ms (SLO: <92.350ms 📉 -12.9%) vs baseline: +0.1%

Memory: ✅ 39.836MB (SLO: <46.500MB 📉 -14.3%) vs baseline: +4.3%


✅ is-recording

Time: ✅ 38.046ms (SLO: <44.500ms 📉 -14.5%) vs baseline: +0.1%

Memory: ✅ 39.456MB (SLO: <47.500MB 📉 -16.9%) vs baseline: +4.4%


✅ record-exception

Time: ✅ 59.190ms (SLO: <67.650ms 📉 -12.5%) vs baseline: +0.4%

Memory: ✅ 40.052MB (SLO: <47.000MB 📉 -14.8%) vs baseline: +5.0%


✅ set-status

Time: ✅ 44.622ms (SLO: <50.400ms 📉 -11.5%) vs baseline: +1.1%

Memory: ✅ 39.450MB (SLO: <47.000MB 📉 -16.1%) vs baseline: +5.0%


✅ start

Time: ✅ 38.145ms (SLO: <43.450ms 📉 -12.2%) vs baseline: +2.2%

Memory: ✅ 39.407MB (SLO: <47.000MB 📉 -16.2%) vs baseline: +4.5%


✅ start-finish

Time: ✅ 82.610ms (SLO: <88.000ms -6.1%) vs baseline: +0.4%

Memory: ✅ 37.415MB (SLO: <46.500MB 📉 -19.5%) vs baseline: +5.0%


✅ start-finish-telemetry

Time: ✅ 84.149ms (SLO: <89.000ms -5.5%) vs baseline: -0.3%

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


✅ update-name

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

Memory: ✅ 39.592MB (SLO: <47.000MB 📉 -15.8%) vs baseline: +4.5%


🟡 ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 35.154MB (SLO: <35.500MB 🟡 -1.0%) vs baseline: +5.0%


✅ high_rate_limit

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

Memory: ✅ 35.154MB (SLO: <35.500MB 🟡 -1.0%) vs baseline: +4.9%


✅ long_window

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

Memory: ✅ 35.075MB (SLO: <35.500MB 🟡 -1.2%) vs baseline: +4.4%


✅ low_rate_limit

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

Memory: ✅ 35.075MB (SLO: <35.500MB 🟡 -1.2%) vs baseline: +4.7%


✅ no_rate_limit

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

Memory: ✅ 35.173MB (SLO: <35.500MB 🟡 -0.9%) vs baseline: +4.9%


✅ short_window

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

Memory: ✅ 35.193MB (SLO: <35.500MB 🟡 -0.9%) vs baseline: +5.0%


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 308.335ms (SLO: <320.950ms -3.9%) vs baseline: -0.2%

Memory: ✅ 35.940MB (SLO: <36.500MB 🟡 -1.5%) vs baseline: +4.7%


✅ deep-profiled

Time: ✅ 314.829ms (SLO: <359.150ms 📉 -12.3%) vs baseline: -0.2%

Memory: ✅ 39.734MB (SLO: <40.500MB 🟡 -1.9%) vs baseline: +4.6%


✅ medium

Time: ✅ 6.983ms (SLO: <7.400ms -5.6%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.946ms (SLO: <1.050ms -9.9%) vs baseline: +0.9%

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +5.1%


🟡 sethttpmeta - 32/32

✅ all-disabled

Time: ✅ 10.499µs (SLO: <20.000µs 📉 -47.5%) vs baseline: -0.9%

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


✅ all-enabled

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

Memory: ✅ 35.271MB (SLO: <36.000MB -2.0%) vs baseline: +4.9%


✅ collectipvariant_exists

Time: ✅ 40.965µs (SLO: <50.000µs 📉 -18.1%) vs baseline: -0.5%

Memory: ✅ 35.527MB (SLO: <36.000MB 🟡 -1.3%) vs baseline: +5.6%


✅ no-collectipvariant

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

Memory: ✅ 35.232MB (SLO: <36.000MB -2.1%) vs baseline: +4.1%


✅ no-useragentvariant

Time: ✅ 39.074µs (SLO: <50.000µs 📉 -21.9%) vs baseline: +0.4%

Memory: ✅ 35.409MB (SLO: <36.000MB 🟡 -1.6%) vs baseline: +5.3%


✅ obfuscation-no-query

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

Memory: ✅ 35.429MB (SLO: <36.000MB 🟡 -1.6%) vs baseline: +5.3%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 76.061µs (SLO: <90.000µs 📉 -15.5%) vs baseline: -0.2%

Memory: ✅ 35.625MB (SLO: <36.500MB -2.4%) vs baseline: +4.7%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 76.600µs (SLO: <90.000µs 📉 -14.9%) vs baseline: ~same

Memory: ✅ 35.743MB (SLO: <36.500MB -2.1%) vs baseline: +4.9%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 35.783MB (SLO: <36.500MB 🟡 -2.0%) vs baseline: +5.0%


✅ obfuscation-worst-case-explicit-query

Time: ✅ 149.121µs (SLO: <160.000µs -6.8%) vs baseline: ~same

Memory: ✅ 35.724MB (SLO: <36.500MB -2.1%) vs baseline: +4.8%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 155.041µs (SLO: <170.000µs -8.8%) vs baseline: -0.2%

Memory: ✅ 35.724MB (SLO: <36.500MB -2.1%) vs baseline: +5.0%


✅ useragentvariant_exists_1

Time: ✅ 39.780µs (SLO: <50.000µs 📉 -20.4%) vs baseline: -0.1%

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


✅ useragentvariant_exists_2

Time: ✅ 40.810µs (SLO: <50.000µs 📉 -18.4%) vs baseline: -0.6%

Memory: ✅ 35.488MB (SLO: <36.000MB 🟡 -1.4%) vs baseline: +5.1%


✅ useragentvariant_exists_3

Time: ✅ 40.167µs (SLO: <50.000µs 📉 -19.7%) vs baseline: -0.4%

Memory: ✅ 35.389MB (SLO: <36.000MB 🟡 -1.7%) vs baseline: +4.9%


✅ useragentvariant_not_exists_1

Time: ✅ 39.542µs (SLO: <50.000µs 📉 -20.9%) vs baseline: -0.4%

Memory: ✅ 35.468MB (SLO: <36.000MB 🟡 -1.5%) vs baseline: +5.0%


✅ useragentvariant_not_exists_2

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

Memory: ✅ 35.311MB (SLO: <36.000MB 🟡 -1.9%) vs baseline: +4.4%


🟡 span - 26/26

✅ add-event

Time: ✅ 18.177ms (SLO: <22.500ms 📉 -19.2%) vs baseline: -0.7%

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


✅ add-metrics

Time: ✅ 88.497ms (SLO: <93.500ms -5.4%) vs baseline: +0.2%

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


✅ add-tags

Time: ✅ 140.884ms (SLO: <155.000ms -9.1%) vs baseline: -1.8%

Memory: ✅ 41.034MB (SLO: <53.000MB 📉 -22.6%) vs baseline: +4.5%


✅ get-context

Time: ✅ 17.047ms (SLO: <20.500ms 📉 -16.8%) vs baseline: +0.8%

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


✅ is-recording

Time: ✅ 17.253ms (SLO: <20.500ms 📉 -15.8%) vs baseline: +0.1%

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


✅ record-exception

Time: ✅ 36.662ms (SLO: <40.000ms -8.3%) vs baseline: +0.4%

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


✅ set-status

Time: ✅ 18.780ms (SLO: <22.000ms 📉 -14.6%) vs baseline: +1.3%

Memory: ✅ 36.758MB (SLO: <53.000MB 📉 -30.6%) vs baseline: +5.1%


✅ start

Time: ✅ 17.417ms (SLO: <20.500ms 📉 -15.0%) vs baseline: +2.9%

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


✅ start-finish

Time: ✅ 50.893ms (SLO: <52.500ms -3.1%) vs baseline: -0.2%

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


✅ start-finish-telemetry

Time: ✅ 52.182ms (SLO: <54.500ms -4.3%) vs baseline: ~same

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.6%


✅ start-finish-traceid128

Time: ✅ 54.115ms (SLO: <57.000ms -5.1%) vs baseline: +0.5%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.2%


✅ start-traceid128

Time: ✅ 17.307ms (SLO: <22.500ms 📉 -23.1%) vs baseline: +0.1%

Memory: ✅ 36.766MB (SLO: <53.000MB 📉 -30.6%) vs baseline: +4.6%


✅ update-name

Time: ✅ 17.266ms (SLO: <22.000ms 📉 -21.5%) vs baseline: -0.2%

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.057ms (SLO: <32.950ms 📉 -11.8%) vs baseline: -1.0%

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


✅ medium

Time: ✅ 2.878ms (SLO: <3.200ms 📉 -10.1%) vs baseline: -0.7%

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.4%


✅ small

Time: ✅ 332.385µs (SLO: <370.000µs 📉 -10.2%) vs baseline: +2.0%

Memory: ✅ 34.996MB (SLO: <35.500MB 🟡 -1.4%) vs baseline: +5.3%

⚠️ Unstable Tests (1 suite)
⚠️ packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 154.774µs (SLO: <170.000µs -9.0%) vs baseline: +0.4%

Memory: ✅ 39.575MB (SLO: <43.000MB -8.0%) vs baseline: +4.5%


✅ import_many_cached

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

Memory: ✅ 40.083MB (SLO: <43.000MB -6.8%) vs baseline: +5.8%


✅ import_many_stdlib

Time: ✅ 0.760ms (SLO: <1.750ms 📉 -56.6%) vs baseline: +0.3%

Memory: ✅ 39.569MB (SLO: <43.000MB -8.0%) vs baseline: +4.2%


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.172ms (SLO: <1.100ms 📉 -84.4%) vs baseline: -0.7%

Memory: ✅ 39.803MB (SLO: <43.000MB -7.4%) vs baseline: +5.5%


✅ import_many_unknown

Time: ✅ 833.826µs (SLO: <890.000µs -6.3%) vs baseline: -0.2%

Memory: ✅ 39.828MB (SLO: <43.000MB -7.4%) vs baseline: +4.7%


✅ import_many_unknown_cached

Time: ✅ 793.976µs (SLO: <870.000µs -8.7%) vs baseline: +0.3%

Memory: ✅ 40.184MB (SLO: <43.000MB -6.5%) vs baseline: +5.4%


✅ import_one

Time: ✅ 19.843µs (SLO: <30.000µs 📉 -33.9%) vs baseline: +0.5%

Memory: ✅ 39.723MB (SLO: <43.000MB -7.6%) vs baseline: +5.4%


✅ import_one_cache

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

Memory: ✅ 39.482MB (SLO: <43.000MB -8.2%) vs baseline: +4.2%


✅ import_one_stdlib

Time: ✅ 18.762µs (SLO: <20.000µs -6.2%) vs baseline: +0.3%

Memory: ✅ 39.621MB (SLO: <43.000MB -7.9%) vs baseline: +4.4%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.340MB (SLO: <43.000MB -8.5%) vs baseline: +3.2%


✅ import_one_unknown

Time: ✅ 45.638µs (SLO: <50.000µs -8.7%) vs baseline: +0.4%

Memory: ✅ 40.005MB (SLO: <43.000MB -7.0%) vs baseline: +5.1%


✅ import_one_unknown_cache

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

Memory: ✅ 39.439MB (SLO: <43.000MB -8.3%) vs baseline: +3.6%

✅ All Tests Passing (6 suites)
iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 37.051µs (SLO: <40.000µs -7.4%) vs baseline: +5.5%

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ re_expand_noaspect

Time: ✅ 34.966µs (SLO: <40.000µs 📉 -12.6%) vs baseline: -0.8%

Memory: ✅ 41.307MB (SLO: <43.500MB -5.0%) vs baseline: +4.4%


✅ re_findall_aspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +4.9%


✅ re_findall_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +5.1%


✅ re_finditer_aspect

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

Memory: ✅ 41.347MB (SLO: <43.500MB -5.0%) vs baseline: +4.8%


✅ re_finditer_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ re_fullmatch_aspect

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

Memory: ✅ 41.504MB (SLO: <43.500MB -4.6%) vs baseline: +5.2%


✅ re_fullmatch_noaspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.7%


✅ re_group_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ re_group_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ re_groups_aspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.9%


✅ re_groups_noaspect

Time: ✅ 4.942µs (SLO: <10.000µs 📉 -50.6%) vs baseline: -1.6%

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ re_match_aspect

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

Memory: ✅ 41.366MB (SLO: <43.500MB -4.9%) vs baseline: +4.9%


✅ re_match_noaspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.1%


✅ re_search_aspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.9%


✅ re_search_noaspect

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

Memory: ✅ 41.366MB (SLO: <43.500MB -4.9%) vs baseline: +4.9%


✅ re_sub_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.7%


✅ re_sub_noaspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.9%


✅ re_subn_aspect

Time: ✅ 3.949µs (SLO: <10.000µs 📉 -60.5%) vs baseline: +5.1%

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ re_subn_noaspect

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

Memory: ✅ 41.524MB (SLO: <43.500MB -4.5%) vs baseline: +5.0%


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 41.347MB (SLO: <43.500MB -5.0%) vs baseline: +4.8%


✅ rsplit_noaspect

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

Memory: ✅ 41.307MB (SLO: <43.500MB -5.0%) vs baseline: +4.6%


✅ split_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ split_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ splitlines_aspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.8%


✅ splitlines_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.9%


iastpropagation - 8/8

✅ no-propagation

Time: ✅ 49.210µs (SLO: <60.000µs 📉 -18.0%) vs baseline: +0.7%

Memory: ✅ 38.299MB (SLO: <42.000MB -8.8%) vs baseline: +4.0%


✅ propagation_enabled

Time: ✅ 137.698µs (SLO: <190.000µs 📉 -27.5%) vs baseline: +0.5%

Memory: ✅ 38.358MB (SLO: <42.000MB -8.7%) vs baseline: +4.9%


✅ propagation_enabled_100

Time: ✅ 1.586ms (SLO: <2.300ms 📉 -31.0%) vs baseline: +0.5%

Memory: ✅ 38.398MB (SLO: <42.000MB -8.6%) vs baseline: +5.1%


✅ propagation_enabled_1000

Time: ✅ 29.459ms (SLO: <34.550ms 📉 -14.7%) vs baseline: +0.4%

Memory: ✅ 38.280MB (SLO: <42.000MB -8.9%) vs baseline: +4.6%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.644ms (SLO: <42.000ms -3.2%) vs baseline: +0.3%

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


✅ add-link

Time: ✅ 36.299ms (SLO: <38.550ms -5.8%) vs baseline: +0.2%

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


✅ add-metrics

Time: ✅ 222.805ms (SLO: <232.000ms -4.0%) vs baseline: +2.4%

Memory: ✅ 37.729MB (SLO: <39.000MB -3.3%) vs baseline: +5.1%


✅ add-tags

Time: ✅ 212.173ms (SLO: <221.600ms -4.3%) vs baseline: -0.7%

Memory: ✅ 37.690MB (SLO: <39.000MB -3.4%) vs baseline: +5.0%


✅ get-context

Time: ✅ 29.295ms (SLO: <31.300ms -6.4%) vs baseline: +0.6%

Memory: ✅ 37.670MB (SLO: <39.000MB -3.4%) vs baseline: +4.8%


✅ is-recording

Time: ✅ 29.515ms (SLO: <31.000ms -4.8%) vs baseline: +1.4%

Memory: ✅ 37.650MB (SLO: <39.000MB -3.5%) vs baseline: +4.8%


✅ record-exception

Time: ✅ 63.141ms (SLO: <65.850ms -4.1%) vs baseline: -0.2%

Memory: ✅ 37.650MB (SLO: <39.000MB -3.5%) vs baseline: +4.6%


✅ set-status

Time: ✅ 32.092ms (SLO: <34.150ms -6.0%) vs baseline: +0.1%

Memory: ✅ 37.709MB (SLO: <39.000MB -3.3%) vs baseline: +5.1%


✅ start

Time: ✅ 29.304ms (SLO: <30.150ms -2.8%) vs baseline: +1.5%

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


✅ start-finish

Time: ✅ 34.063ms (SLO: <35.350ms -3.6%) vs baseline: +0.3%

Memory: ✅ 37.709MB (SLO: <39.000MB -3.3%) vs baseline: +4.7%


✅ start-finish-telemetry

Time: ✅ 34.015ms (SLO: <35.450ms -4.0%) vs baseline: ~same

Memory: ✅ 37.729MB (SLO: <39.000MB -3.3%) vs baseline: +4.8%


✅ update-name

Time: ✅ 31.066ms (SLO: <33.400ms -7.0%) vs baseline: -0.3%

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 343.443ms (SLO: <354.300ms -3.1%) vs baseline: -0.8%

Memory: ✅ 40.869MB (SLO: <43.500MB -6.0%) vs baseline: +5.8%


✅ cache_on

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

Memory: ✅ 39.725MB (SLO: <43.000MB -7.6%) vs baseline: +3.9%


samplingrules - 8/8

✅ average_match

Time: ✅ 136.582µs (SLO: <290.000µs 📉 -52.9%) vs baseline: -0.8%

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.8%


✅ high_match

Time: ✅ 172.059µs (SLO: <480.000µs 📉 -64.2%) vs baseline: -1.1%

Memory: ✅ 34.741MB (SLO: <35.500MB -2.1%) vs baseline: +4.4%


✅ low_match

Time: ✅ 98.657µs (SLO: <120.000µs 📉 -17.8%) vs baseline: -0.6%

Memory: ✅ 603.641MB (SLO: <700.000MB 📉 -13.8%) vs baseline: +4.8%


✅ very_low_match

Time: ✅ 2.652ms (SLO: <8.500ms 📉 -68.8%) vs baseline: -0.3%

Memory: ✅ 71.092MB (SLO: <75.000MB -5.2%) vs baseline: +4.7%

ℹ️ Scenarios Missing SLO Configuration (26 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
  • sethttpmeta-obfuscation-disabled
  • startup-baseline
  • startup-baseline_django
  • startup-baseline_flask
  • startup-ddtrace_run
  • startup-ddtrace_run_appsec
  • startup-ddtrace_run_profiling
  • startup-ddtrace_run_runtime_metrics
  • startup-ddtrace_run_send_span
  • startup-ddtrace_run_telemetry_disabled
  • startup-ddtrace_run_telemetry_enabled
  • startup-import_ddtrace
  • startup-import_ddtrace_auto
  • startup-import_ddtrace_auto_django
  • startup-import_ddtrace_auto_flask
  • startup-import_ddtrace_django
  • startup-import_ddtrace_flask

@KowalskiThomas KowalskiThomas force-pushed the kowalski/refactor-profiling-use-custom-std-deque-like-data-structure branch 3 times, most recently from ef99394 to 782e2d7 Compare December 22, 2025 10:31
@KowalskiThomas KowalskiThomas force-pushed the kowalski/refactor-profiling-use-custom-std-deque-like-data-structure branch from 782e2d7 to 5acbd98 Compare December 22, 2025 10:34
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. Profiling Continous Profling

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants