Skip to content

Conversation

@quinna-h
Copy link
Contributor

@quinna-h quinna-h commented Dec 2, 2025

Description

Quick fix for version checking for django channels, to fix AttributeError when __version__ not found

Testing

Risks

Additional Notes

@github-actions
Copy link
Contributor

github-actions bot commented Dec 2, 2025

CODEOWNERS have been resolved as:

ddtrace/contrib/internal/django/patch.py                                @DataDog/apm-core-python @DataDog/apm-idm-python

@github-actions
Copy link
Contributor

github-actions bot commented Dec 2, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

The average import time from this PR is: 246 ± 3 ms.

The average import time from base is: 249 ± 4 ms.

The import time difference between this PR and base is: -2.3 ± 0.2 ms.

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.652 ms (1.08%)
ddtrace 1.347 ms (0.55%)
ddtrace._logger 0.668 ms (0.27%)
ddtrace.internal.telemetry 0.668 ms (0.27%)
ddtrace.internal.telemetry.writer 0.668 ms (0.27%)
ddtrace.internal.utils.version 0.668 ms (0.27%)
ddtrace.version 0.668 ms (0.27%)
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%)
ddtrace.bootstrap.sitecustomize 1.305 ms (0.53%)
ddtrace.bootstrap.preload 1.305 ms (0.53%)
ddtrace.internal.remoteconfig.client 0.676 ms (0.27%)

@pr-commenter
Copy link

pr-commenter bot commented Dec 2, 2025

Performance SLOs

Comparing candidate add-version-checking-django-channels (ced1023) with baseline main (34ab1fa)

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

✅ ospathbasename_aspect

Time: ✅ 5.209µs (SLO: <10.000µs 📉 -47.9%) vs baseline: 📈 +26.7%

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

Memory: ✅ 40.206MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +5.0%


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +4.7%


✅ ospathnormcase_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.8%


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

Memory: ✅ 40.285MB (SLO: <41.000MB 🟡 -1.7%) vs baseline: +4.8%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.4%


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

Memory: ✅ 40.305MB (SLO: <41.000MB 🟡 -1.7%) vs baseline: +5.1%


✅ ospathsplitext_noaspect

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

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


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.380µs (SLO: <20.000µs 📉 -83.1%) vs baseline: 📈 +14.9%

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


✅ 1-count-metrics-100-times

Time: ✅ 200.405µs (SLO: <220.000µs -8.9%) vs baseline: -1.4%

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 215.800µs (SLO: <230.000µs -6.2%) vs baseline: -0.4%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 135.904µs (SLO: <150.000µs -9.4%) vs baseline: +0.2%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 215.054µs (SLO: <250.000µs 📉 -14.0%) vs baseline: +0.4%

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


✅ 100-count-metrics-100-times

Time: ✅ 20.180ms (SLO: <22.000ms -8.3%) vs baseline: -0.9%

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


✅ 100-distribution-metrics-100-times

Time: ✅ 2.306ms (SLO: <2.300ms +0.3%) vs baseline: +0.4%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.402ms (SLO: <1.550ms -9.5%) vs baseline: -0.2%

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.229ms (SLO: <2.550ms 📉 -12.6%) vs baseline: -0.4%

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


✅ flush-1-metric

Time: ✅ 4.629µs (SLO: <20.000µs 📉 -76.9%) vs baseline: -1.3%

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


✅ flush-100-metrics

Time: ✅ 174.143µs (SLO: <250.000µs 📉 -30.3%) vs baseline: -0.3%

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


✅ flush-1000-metrics

Time: ✅ 2.173ms (SLO: <2.500ms 📉 -13.1%) vs baseline: -0.6%

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.303µs (SLO: <20.000µs 📉 -33.5%) vs baseline: +1.1%

Memory: ✅ 34.760MB (SLO: <35.500MB -2.1%) vs baseline: +4.9%


✅ context_with_data_no_listeners

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

Memory: ✅ 34.682MB (SLO: <35.500MB -2.3%) vs baseline: +4.6%


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

Time: ✅ 24.241µs (SLO: <30.000µs 📉 -19.2%) vs baseline: +0.7%

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


🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 19.558ms (SLO: <22.300ms 📉 -12.3%) vs baseline: -0.2%

Memory: ✅ 67.830MB (SLO: <70.500MB -3.8%) vs baseline: +4.5%


✅ exception-replay-enabled

Time: ✅ 1.361ms (SLO: <1.450ms -6.1%) vs baseline: ~same

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


✅ iast

Time: ✅ 19.599ms (SLO: <22.250ms 📉 -11.9%) vs baseline: +0.3%

Memory: ✅ 67.845MB (SLO: <70.000MB -3.1%) vs baseline: +4.6%


✅ profiler

Time: ✅ 15.483ms (SLO: <16.550ms -6.4%) vs baseline: +0.5%

Memory: ✅ 56.179MB (SLO: <57.500MB -2.3%) vs baseline: +4.7%


✅ resource-renaming

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

Memory: ✅ 67.928MB (SLO: <70.500MB -3.6%) vs baseline: +4.7%


✅ span-code-origin

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

Memory: ✅ 68.076MB (SLO: <71.000MB -4.1%) vs baseline: +4.9%


✅ tracer

Time: ✅ 19.673ms (SLO: <21.750ms -9.5%) vs baseline: +0.6%

Memory: ✅ 67.869MB (SLO: <70.000MB -3.0%) vs baseline: +4.6%


✅ tracer-and-profiler

Time: ✅ 21.244ms (SLO: <23.500ms -9.6%) vs baseline: -0.2%

Memory: ✅ 69.285MB (SLO: <71.000MB -2.4%) vs baseline: +4.8%


✅ tracer-dont-create-db-spans

Time: ✅ 19.658ms (SLO: <21.500ms -8.6%) vs baseline: ~same

Memory: ✅ 67.830MB (SLO: <70.000MB -3.1%) vs baseline: +4.5%


✅ tracer-minimal

Time: ✅ 16.794ms (SLO: <17.500ms -4.0%) vs baseline: ~same

Memory: ✅ 67.830MB (SLO: <70.000MB -3.1%) vs baseline: +4.8%


✅ tracer-native

Time: ✅ 19.498ms (SLO: <21.750ms 📉 -10.4%) vs baseline: ~same

Memory: ✅ 67.810MB (SLO: <72.500MB -6.5%) vs baseline: +4.5%


✅ tracer-no-caches

Time: ✅ 17.637ms (SLO: <19.650ms 📉 -10.2%) vs baseline: +0.3%

Memory: ✅ 67.830MB (SLO: <70.000MB -3.1%) vs baseline: +4.8%


✅ tracer-no-databases

Time: ✅ 19.155ms (SLO: <20.100ms -4.7%) vs baseline: +0.4%

Memory: ✅ 67.830MB (SLO: <70.000MB -3.1%) vs baseline: +4.9%


✅ tracer-no-middleware

Time: ✅ 19.243ms (SLO: <21.500ms 📉 -10.5%) vs baseline: -0.1%

Memory: ✅ 67.787MB (SLO: <70.000MB -3.2%) vs baseline: +4.8%


✅ tracer-no-templates

Time: ✅ 19.680ms (SLO: <22.000ms 📉 -10.5%) vs baseline: +1.8%

Memory: ✅ 67.790MB (SLO: <70.500MB -3.8%) vs baseline: +4.6%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.299ms (SLO: <19.850ms 📉 -17.9%) vs baseline: -0.1%

Memory: ✅ 69.695MB (SLO: <70.000MB 🟡 -0.4%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 16.322ms (SLO: <19.400ms 📉 -15.9%) vs baseline: +0.3%

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


✅ tracer-enabled

Time: ✅ 16.328ms (SLO: <19.450ms 📉 -16.1%) vs baseline: ~same

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


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.376ms (SLO: <4.750ms 📉 -28.9%) vs baseline: -0.2%

Memory: ✅ 55.508MB (SLO: <66.500MB 📉 -16.5%) vs baseline: +4.9%


✅ appsec-post

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

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


✅ appsec-telemetry

Time: ✅ 3.399ms (SLO: <4.750ms 📉 -28.4%) vs baseline: +0.7%

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


✅ debugger

Time: ✅ 1.869ms (SLO: <2.000ms -6.6%) vs baseline: +0.1%

Memory: ✅ 47.899MB (SLO: <49.500MB -3.2%) vs baseline: +4.7%


✅ iast-get

Time: ✅ 1.860ms (SLO: <2.000ms -7.0%) vs baseline: ~same

Memory: ✅ 44.558MB (SLO: <49.000MB -9.1%) vs baseline: +4.7%


✅ profiler

Time: ✅ 1.905ms (SLO: <2.100ms -9.3%) vs baseline: -0.2%

Memory: ✅ 48.823MB (SLO: <50.000MB -2.4%) vs baseline: +4.9%


✅ resource-renaming

Time: ✅ 3.367ms (SLO: <3.650ms -7.7%) vs baseline: -0.2%

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


✅ tracer

Time: ✅ 3.372ms (SLO: <3.650ms -7.6%) vs baseline: ~same

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


✅ tracer-native

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

Memory: ✅ 55.470MB (SLO: <60.000MB -7.6%) vs baseline: +4.9%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.060ms (SLO: <4.200ms 📉 -50.9%) vs baseline: -0.1%

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


✅ iast-enabled

Time: ✅ 2.068ms (SLO: <2.800ms 📉 -26.1%) vs baseline: +0.2%

Memory: ✅ 55.404MB (SLO: <62.500MB 📉 -11.4%) vs baseline: +4.9%


✅ tracer-enabled

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

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.475µs (SLO: <100.000µs 📉 -18.5%) vs baseline: +0.6%

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


✅ b3_headers

Time: ✅ 14.317µs (SLO: <20.000µs 📉 -28.4%) vs baseline: +0.9%

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 64.058µs (SLO: <80.000µs 📉 -19.9%) vs baseline: +0.6%

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 69.512µs (SLO: <80.000µs 📉 -13.1%) vs baseline: +5.2%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

Time: ✅ 22.727µs (SLO: <30.000µs 📉 -24.2%) vs baseline: +1.4%

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.686µs (SLO: <30.000µs -7.7%) vs baseline: -0.5%

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

Time: ✅ 34.800µs (SLO: <40.000µs 📉 -13.0%) vs baseline: -0.3%

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

Memory: ✅ 34.760MB (SLO: <35.500MB -2.1%) vs baseline: +4.6%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 34.721MB (SLO: <35.500MB -2.2%) vs baseline: +4.7%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 34.682MB (SLO: <35.500MB -2.3%) vs baseline: +4.4%


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

Time: ✅ 10.232µs (SLO: <20.000µs 📉 -48.8%) vs baseline: +1.4%

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

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

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


✅ with_all

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

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 33.841µs (SLO: <40.000µs 📉 -15.4%) vs baseline: +6.0%

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +4.5%


✅ re_expand_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.6%


✅ re_findall_aspect

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

Memory: ✅ 40.265MB (SLO: <41.000MB 🟡 -1.8%) vs baseline: +4.9%


✅ re_findall_noaspect

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

Memory: ✅ 40.246MB (SLO: <41.000MB 🟡 -1.8%) vs baseline: +4.1%


✅ re_finditer_aspect

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

Memory: ✅ 40.069MB (SLO: <41.000MB -2.3%) vs baseline: +4.1%


✅ re_finditer_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.8%


✅ re_fullmatch_aspect

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

Memory: ✅ 40.206MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +4.8%


✅ re_fullmatch_noaspect

Time: ✅ 1.307µs (SLO: <10.000µs 📉 -86.9%) vs baseline: -3.1%

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.7%


✅ re_group_aspect

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

Memory: ✅ 40.187MB (SLO: <41.000MB 🟡 -2.0%) vs baseline: +4.3%


✅ re_group_noaspect

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

Memory: ✅ 40.344MB (SLO: <41.000MB 🟡 -1.6%) vs baseline: +5.0%


✅ re_groups_aspect

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

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


✅ re_groups_noaspect

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

Memory: ✅ 40.108MB (SLO: <41.000MB -2.2%) vs baseline: +4.4%


✅ re_match_aspect

Time: ✅ 2.794µs (SLO: <10.000µs 📉 -72.1%) vs baseline: +1.7%

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +5.0%


✅ re_match_noaspect

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

Memory: ✅ 40.187MB (SLO: <41.000MB 🟡 -2.0%) vs baseline: +4.4%


✅ re_search_aspect

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

Memory: ✅ 40.246MB (SLO: <41.000MB 🟡 -1.8%) vs baseline: +4.9%


✅ re_search_noaspect

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

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


✅ re_sub_aspect

Time: ✅ 3.544µs (SLO: <10.000µs 📉 -64.6%) vs baseline: +3.6%

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +4.6%


✅ re_sub_noaspect

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

Memory: ✅ 40.403MB (SLO: <41.000MB 🟡 -1.5%) vs baseline: +5.6%


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +5.0%


🟡 iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 40.226MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +4.8%


✅ rsplit_noaspect

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

Memory: ✅ 40.029MB (SLO: <41.000MB -2.4%) vs baseline: +4.2%


✅ split_aspect

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

Memory: ✅ 40.206MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +5.0%


✅ split_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.3%


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

Memory: ✅ 40.285MB (SLO: <41.000MB 🟡 -1.7%) vs baseline: +5.0%


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 39.660ms (SLO: <47.150ms 📉 -15.9%) vs baseline: -0.2%

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


✅ add-metrics

Time: ✅ 261.364ms (SLO: <344.800ms 📉 -24.2%) vs baseline: ~same

Memory: ✅ 43.686MB (SLO: <47.500MB -8.0%) vs baseline: +4.3%


✅ add-tags

Time: ✅ 316.309ms (SLO: <321.000ms 🟡 -1.5%) vs baseline: -0.6%

Memory: ✅ 43.721MB (SLO: <47.500MB -8.0%) vs baseline: +4.8%


✅ get-context

Time: ✅ 79.411ms (SLO: <92.350ms 📉 -14.0%) vs baseline: -0.5%

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


✅ is-recording

Time: ✅ 37.061ms (SLO: <44.500ms 📉 -16.7%) vs baseline: -0.2%

Memory: ✅ 39.520MB (SLO: <47.500MB 📉 -16.8%) vs baseline: +4.6%


✅ record-exception

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

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


✅ set-status

Time: ✅ 43.689ms (SLO: <50.400ms 📉 -13.3%) vs baseline: +0.3%

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


✅ start

Time: ✅ 37.231ms (SLO: <43.450ms 📉 -14.3%) vs baseline: +2.1%

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


✅ start-finish

Time: ✅ 81.837ms (SLO: <88.000ms -7.0%) vs baseline: -0.2%

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


✅ start-finish-telemetry

Time: ✅ 83.282ms (SLO: <89.000ms -6.4%) vs baseline: -0.3%

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


✅ update-name

Time: ✅ 38.032ms (SLO: <45.150ms 📉 -15.8%) vs baseline: -0.6%

Memory: ✅ 39.739MB (SLO: <47.000MB 📉 -15.4%) vs baseline: +5.3%


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 309.773ms (SLO: <320.950ms -3.5%) vs baseline: +0.2%

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


✅ deep-profiled

Time: ✅ 327.700ms (SLO: <359.150ms -8.8%) vs baseline: -0.2%

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


✅ medium

Time: ✅ 6.993ms (SLO: <7.400ms -5.5%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.947ms (SLO: <1.050ms -9.9%) vs baseline: +1.4%

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


🟡 sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

Time: ✅ 40.904µs (SLO: <50.000µs 📉 -18.2%) vs baseline: +2.2%

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


✅ collectipvariant_exists

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

Memory: ✅ 35.645MB (SLO: <36.000MB 🟡 -1.0%) vs baseline: +4.6%


✅ no-collectipvariant

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

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


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

Time: ✅ 40.484µs (SLO: <50.000µs 📉 -19.0%) vs baseline: +0.1%

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


✅ obfuscation-regular-case-explicit-query

Time: ✅ 76.032µs (SLO: <90.000µs 📉 -15.5%) vs baseline: +0.3%

Memory: ✅ 35.645MB (SLO: <36.500MB -2.3%) vs baseline: +4.7%


✅ obfuscation-regular-case-implicit-query

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

Memory: ✅ 35.665MB (SLO: <36.500MB -2.3%) vs baseline: +4.9%


✅ obfuscation-send-querystring-disabled

Time: ✅ 154.240µs (SLO: <170.000µs -9.3%) vs baseline: -0.1%

Memory: ✅ 35.645MB (SLO: <36.500MB -2.3%) vs baseline: +4.9%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 35.645MB (SLO: <36.500MB -2.3%) vs baseline: +4.7%


✅ obfuscation-worst-case-implicit-query

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

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


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

Memory: ✅ 35.586MB (SLO: <36.000MB 🟡 -1.1%) vs baseline: +4.6%


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.232ms (SLO: <32.950ms 📉 -11.3%) vs baseline: -0.3%

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


✅ medium

Time: ✅ 2.877ms (SLO: <3.200ms 📉 -10.1%) vs baseline: -0.4%

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


✅ small

Time: ✅ 331.615µs (SLO: <370.000µs 📉 -10.4%) vs baseline: +1.7%

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

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

✅ import_many

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

Memory: ✅ 39.544MB (SLO: <41.000MB -3.6%) vs baseline: +5.1%


✅ import_many_cached

Time: ✅ 122.149µs (SLO: <130.000µs -6.0%) vs baseline: +1.2%

Memory: ✅ 39.756MB (SLO: <41.000MB -3.0%) vs baseline: +5.4%


✅ import_many_stdlib

Time: ✅ 0.752ms (SLO: <1.750ms 📉 -57.0%) vs baseline: -0.5%

Memory: ✅ 39.659MB (SLO: <41.000MB -3.3%) vs baseline: +5.0%


⚠️ import_many_stdlib_cached

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

Memory: ✅ 39.498MB (SLO: <41.000MB -3.7%) vs baseline: +4.7%


✅ import_many_unknown

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

Memory: ✅ 39.791MB (SLO: <41.000MB -2.9%) vs baseline: +4.8%


✅ import_many_unknown_cached

Time: ✅ 799.440µs (SLO: <870.000µs -8.1%) vs baseline: +0.6%

Memory: ✅ 39.816MB (SLO: <41.000MB -2.9%) vs baseline: +4.7%


✅ import_one

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

Memory: ✅ 39.615MB (SLO: <41.000MB -3.4%) vs baseline: +4.9%


✅ import_one_cache

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

Memory: ✅ 39.628MB (SLO: <41.000MB -3.3%) vs baseline: +5.5%


✅ import_one_stdlib

Time: ✅ 18.624µs (SLO: <20.000µs -6.9%) vs baseline: -0.6%

Memory: ✅ 39.589MB (SLO: <41.000MB -3.4%) vs baseline: +5.2%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.717MB (SLO: <41.000MB -3.1%) vs baseline: +5.4%


✅ import_one_unknown

Time: ✅ 45.421µs (SLO: <50.000µs -9.2%) vs baseline: +0.9%

Memory: ✅ 39.531MB (SLO: <41.000MB -3.6%) vs baseline: +4.8%


✅ import_one_unknown_cache

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

Memory: ✅ 39.493MB (SLO: <41.000MB -3.7%) vs baseline: +4.8%

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

✅ errortracking-enabled-all

Time: ✅ 2.068ms (SLO: <2.300ms 📉 -10.1%) vs baseline: -0.3%

Memory: ✅ 55.306MB (SLO: <56.500MB -2.1%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 2.073ms (SLO: <2.250ms -7.9%) vs baseline: +0.3%

Memory: ✅ 55.365MB (SLO: <56.500MB -2.0%) vs baseline: +4.9%


✅ tracer-enabled

Time: ✅ 2.071ms (SLO: <2.300ms -9.9%) vs baseline: +0.2%

Memory: ✅ 55.365MB (SLO: <56.500MB -2.0%) vs baseline: +5.0%


iastaspects - 118/118

✅ add_aspect

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

Memory: ✅ 40.257MB (SLO: <41.500MB -3.0%) vs baseline: +5.0%


✅ add_inplace_aspect

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

Memory: ✅ 40.214MB (SLO: <41.500MB -3.1%) vs baseline: +4.3%


✅ add_inplace_noaspect

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

Memory: ✅ 40.030MB (SLO: <41.500MB -3.5%) vs baseline: +4.6%


✅ add_noaspect

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

Memory: ✅ 40.075MB (SLO: <41.500MB -3.4%) vs baseline: +4.4%


✅ bytearray_aspect

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

Memory: ✅ 40.168MB (SLO: <41.500MB -3.2%) vs baseline: +4.8%


✅ bytearray_extend_aspect

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

Memory: ✅ 40.096MB (SLO: <41.500MB -3.4%) vs baseline: +3.6%


✅ bytearray_extend_noaspect

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

Memory: ✅ 40.222MB (SLO: <41.500MB -3.1%) vs baseline: +4.8%


✅ bytearray_noaspect

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

Memory: ✅ 40.150MB (SLO: <41.500MB -3.3%) vs baseline: +5.0%


✅ bytes_aspect

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

Memory: ✅ 40.098MB (SLO: <41.500MB -3.4%) vs baseline: +4.5%


✅ bytes_noaspect

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

Memory: ✅ 40.127MB (SLO: <41.500MB -3.3%) vs baseline: +4.7%


✅ bytesio_aspect

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

Memory: ✅ 40.166MB (SLO: <41.500MB -3.2%) vs baseline: +4.8%


✅ bytesio_noaspect

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

Memory: ✅ 40.260MB (SLO: <41.500MB -3.0%) vs baseline: +5.3%


✅ capitalize_aspect

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

Memory: ✅ 40.310MB (SLO: <41.500MB -2.9%) vs baseline: +5.0%


✅ capitalize_noaspect

Time: ✅ 0.433µs (SLO: <10.000µs 📉 -95.7%) vs baseline: -1.5%

Memory: ✅ 40.250MB (SLO: <41.500MB -3.0%) vs baseline: +5.0%


✅ casefold_aspect

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

Memory: ✅ 40.131MB (SLO: <41.500MB -3.3%) vs baseline: +4.5%


✅ casefold_noaspect

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

Memory: ✅ 40.218MB (SLO: <41.500MB -3.1%) vs baseline: +4.7%


✅ decode_aspect

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

Memory: ✅ 40.189MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ decode_noaspect

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

Memory: ✅ 40.301MB (SLO: <41.500MB -2.9%) vs baseline: +5.2%


✅ encode_aspect

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

Memory: ✅ 40.108MB (SLO: <41.500MB -3.4%) vs baseline: +4.4%


✅ encode_noaspect

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

Memory: ✅ 40.164MB (SLO: <41.500MB -3.2%) vs baseline: +4.5%


✅ format_aspect

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

Memory: ✅ 40.147MB (SLO: <41.500MB -3.3%) vs baseline: +4.6%


✅ format_map_aspect

Time: ✅ 3.548µs (SLO: <10.000µs 📉 -64.5%) vs baseline: -1.5%

Memory: ✅ 40.233MB (SLO: <41.500MB -3.1%) vs baseline: +5.0%


✅ format_map_noaspect

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

Memory: ✅ 40.189MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ format_noaspect

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

Memory: ✅ 40.139MB (SLO: <41.500MB -3.3%) vs baseline: +4.3%


✅ index_aspect

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

Memory: ✅ 40.314MB (SLO: <41.500MB -2.9%) vs baseline: +5.1%


✅ index_noaspect

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

Memory: ✅ 40.202MB (SLO: <41.500MB -3.1%) vs baseline: +4.4%


✅ join_aspect

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

Memory: ✅ 40.238MB (SLO: <41.500MB -3.0%) vs baseline: +4.8%


✅ join_noaspect

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

Memory: ✅ 40.198MB (SLO: <41.500MB -3.1%) vs baseline: +4.7%


✅ ljust_aspect

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

Memory: ✅ 40.250MB (SLO: <41.500MB -3.0%) vs baseline: +4.5%


✅ ljust_noaspect

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

Memory: ✅ 40.200MB (SLO: <41.500MB -3.1%) vs baseline: +4.8%


✅ lower_aspect

Time: ✅ 2.304µs (SLO: <10.000µs 📉 -77.0%) vs baseline: +1.9%

Memory: ✅ 40.188MB (SLO: <41.500MB -3.2%) vs baseline: +4.5%


✅ lower_noaspect

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

Memory: ✅ 40.084MB (SLO: <41.500MB -3.4%) vs baseline: +4.8%


✅ lstrip_aspect

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

Memory: ✅ 40.186MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ lstrip_noaspect

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

Memory: ✅ 40.121MB (SLO: <41.500MB -3.3%) vs baseline: +4.9%


✅ modulo_aspect

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

Memory: ✅ 40.270MB (SLO: <41.500MB -3.0%) vs baseline: +4.8%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 40.177MB (SLO: <41.500MB -3.2%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes

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

Memory: ✅ 40.094MB (SLO: <41.500MB -3.4%) vs baseline: +4.2%


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 40.272MB (SLO: <41.500MB -3.0%) vs baseline: +4.7%


✅ modulo_noaspect

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

Memory: ✅ 40.281MB (SLO: <41.500MB -2.9%) vs baseline: +4.9%


✅ replace_aspect

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

Memory: ✅ 40.152MB (SLO: <41.500MB -3.2%) vs baseline: +3.9%


✅ replace_noaspect

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

Memory: ✅ 40.199MB (SLO: <41.500MB -3.1%) vs baseline: +4.5%


✅ repr_aspect

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

Memory: ✅ 40.316MB (SLO: <41.500MB -2.9%) vs baseline: +5.1%


✅ repr_noaspect

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

Memory: ✅ 40.136MB (SLO: <41.500MB -3.3%) vs baseline: +4.5%


✅ rstrip_aspect

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

Memory: ✅ 40.305MB (SLO: <41.500MB -2.9%) vs baseline: +4.9%


✅ rstrip_noaspect

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

Memory: ✅ 40.299MB (SLO: <41.500MB -2.9%) vs baseline: +5.1%


✅ slice_aspect

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

Memory: ✅ 40.158MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ slice_noaspect

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

Memory: ✅ 40.240MB (SLO: <41.500MB -3.0%) vs baseline: +5.0%


✅ stringio_aspect

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

Memory: ✅ 40.131MB (SLO: <41.500MB -3.3%) vs baseline: +4.6%


✅ stringio_noaspect

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

Memory: ✅ 40.180MB (SLO: <41.500MB -3.2%) vs baseline: +4.6%


✅ strip_aspect

Time: ✅ 2.240µs (SLO: <20.000µs 📉 -88.8%) vs baseline: +0.9%

Memory: ✅ 40.310MB (SLO: <41.500MB -2.9%) vs baseline: +4.7%


✅ strip_noaspect

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

Memory: ✅ 40.197MB (SLO: <41.500MB -3.1%) vs baseline: +4.9%


✅ swapcase_aspect

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

Memory: ✅ 40.174MB (SLO: <41.500MB -3.2%) vs baseline: +4.3%


✅ swapcase_noaspect

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

Memory: ✅ 40.260MB (SLO: <41.500MB -3.0%) vs baseline: +4.9%


✅ title_aspect

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

Memory: ✅ 40.269MB (SLO: <41.500MB -3.0%) vs baseline: +4.5%


✅ title_noaspect

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

Memory: ✅ 40.200MB (SLO: <41.500MB -3.1%) vs baseline: +4.8%


✅ translate_aspect

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

Memory: ✅ 40.170MB (SLO: <41.500MB -3.2%) vs baseline: +4.1%


✅ translate_noaspect

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

Memory: ✅ 40.229MB (SLO: <41.500MB -3.1%) vs baseline: +4.6%


✅ upper_aspect

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

Memory: ✅ 40.211MB (SLO: <41.500MB -3.1%) vs baseline: +4.3%


✅ upper_noaspect

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

Memory: ✅ 40.183MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


iastpropagation - 8/8

✅ no-propagation

Time: ✅ 48.656µs (SLO: <60.000µs 📉 -18.9%) vs baseline: +0.5%

Memory: ✅ 40.029MB (SLO: <42.000MB -4.7%) vs baseline: +4.7%


✅ propagation_enabled

Time: ✅ 174.398µs (SLO: <190.000µs -8.2%) vs baseline: -0.7%

Memory: ✅ 40.088MB (SLO: <42.000MB -4.6%) vs baseline: +4.9%


✅ propagation_enabled_100

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

Memory: ✅ 40.108MB (SLO: <42.000MB -4.5%) vs baseline: +4.9%


✅ propagation_enabled_1000

Time: ✅ 32.358ms (SLO: <34.550ms -6.3%) vs baseline: -0.3%

Memory: ✅ 40.069MB (SLO: <42.000MB -4.6%) vs baseline: +4.8%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.135ms (SLO: <42.000ms -4.4%) vs baseline: -0.4%

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +4.6%


✅ add-link

Time: ✅ 36.253ms (SLO: <38.550ms -6.0%) vs baseline: +0.4%

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +4.4%


✅ add-metrics

Time: ✅ 217.763ms (SLO: <232.000ms -6.1%) vs baseline: -0.3%

Memory: ✅ 37.611MB (SLO: <39.000MB -3.6%) vs baseline: +4.7%


✅ add-tags

Time: ✅ 210.680ms (SLO: <221.600ms -4.9%) vs baseline: +0.8%

Memory: ✅ 37.611MB (SLO: <39.000MB -3.6%) vs baseline: +4.8%


✅ get-context

Time: ✅ 29.022ms (SLO: <31.300ms -7.3%) vs baseline: ~same

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


✅ is-recording

Time: ✅ 29.324ms (SLO: <31.000ms -5.4%) vs baseline: +1.2%

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


✅ record-exception

Time: ✅ 62.773ms (SLO: <65.850ms -4.7%) vs baseline: -0.4%

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


✅ set-status

Time: ✅ 31.772ms (SLO: <34.150ms -7.0%) vs baseline: +0.1%

Memory: ✅ 37.513MB (SLO: <39.000MB -3.8%) vs baseline: +4.2%


✅ start

Time: ✅ 29.521ms (SLO: <30.150ms -2.1%) vs baseline: +2.5%

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +4.5%


✅ start-finish

Time: ✅ 34.162ms (SLO: <35.350ms -3.4%) vs baseline: +0.7%

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


✅ start-finish-telemetry

Time: ✅ 34.020ms (SLO: <35.450ms -4.0%) vs baseline: +0.4%

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +4.7%


✅ update-name

Time: ✅ 31.063ms (SLO: <33.400ms -7.0%) vs baseline: +0.4%

Memory: ✅ 37.611MB (SLO: <39.000MB -3.6%) vs baseline: +4.8%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 342.099ms (SLO: <354.300ms -3.4%) vs baseline: -0.7%

Memory: ✅ 40.319MB (SLO: <41.500MB -2.8%) vs baseline: +4.6%


✅ cache_on

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

Memory: ✅ 39.691MB (SLO: <41.000MB -3.2%) vs baseline: +5.1%


samplingrules - 8/8

✅ average_match

Time: ✅ 137.194µs (SLO: <290.000µs 📉 -52.7%) vs baseline: +0.3%

Memory: ✅ 34.662MB (SLO: <35.500MB -2.4%) vs baseline: +4.5%


✅ high_match

Time: ✅ 174.392µs (SLO: <480.000µs 📉 -63.7%) vs baseline: +0.2%

Memory: ✅ 34.721MB (SLO: <35.500MB -2.2%) vs baseline: +4.9%


✅ low_match

Time: ✅ 98.808µs (SLO: <120.000µs 📉 -17.7%) vs baseline: +0.5%

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


✅ very_low_match

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

Memory: ✅ 71.048MB (SLO: <75.000MB -5.3%) vs baseline: +4.9%


span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 88.303ms (SLO: <93.500ms -5.6%) vs baseline: -0.5%

Memory: ✅ 41.251MB (SLO: <53.000MB 📉 -22.2%) vs baseline: +5.2%


✅ add-tags

Time: ✅ 142.143ms (SLO: <155.000ms -8.3%) vs baseline: -0.7%

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


✅ get-context

Time: ✅ 17.001ms (SLO: <20.500ms 📉 -17.1%) vs baseline: -0.6%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.817ms (SLO: <40.000ms -8.0%) vs baseline: +1.1%

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


✅ set-status

Time: ✅ 18.707ms (SLO: <22.000ms 📉 -15.0%) vs baseline: ~same

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


✅ start

Time: ✅ 17.466ms (SLO: <20.500ms 📉 -14.8%) vs baseline: +3.3%

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


✅ start-finish

Time: ✅ 50.882ms (SLO: <52.500ms -3.1%) vs baseline: -0.1%

Memory: ✅ 34.760MB (SLO: <35.500MB -2.1%) vs baseline: +4.6%


✅ start-finish-telemetry

Time: ✅ 52.424ms (SLO: <54.500ms -3.8%) vs baseline: +0.8%

Memory: ✅ 34.760MB (SLO: <35.500MB -2.1%) vs baseline: +4.6%


✅ start-finish-traceid128

Time: ✅ 53.939ms (SLO: <57.000ms -5.4%) vs baseline: -0.6%

Memory: ✅ 34.721MB (SLO: <35.500MB -2.2%) vs baseline: +4.4%


✅ start-traceid128

Time: ✅ 17.250ms (SLO: <22.500ms 📉 -23.3%) vs baseline: +0.3%

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


✅ update-name

Time: ✅ 17.252ms (SLO: <22.000ms 📉 -21.6%) vs baseline: -0.6%

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

ℹ️ Scenarios Missing SLO Configuration (10 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

@quinna-h quinna-h marked this pull request as ready for review December 2, 2025 22:24
@quinna-h quinna-h requested review from a team as code owners December 2, 2025 22:24
@quinna-h quinna-h requested review from dubloom and juanjux December 2, 2025 22:24
@quinna-h quinna-h added the changelog/no-changelog A changelog entry is not required for this PR. label Dec 2, 2025
Copy link
Contributor

@dubloom dubloom left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We could do parse_version(getattr(channels, "version", "")) but that's a nit and may be less readable

LGTM !

@quinna-h quinna-h merged commit 00fdce8 into main Dec 3, 2025
798 of 800 checks passed
@quinna-h quinna-h deleted the add-version-checking-django-channels branch December 3, 2025 15:58
dd-octo-sts bot pushed a commit that referenced this pull request Dec 3, 2025
## Description

<!-- Provide an overview of the change and motivation for the change -->

Quick fix for version checking for django channels, to fix
`AttributeError` when `__version__` not found

## Testing

<!-- Describe your testing strategy or note what tests are included -->

## Risks

<!-- Note any risks associated with this change, or "None" if no risks
-->

## Additional Notes

<!-- Any other information that would be helpful for reviewers -->

(cherry picked from commit 00fdce8)
quinna-h added a commit that referenced this pull request Dec 3, 2025
## Description

<!-- Provide an overview of the change and motivation for the change -->

Quick fix for version checking for django channels, to fix
`AttributeError` when `__version__` not found

## Testing

<!-- Describe your testing strategy or note what tests are included -->

## Risks

<!-- Note any risks associated with this change, or "None" if no risks
-->

## Additional Notes

<!-- Any other information that would be helpful for reviewers -->

(cherry picked from commit 00fdce8)
quinna-h added a commit that referenced this pull request Dec 3, 2025
Backport 00fdce8 from #15484 to 4.0.

## Description

<!-- Provide an overview of the change and motivation for the change -->

Quick fix for version checking for django channels, to fix
`AttributeError` when `__version__` not found

## Testing

<!-- Describe your testing strategy or note what tests are included -->

## Risks

<!-- Note any risks associated with this change, or "None" if no risks
-->

## Additional Notes

<!-- Any other information that would be helpful for reviewers -->

Co-authored-by: Quinna Halim <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

backport 4.0 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.

3 participants