Skip to content

Conversation

@dd-octo-sts
Copy link
Contributor

@dd-octo-sts dd-octo-sts bot commented Dec 22, 2025

Backport 381404b from #15749 to 4.0.

The urlparse function was imported inside the async function view_iast_ssrf_secure, which caused a race condition in multiprocess mode where:

  • The IAST validator wrapper for urlparse is set up at module startup
  • But importing inside a function can bypass or inconsistently apply the wrapper
  • This caused the secure mark to not be applied reliably, leading to false SSRF vulnerability reports

Flaky tests IDs: DD_1PGYGI DD_ONKXDT DD_U2V880 DD_954GJO DD_O236KS

The urlparse function was imported inside the async function
view_iast_ssrf_secure, which caused a race condition in multiprocess
mode where:
- The IAST validator wrapper for urlparse is set up at module startup
- But importing inside a function can bypass or inconsistently apply the
wrapper
- This caused the secure mark to not be applied reliably, leading to
false SSRF vulnerability reports

Flaky tests IDs: DD_1PGYGI DD_ONKXDT DD_U2V880 DD_954GJO DD_O236KS

(cherry picked from commit 381404b)
Signed-off-by: Alberto Vara <[email protected]>
@dd-octo-sts dd-octo-sts bot requested a review from a team as a code owner December 22, 2025 15:01
@dd-octo-sts dd-octo-sts bot added the changelog/no-changelog A changelog entry is not required for this PR. label Dec 22, 2025
@github-actions
Copy link
Contributor

CODEOWNERS have been resolved as:

ddtrace/appsec/_iast/taint_sinks/_base.py                               @DataDog/asm-python
tests/appsec/integrations/fastapi_tests/app.py                          @DataDog/asm-python

@avara1986 avara1986 force-pushed the backport-15749-to-4.0 branch from abcaadd to 2e18fa2 Compare December 22, 2025 15:02
@avara1986 avara1986 enabled auto-merge (squash) December 22, 2025 15:04
@github-actions
Copy link
Contributor

github-actions bot commented Dec 22, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

The average import time from base is: 244 ± 3 ms.

The import time difference between this PR and base is: -4.6 ± 0.1 ms.

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.363 ms (0.99%)
ddtrace.bootstrap.sitecustomize 1.677 ms (0.70%)
ddtrace.bootstrap.preload 1.677 ms (0.70%)
ddtrace.internal.remoteconfig.client 0.693 ms (0.29%)
ddtrace.internal.core.crashtracking 0.068 ms (0.03%)
ddtrace.internal.settings.profiling 0.040 ms (0.02%)
ddtrace.vendor.psutil 0.040 ms (0.02%)
ddtrace 0.685 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%)

@pr-commenter
Copy link

pr-commenter bot commented Dec 22, 2025

Performance SLOs

Comparing candidate backport-15749-to-4.0 (2e18fa2) with baseline 4.0 (03b5f92)

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

✅ add_aspect

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

Memory: ✅ 37.825MB (SLO: <41.500MB -8.9%) vs baseline: +4.6%


✅ add_inplace_aspect

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

Memory: ✅ 37.925MB (SLO: <41.500MB -8.6%) vs baseline: +5.2%


✅ add_inplace_noaspect

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

Memory: ✅ 37.823MB (SLO: <41.500MB -8.9%) vs baseline: +4.3%


✅ add_noaspect

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

Memory: ✅ 37.843MB (SLO: <41.500MB -8.8%) vs baseline: +4.7%


✅ bytearray_aspect

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

Memory: ✅ 37.960MB (SLO: <41.500MB -8.5%) vs baseline: +5.0%


✅ bytearray_extend_aspect

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

Memory: ✅ 37.932MB (SLO: <41.500MB -8.6%) vs baseline: +5.2%


✅ bytearray_extend_noaspect

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

Memory: ✅ 37.788MB (SLO: <41.500MB -8.9%) vs baseline: +4.6%


✅ bytearray_noaspect

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

Memory: ✅ 37.919MB (SLO: <41.500MB -8.6%) vs baseline: +4.7%


✅ bytes_aspect

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

Memory: ✅ 37.717MB (SLO: <41.500MB -9.1%) vs baseline: +4.1%


✅ bytes_noaspect

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

Memory: ✅ 37.795MB (SLO: <41.500MB -8.9%) vs baseline: +4.8%


✅ bytesio_aspect

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

Memory: ✅ 37.967MB (SLO: <41.500MB -8.5%) vs baseline: +5.1%


✅ bytesio_noaspect

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

Memory: ✅ 37.840MB (SLO: <41.500MB -8.8%) vs baseline: +4.7%


✅ capitalize_aspect

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

Memory: ✅ 38.084MB (SLO: <41.500MB -8.2%) vs baseline: +5.1%


✅ capitalize_noaspect

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

Memory: ✅ 37.896MB (SLO: <41.500MB -8.7%) vs baseline: +5.1%


✅ casefold_aspect

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

Memory: ✅ 37.915MB (SLO: <41.500MB -8.6%) vs baseline: +4.7%


✅ casefold_noaspect

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

Memory: ✅ 37.760MB (SLO: <41.500MB -9.0%) vs baseline: +4.4%


✅ decode_aspect

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

Memory: ✅ 37.926MB (SLO: <41.500MB -8.6%) vs baseline: +5.3%


✅ decode_noaspect

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

Memory: ✅ 37.766MB (SLO: <41.500MB -9.0%) vs baseline: +4.6%


✅ encode_aspect

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

Memory: ✅ 37.850MB (SLO: <41.500MB -8.8%) vs baseline: +5.2%


✅ encode_noaspect

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

Memory: ✅ 37.885MB (SLO: <41.500MB -8.7%) vs baseline: +4.8%


✅ format_aspect

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

Memory: ✅ 37.856MB (SLO: <41.500MB -8.8%) vs baseline: +4.9%


✅ format_map_aspect

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

Memory: ✅ 37.891MB (SLO: <41.500MB -8.7%) vs baseline: +4.8%


✅ format_map_noaspect

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

Memory: ✅ 37.905MB (SLO: <41.500MB -8.7%) vs baseline: +5.1%


✅ format_noaspect

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

Memory: ✅ 37.828MB (SLO: <41.500MB -8.8%) vs baseline: +4.8%


✅ index_aspect

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

Memory: ✅ 37.718MB (SLO: <41.500MB -9.1%) vs baseline: +4.7%


✅ index_noaspect

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

Memory: ✅ 37.731MB (SLO: <41.500MB -9.1%) vs baseline: +4.5%


✅ join_aspect

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

Memory: ✅ 37.687MB (SLO: <41.500MB -9.2%) vs baseline: +3.9%


✅ join_noaspect

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

Memory: ✅ 37.757MB (SLO: <41.500MB -9.0%) vs baseline: +4.1%


✅ ljust_aspect

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

Memory: ✅ 37.883MB (SLO: <41.500MB -8.7%) vs baseline: +5.0%


✅ ljust_noaspect

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

Memory: ✅ 37.779MB (SLO: <41.500MB -9.0%) vs baseline: +4.5%


✅ lower_aspect

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

Memory: ✅ 37.880MB (SLO: <41.500MB -8.7%) vs baseline: +5.1%


✅ lower_noaspect

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

Memory: ✅ 37.785MB (SLO: <41.500MB -9.0%) vs baseline: +4.5%


✅ lstrip_aspect

Time: ✅ 2.504µs (SLO: <20.000µs 📉 -87.5%) vs baseline: 📈 +15.0%

Memory: ✅ 37.823MB (SLO: <41.500MB -8.9%) vs baseline: +4.5%


✅ lstrip_noaspect

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

Memory: ✅ 37.683MB (SLO: <41.500MB -9.2%) vs baseline: +4.5%


✅ modulo_aspect

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

Memory: ✅ 37.921MB (SLO: <41.500MB -8.6%) vs baseline: +5.4%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 37.840MB (SLO: <41.500MB -8.8%) vs baseline: +4.7%


✅ modulo_aspect_for_bytes

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

Memory: ✅ 38.022MB (SLO: <41.500MB -8.4%) vs baseline: +5.6%


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 37.831MB (SLO: <41.500MB -8.8%) vs baseline: +5.0%


✅ modulo_noaspect

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

Memory: ✅ 37.804MB (SLO: <41.500MB -8.9%) vs baseline: +4.4%


✅ replace_aspect

Time: ✅ 5.362µs (SLO: <10.000µs 📉 -46.4%) vs baseline: +9.1%

Memory: ✅ 37.790MB (SLO: <41.500MB -8.9%) vs baseline: +4.7%


✅ replace_noaspect

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

Memory: ✅ 37.759MB (SLO: <41.500MB -9.0%) vs baseline: +4.6%


✅ repr_aspect

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

Memory: ✅ 37.781MB (SLO: <41.500MB -9.0%) vs baseline: +4.6%


✅ repr_noaspect

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

Memory: ✅ 37.821MB (SLO: <41.500MB -8.9%) vs baseline: +5.0%


✅ rstrip_aspect

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

Memory: ✅ 37.959MB (SLO: <41.500MB -8.5%) vs baseline: +4.7%


✅ rstrip_noaspect

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

Memory: ✅ 37.848MB (SLO: <41.500MB -8.8%) vs baseline: +4.5%


✅ slice_aspect

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

Memory: ✅ 37.829MB (SLO: <41.500MB -8.8%) vs baseline: +4.5%


✅ slice_noaspect

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

Memory: ✅ 37.809MB (SLO: <41.500MB -8.9%) vs baseline: +4.7%


✅ stringio_aspect

Time: ✅ 1.788µs (SLO: <10.000µs 📉 -82.1%) vs baseline: +5.8%

Memory: ✅ 37.757MB (SLO: <41.500MB -9.0%) vs baseline: +4.7%


✅ stringio_noaspect

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

Memory: ✅ 37.830MB (SLO: <41.500MB -8.8%) vs baseline: +5.0%


✅ strip_aspect

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

Memory: ✅ 37.960MB (SLO: <41.500MB -8.5%) vs baseline: +5.1%


✅ strip_noaspect

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

Memory: ✅ 37.783MB (SLO: <41.500MB -9.0%) vs baseline: +4.6%


✅ swapcase_aspect

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

Memory: ✅ 37.799MB (SLO: <41.500MB -8.9%) vs baseline: +5.0%


✅ swapcase_noaspect

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

Memory: ✅ 37.847MB (SLO: <41.500MB -8.8%) vs baseline: +4.6%


✅ title_aspect

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

Memory: ✅ 38.012MB (SLO: <41.500MB -8.4%) vs baseline: +5.0%


✅ title_noaspect

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

Memory: ✅ 37.848MB (SLO: <41.500MB -8.8%) vs baseline: +4.5%


✅ translate_aspect

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

Memory: ✅ 37.786MB (SLO: <41.500MB -8.9%) vs baseline: +4.4%


✅ translate_noaspect

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

Memory: ✅ 38.007MB (SLO: <41.500MB -8.4%) vs baseline: +5.0%


✅ upper_aspect

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

Memory: ✅ 37.946MB (SLO: <41.500MB -8.6%) vs baseline: +4.9%


✅ upper_noaspect

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

Memory: ✅ 37.805MB (SLO: <41.500MB -8.9%) vs baseline: +4.8%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 4.299µs (SLO: <10.000µs 📉 -57.0%) vs baseline: +2.5%

Memory: ✅ 37.827MB (SLO: <41.000MB -7.7%) vs baseline: +4.7%


✅ ospathbasename_noaspect

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

Memory: ✅ 37.945MB (SLO: <41.000MB -7.5%) vs baseline: +5.0%


✅ ospathjoin_aspect

Time: ✅ 6.830µs (SLO: <10.000µs 📉 -31.7%) vs baseline: 📈 +14.3%

Memory: ✅ 37.965MB (SLO: <41.000MB -7.4%) vs baseline: +5.1%


✅ ospathjoin_noaspect

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

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +4.8%


✅ ospathnormcase_aspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +4.8%


✅ ospathnormcase_noaspect

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

Memory: ✅ 37.827MB (SLO: <41.000MB -7.7%) vs baseline: +4.6%


✅ ospathsplit_aspect

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

Memory: ✅ 37.808MB (SLO: <41.000MB -7.8%) vs baseline: +4.8%


✅ ospathsplit_noaspect

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

Memory: ✅ 37.847MB (SLO: <41.000MB -7.7%) vs baseline: +4.9%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 37.965MB (SLO: <41.000MB -7.4%) vs baseline: +5.1%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ ospathsplitext_aspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +5.0%


✅ ospathsplitext_noaspect

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

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +4.6%


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.251µs (SLO: <20.000µs 📉 -83.7%) vs baseline: 📈 +11.2%

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +4.8%


✅ 1-count-metrics-100-times

Time: ✅ 199.442µs (SLO: <220.000µs -9.3%) vs baseline: -0.7%

Memory: ✅ 34.485MB (SLO: <35.500MB -2.9%) vs baseline: +4.9%


✅ 1-distribution-metric-1-times

Time: ✅ 3.338µs (SLO: <20.000µs 📉 -83.3%) vs baseline: +1.2%

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +4.9%


✅ 1-distribution-metrics-100-times

Time: ✅ 216.076µs (SLO: <230.000µs -6.1%) vs baseline: -0.8%

Memory: ✅ 34.426MB (SLO: <35.500MB -3.0%) vs baseline: +4.7%


✅ 1-gauge-metric-1-times

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +5.0%


✅ 1-gauge-metrics-100-times

Time: ✅ 136.500µs (SLO: <150.000µs -9.0%) vs baseline: -0.3%

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +4.8%


✅ 1-rate-metric-1-times

Time: ✅ 3.048µs (SLO: <20.000µs 📉 -84.8%) vs baseline: -1.4%

Memory: ✅ 34.426MB (SLO: <35.500MB -3.0%) vs baseline: +4.6%


✅ 1-rate-metrics-100-times

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

Memory: ✅ 34.485MB (SLO: <35.500MB -2.9%) vs baseline: +4.6%


✅ 100-count-metrics-100-times

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +4.7%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.286ms (SLO: <2.300ms 🟡 -0.6%) vs baseline: -0.2%

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +4.9%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.401ms (SLO: <1.550ms -9.6%) vs baseline: -0.1%

Memory: ✅ 34.485MB (SLO: <35.500MB -2.9%) vs baseline: +4.7%


✅ 100-rate-metrics-100-times

Time: ✅ 2.184ms (SLO: <2.550ms 📉 -14.4%) vs baseline: -0.7%

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +4.9%


✅ flush-1-metric

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

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +5.0%


✅ flush-100-metrics

Time: ✅ 175.407µs (SLO: <250.000µs 📉 -29.8%) vs baseline: ~same

Memory: ✅ 34.426MB (SLO: <35.500MB -3.0%) vs baseline: +4.8%


✅ flush-1000-metrics

Time: ✅ 2.116ms (SLO: <2.500ms 📉 -15.4%) vs baseline: -0.2%

Memory: ✅ 35.173MB (SLO: <36.500MB -3.6%) vs baseline: +4.7%

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.276µs (SLO: <20.000µs 📉 -33.6%) vs baseline: -0.2%

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +4.8%


✅ context_with_data_no_listeners

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

Memory: ✅ 34.426MB (SLO: <35.500MB -3.0%) vs baseline: +4.6%


✅ get_item_exists

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +5.2%


✅ get_item_missing

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

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +5.0%


✅ set_item

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

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +5.0%

✅ All Tests Passing (19 suites)
djangosimple - 30/30

✅ appsec

Time: ✅ 19.251ms (SLO: <22.300ms 📉 -13.7%) vs baseline: ~same

Memory: ✅ 67.653MB (SLO: <70.500MB -4.0%) vs baseline: +4.9%


✅ exception-replay-enabled

Time: ✅ 1.343ms (SLO: <1.450ms -7.4%) vs baseline: +0.8%

Memory: ✅ 65.765MB (SLO: <67.500MB -2.6%) vs baseline: +4.8%


✅ iast

Time: ✅ 19.214ms (SLO: <22.250ms 📉 -13.6%) vs baseline: -0.3%

Memory: ✅ 67.535MB (SLO: <70.000MB -3.5%) vs baseline: +4.7%


✅ profiler

Time: ✅ 15.196ms (SLO: <16.550ms -8.2%) vs baseline: -0.1%

Memory: ✅ 55.778MB (SLO: <57.500MB -3.0%) vs baseline: +4.9%


✅ resource-renaming

Time: ✅ 19.236ms (SLO: <21.750ms 📉 -11.6%) vs baseline: -0.5%

Memory: ✅ 67.613MB (SLO: <70.500MB -4.1%) vs baseline: +4.8%


✅ span-code-origin

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

Memory: ✅ 68.946MB (SLO: <71.000MB -2.9%) vs baseline: +3.0%


✅ tracer

Time: ✅ 19.239ms (SLO: <21.750ms 📉 -11.5%) vs baseline: -0.2%

Memory: ✅ 67.535MB (SLO: <70.000MB -3.5%) vs baseline: +4.8%


✅ tracer-and-profiler

Time: ✅ 20.892ms (SLO: <23.500ms 📉 -11.1%) vs baseline: +0.1%

Memory: ✅ 69.186MB (SLO: <71.000MB -2.6%) vs baseline: +5.1%


✅ tracer-dont-create-db-spans

Time: ✅ 19.191ms (SLO: <21.500ms 📉 -10.7%) vs baseline: +0.1%

Memory: ✅ 67.555MB (SLO: <70.000MB -3.5%) vs baseline: +4.7%


✅ tracer-minimal

Time: ✅ 16.638ms (SLO: <17.500ms -4.9%) vs baseline: ~same

Memory: ✅ 67.535MB (SLO: <70.000MB -3.5%) vs baseline: +4.8%


✅ tracer-native

Time: ✅ 19.288ms (SLO: <21.750ms 📉 -11.3%) vs baseline: +0.1%

Memory: ✅ 67.653MB (SLO: <72.500MB -6.7%) vs baseline: +4.9%


✅ tracer-no-caches

Time: ✅ 17.250ms (SLO: <19.650ms 📉 -12.2%) vs baseline: -0.2%

Memory: ✅ 67.574MB (SLO: <70.000MB -3.5%) vs baseline: +4.9%


✅ tracer-no-databases

Time: ✅ 18.735ms (SLO: <20.100ms -6.8%) vs baseline: +0.3%

Memory: ✅ 67.633MB (SLO: <70.000MB -3.4%) vs baseline: +4.8%


✅ tracer-no-middleware

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

Memory: ✅ 67.574MB (SLO: <70.000MB -3.5%) vs baseline: +4.9%


✅ tracer-no-templates

Time: ✅ 19.142ms (SLO: <22.000ms 📉 -13.0%) vs baseline: +0.3%

Memory: ✅ 67.574MB (SLO: <70.500MB -4.2%) vs baseline: +4.9%


errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.346ms (SLO: <19.850ms 📉 -17.7%) vs baseline: ~same

Memory: ✅ 67.653MB (SLO: <70.000MB -3.4%) vs baseline: +4.9%


✅ errortracking-enabled-user

Time: ✅ 16.355ms (SLO: <19.400ms 📉 -15.7%) vs baseline: +0.2%

Memory: ✅ 67.504MB (SLO: <70.000MB -3.6%) vs baseline: +4.7%


✅ tracer-enabled

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

Memory: ✅ 67.180MB (SLO: <70.000MB -4.0%) vs baseline: +4.6%


errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.072ms (SLO: <2.300ms -9.9%) vs baseline: ~same

Memory: ✅ 54.146MB (SLO: <56.500MB -4.2%) vs baseline: +4.4%


✅ errortracking-enabled-user

Time: ✅ 2.074ms (SLO: <2.250ms -7.8%) vs baseline: +0.2%

Memory: ✅ 54.205MB (SLO: <56.500MB -4.1%) vs baseline: +4.5%


✅ tracer-enabled

Time: ✅ 2.081ms (SLO: <2.300ms -9.5%) vs baseline: +0.4%

Memory: ✅ 53.870MB (SLO: <56.500MB -4.7%) vs baseline: +4.5%


flasksimple - 18/18

✅ appsec-get

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

Memory: ✅ 63.746MB (SLO: <66.500MB -4.1%) vs baseline: +4.9%


✅ appsec-post

Time: ✅ 6.614ms (SLO: <6.750ms -2.0%) vs baseline: +0.1%

Memory: ✅ 63.981MB (SLO: <66.500MB -3.8%) vs baseline: +4.8%


✅ appsec-telemetry

Time: ✅ 4.596ms (SLO: <4.750ms -3.2%) vs baseline: ~same

Memory: ✅ 63.802MB (SLO: <66.500MB -4.1%) vs baseline: +5.0%


✅ debugger

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

Memory: ✅ 47.664MB (SLO: <49.500MB -3.7%) vs baseline: +5.0%


✅ iast-get

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

Memory: ✅ 44.578MB (SLO: <49.000MB -9.0%) vs baseline: +4.8%


✅ profiler

Time: ✅ 1.911ms (SLO: <2.100ms -9.0%) vs baseline: ~same

Memory: ✅ 48.351MB (SLO: <50.000MB -3.3%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 3.367ms (SLO: <3.650ms -7.8%) vs baseline: -0.3%

Memory: ✅ 53.958MB (SLO: <56.000MB -3.6%) vs baseline: +4.5%


✅ tracer

Time: ✅ 3.355ms (SLO: <3.650ms -8.1%) vs baseline: -0.2%

Memory: ✅ 53.978MB (SLO: <56.500MB -4.5%) vs baseline: +4.8%


✅ tracer-native

Time: ✅ 3.360ms (SLO: <3.650ms -8.0%) vs baseline: +0.4%

Memory: ✅ 53.958MB (SLO: <60.000MB 📉 -10.1%) vs baseline: +4.8%


flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 3.951ms (SLO: <4.200ms -5.9%) vs baseline: -0.2%

Memory: ✅ 64.094MB (SLO: <66.000MB -2.9%) vs baseline: +4.7%


✅ iast-enabled

Time: ✅ 2.430ms (SLO: <2.800ms 📉 -13.2%) vs baseline: ~same

Memory: ✅ 60.241MB (SLO: <62.500MB -3.6%) vs baseline: +4.7%


✅ tracer-enabled

Time: ✅ 2.061ms (SLO: <2.250ms -8.4%) vs baseline: +0.2%

Memory: ✅ 54.028MB (SLO: <56.500MB -4.4%) vs baseline: +4.7%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 84.219µs (SLO: <100.000µs 📉 -15.8%) vs baseline: +4.7%

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +5.0%


✅ b3_headers

Time: ✅ 14.645µs (SLO: <20.000µs 📉 -26.8%) vs baseline: +3.1%

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +4.7%


✅ b3_single_headers

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +5.0%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 66.665µs (SLO: <80.000µs 📉 -16.7%) vs baseline: +4.6%

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +5.3%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.406µs (SLO: <80.000µs 📉 -17.0%) vs baseline: +0.3%

Memory: ✅ 34.642MB (SLO: <35.500MB -2.4%) vs baseline: +5.2%


✅ empty_headers

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

Memory: ✅ 34.603MB (SLO: <35.500MB -2.5%) vs baseline: +4.7%


✅ full_t_id_datadog_headers

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

Memory: ✅ 34.603MB (SLO: <35.500MB -2.5%) vs baseline: +5.0%


✅ invalid_priority_header

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +5.0%


✅ invalid_span_id_header

Time: ✅ 6.701µs (SLO: <10.000µs 📉 -33.0%) vs baseline: +2.5%

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +4.7%


✅ invalid_tags_header

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

Memory: ✅ 34.603MB (SLO: <35.500MB -2.5%) vs baseline: +4.9%


✅ invalid_trace_id_header

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

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +4.8%


✅ large_header_no_matches

Time: ✅ 27.641µs (SLO: <30.000µs -7.9%) vs baseline: +0.3%

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.9%


✅ large_valid_headers_all

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

Memory: ✅ 34.524MB (SLO: <35.500MB -2.7%) vs baseline: +4.9%


✅ medium_header_no_matches

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +4.8%


✅ medium_valid_headers_all

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.8%


✅ none_propagation_style

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

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +4.7%


✅ tracecontext_headers

Time: ✅ 36.159µs (SLO: <40.000µs -9.6%) vs baseline: +3.9%

Memory: ✅ 34.564MB (SLO: <35.500MB -2.6%) vs baseline: +5.0%


✅ valid_headers_all

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.9%


✅ valid_headers_basic

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

Memory: ✅ 34.623MB (SLO: <35.500MB -2.5%) vs baseline: +4.9%


✅ wsgi_empty_headers

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

Memory: ✅ 34.603MB (SLO: <35.500MB -2.5%) vs baseline: +4.7%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 34.485MB (SLO: <35.500MB -2.9%) vs baseline: +4.5%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 34.642MB (SLO: <35.500MB -2.4%) vs baseline: +5.0%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +4.6%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +4.6%


✅ wsgi_large_header_no_matches

Time: ✅ 28.955µs (SLO: <40.000µs 📉 -27.6%) vs baseline: +0.9%

Memory: ✅ 34.524MB (SLO: <35.500MB -2.7%) vs baseline: +4.6%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.7%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.9%


✅ wsgi_medium_valid_headers_all

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

Memory: ✅ 34.623MB (SLO: <35.500MB -2.5%) vs baseline: +4.9%


✅ wsgi_valid_headers_all

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

Memory: ✅ 34.623MB (SLO: <35.500MB -2.5%) vs baseline: +5.2%


✅ wsgi_valid_headers_basic

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

Memory: ✅ 34.623MB (SLO: <35.500MB -2.5%) vs baseline: +5.0%


httppropagationinject - 16/16

✅ ids_only

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +4.9%


✅ with_all

Time: ✅ 28.195µs (SLO: <40.000µs 📉 -29.5%) vs baseline: +0.9%

Memory: ✅ 34.485MB (SLO: <35.500MB -2.9%) vs baseline: +4.7%


✅ with_dd_origin

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

Memory: ✅ 34.524MB (SLO: <35.500MB -2.7%) vs baseline: +4.9%


✅ with_priority_and_origin

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

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.9%


✅ with_sampling_priority

Time: ✅ 21.489µs (SLO: <30.000µs 📉 -28.4%) vs baseline: +1.5%

Memory: ✅ 34.583MB (SLO: <35.500MB -2.6%) vs baseline: +4.9%


✅ with_tags

Time: ✅ 26.662µs (SLO: <40.000µs 📉 -33.3%) vs baseline: +2.2%

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +4.6%


✅ with_tags_invalid

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +4.9%


✅ with_tags_max_size

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +4.9%


iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 31.588µs (SLO: <40.000µs 📉 -21.0%) vs baseline: -0.2%

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ re_expand_noaspect

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

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +4.8%


✅ re_findall_aspect

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

Memory: ✅ 37.827MB (SLO: <41.000MB -7.7%) vs baseline: +4.7%


✅ re_findall_noaspect

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

Memory: ✅ 37.926MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ re_finditer_aspect

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

Memory: ✅ 37.926MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ re_finditer_noaspect

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

Memory: ✅ 37.847MB (SLO: <41.000MB -7.7%) vs baseline: +4.9%


✅ re_fullmatch_aspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +5.0%


✅ re_fullmatch_noaspect

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

Memory: ✅ 37.847MB (SLO: <41.000MB -7.7%) vs baseline: +4.5%


✅ re_group_aspect

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

Memory: ✅ 37.926MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ re_group_noaspect

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

Memory: ✅ 37.847MB (SLO: <41.000MB -7.7%) vs baseline: +4.7%


✅ re_groups_aspect

Time: ✅ 3.271µs (SLO: <10.000µs 📉 -67.3%) vs baseline: +5.7%

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +5.0%


✅ re_groups_noaspect

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

Memory: ✅ 37.827MB (SLO: <41.000MB -7.7%) vs baseline: +4.7%


✅ re_match_aspect

Time: ✅ 2.835µs (SLO: <10.000µs 📉 -71.7%) vs baseline: +2.1%

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +4.8%


✅ re_match_noaspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +4.9%


✅ re_search_aspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +4.9%


✅ re_search_noaspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +4.8%


✅ re_sub_aspect

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

Memory: ✅ 37.926MB (SLO: <41.000MB -7.5%) vs baseline: +4.9%


✅ re_sub_noaspect

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

Memory: ✅ 37.867MB (SLO: <41.000MB -7.6%) vs baseline: +4.9%


✅ re_subn_aspect

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

Memory: ✅ 37.768MB (SLO: <41.000MB -7.9%) vs baseline: +4.7%


✅ re_subn_noaspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +4.9%


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 37.788MB (SLO: <41.000MB -7.8%) vs baseline: +4.5%


✅ rsplit_noaspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +5.2%


✅ split_aspect

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

Memory: ✅ 37.926MB (SLO: <41.000MB -7.5%) vs baseline: +5.2%


✅ split_noaspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +5.0%


✅ splitlines_aspect

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

Memory: ✅ 37.906MB (SLO: <41.000MB -7.5%) vs baseline: +5.1%


✅ splitlines_noaspect

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

Memory: ✅ 37.886MB (SLO: <41.000MB -7.6%) vs baseline: +5.0%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.732ms (SLO: <42.000ms -3.0%) vs baseline: +1.1%

Memory: ✅ 36.884MB (SLO: <39.000MB -5.4%) vs baseline: +4.8%


✅ add-link

Time: ✅ 36.178ms (SLO: <38.550ms -6.2%) vs baseline: +0.2%

Memory: ✅ 36.943MB (SLO: <39.000MB -5.3%) vs baseline: +5.1%


✅ add-metrics

Time: ✅ 218.763ms (SLO: <232.000ms -5.7%) vs baseline: -0.8%

Memory: ✅ 36.884MB (SLO: <39.000MB -5.4%) vs baseline: +4.6%


✅ add-tags

Time: ✅ 212.526ms (SLO: <221.600ms -4.1%) vs baseline: +0.4%

Memory: ✅ 36.844MB (SLO: <39.000MB -5.5%) vs baseline: +4.8%


✅ get-context

Time: ✅ 29.262ms (SLO: <31.300ms -6.5%) vs baseline: +1.0%

Memory: ✅ 36.943MB (SLO: <39.000MB -5.3%) vs baseline: +5.0%


✅ is-recording

Time: ✅ 29.200ms (SLO: <31.000ms -5.8%) vs baseline: +0.4%

Memory: ✅ 36.923MB (SLO: <39.000MB -5.3%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 64.079ms (SLO: <65.850ms -2.7%) vs baseline: +1.8%

Memory: ✅ 36.805MB (SLO: <39.000MB -5.6%) vs baseline: +4.7%


✅ set-status

Time: ✅ 32.358ms (SLO: <34.150ms -5.2%) vs baseline: +2.2%

Memory: ✅ 36.943MB (SLO: <39.000MB -5.3%) vs baseline: +4.9%


✅ start

Time: ✅ 28.905ms (SLO: <30.150ms -4.1%) vs baseline: ~same

Memory: ✅ 36.923MB (SLO: <39.000MB -5.3%) vs baseline: +5.0%


✅ start-finish

Time: ✅ 33.770ms (SLO: <35.350ms -4.5%) vs baseline: -0.2%

Memory: ✅ 36.844MB (SLO: <39.000MB -5.5%) vs baseline: +4.5%


✅ start-finish-telemetry

Time: ✅ 33.944ms (SLO: <35.450ms -4.2%) vs baseline: +0.7%

Memory: ✅ 36.844MB (SLO: <39.000MB -5.5%) vs baseline: +5.0%


✅ update-name

Time: ✅ 31.556ms (SLO: <33.400ms -5.5%) vs baseline: +2.5%

Memory: ✅ 36.923MB (SLO: <39.000MB -5.3%) vs baseline: +4.9%


otelspan - 22/22

✅ add-event

Time: ✅ 38.482ms (SLO: <47.150ms 📉 -18.4%) vs baseline: -0.4%

Memory: ✅ 38.948MB (SLO: <47.000MB 📉 -17.1%) vs baseline: +4.8%


✅ add-metrics

Time: ✅ 258.238ms (SLO: <344.800ms 📉 -25.1%) vs baseline: +0.3%

Memory: ✅ 43.273MB (SLO: <47.500MB -8.9%) vs baseline: +4.8%


✅ add-tags

Time: ✅ 313.234ms (SLO: <321.000ms -2.4%) vs baseline: ~same

Memory: ✅ 43.255MB (SLO: <47.500MB -8.9%) vs baseline: +4.9%


✅ get-context

Time: ✅ 78.855ms (SLO: <92.350ms 📉 -14.6%) vs baseline: +0.4%

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


✅ is-recording

Time: ✅ 35.915ms (SLO: <44.500ms 📉 -19.3%) vs baseline: -0.1%

Memory: ✅ 38.848MB (SLO: <47.500MB 📉 -18.2%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 56.843ms (SLO: <67.650ms 📉 -16.0%) vs baseline: -0.4%

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


✅ set-status

Time: ✅ 42.572ms (SLO: <50.400ms 📉 -15.5%) vs baseline: +0.6%

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


✅ start

Time: ✅ 35.208ms (SLO: <43.450ms 📉 -19.0%) vs baseline: -0.2%

Memory: ✅ 38.736MB (SLO: <47.000MB 📉 -17.6%) vs baseline: +4.6%


✅ start-finish

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

Memory: ✅ 36.589MB (SLO: <46.500MB 📉 -21.3%) vs baseline: +4.7%


✅ start-finish-telemetry

Time: ✅ 83.721ms (SLO: <89.000ms -5.9%) vs baseline: +0.3%

Memory: ✅ 36.589MB (SLO: <46.500MB 📉 -21.3%) vs baseline: +4.7%


✅ update-name

Time: ✅ 36.727ms (SLO: <45.150ms 📉 -18.7%) vs baseline: ~same

Memory: ✅ 38.846MB (SLO: <47.000MB 📉 -17.3%) vs baseline: +4.8%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 341.693ms (SLO: <354.300ms -3.6%) vs baseline: -0.9%

Memory: ✅ 39.915MB (SLO: <41.500MB -3.8%) vs baseline: +4.0%


✅ cache_on

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

Memory: ✅ 39.798MB (SLO: <41.000MB -2.9%) vs baseline: +4.6%


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 155.899µs (SLO: <170.000µs -8.3%) vs baseline: +0.5%

Memory: ✅ 38.758MB (SLO: <41.000MB -5.5%) vs baseline: +4.8%


✅ import_many_cached

Time: ✅ 121.140µs (SLO: <130.000µs -6.8%) vs baseline: -0.2%

Memory: ✅ 38.744MB (SLO: <41.000MB -5.5%) vs baseline: +4.5%


✅ import_many_stdlib

Time: ✅ 1.655ms (SLO: <1.750ms -5.4%) vs baseline: +1.3%

Memory: ✅ 38.959MB (SLO: <41.000MB -5.0%) vs baseline: +4.7%


✅ import_many_stdlib_cached

Time: ✅ 0.986ms (SLO: <1.100ms 📉 -10.3%) vs baseline: -0.7%

Memory: ✅ 38.963MB (SLO: <41.000MB -5.0%) vs baseline: +4.9%


✅ import_many_unknown

Time: ✅ 830.442µs (SLO: <890.000µs -6.7%) vs baseline: -0.5%

Memory: ✅ 38.874MB (SLO: <41.000MB -5.2%) vs baseline: +5.0%


✅ import_many_unknown_cached

Time: ✅ 786.332µs (SLO: <870.000µs -9.6%) vs baseline: -0.8%

Memory: ✅ 38.999MB (SLO: <41.000MB -4.9%) vs baseline: +5.1%


✅ import_one

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

Memory: ✅ 38.651MB (SLO: <41.000MB -5.7%) vs baseline: +4.5%


✅ import_one_cache

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

Memory: ✅ 38.755MB (SLO: <41.000MB -5.5%) vs baseline: +4.7%


✅ import_one_stdlib

Time: ✅ 18.674µs (SLO: <20.000µs -6.6%) vs baseline: -0.4%

Memory: ✅ 38.870MB (SLO: <41.000MB -5.2%) vs baseline: +5.3%


✅ import_one_stdlib_cache

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

Memory: ✅ 38.810MB (SLO: <41.000MB -5.3%) vs baseline: +5.4%


✅ import_one_unknown

Time: ✅ 45.235µs (SLO: <50.000µs -9.5%) vs baseline: +0.1%

Memory: ✅ 38.744MB (SLO: <41.000MB -5.5%) vs baseline: +5.1%


✅ import_one_unknown_cache

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

Memory: ✅ 38.804MB (SLO: <41.000MB -5.4%) vs baseline: +5.1%


ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +5.1%


✅ high_rate_limit

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

Memory: ✅ 34.387MB (SLO: <35.500MB -3.1%) vs baseline: +4.7%


✅ long_window

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

Memory: ✅ 34.465MB (SLO: <35.500MB -2.9%) vs baseline: +5.0%


✅ low_rate_limit

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

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +5.0%


✅ no_rate_limit

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

Memory: ✅ 34.524MB (SLO: <35.500MB -2.7%) vs baseline: +5.2%


✅ short_window

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

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +5.0%


recursivecomputation - 8/8

✅ deep

Time: ✅ 308.860ms (SLO: <320.950ms -3.8%) vs baseline: ~same

Memory: ✅ 35.212MB (SLO: <36.500MB -3.5%) vs baseline: +5.0%


✅ deep-profiled

Time: ✅ 327.565ms (SLO: <359.150ms -8.8%) vs baseline: -0.3%

Memory: ✅ 39.322MB (SLO: <40.500MB -2.9%) vs baseline: +4.9%


✅ medium

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

Memory: ✅ 34.387MB (SLO: <35.500MB -3.1%) vs baseline: +4.5%


✅ shallow

Time: ✅ 0.934ms (SLO: <1.050ms 📉 -11.0%) vs baseline: -0.2%

Memory: ✅ 34.544MB (SLO: <35.500MB -2.7%) vs baseline: +5.4%


samplingrules - 8/8

✅ average_match

Time: ✅ 136.288µs (SLO: <290.000µs 📉 -53.0%) vs baseline: -0.7%

Memory: ✅ 34.505MB (SLO: <35.500MB -2.8%) vs baseline: +5.2%


✅ high_match

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

Memory: ✅ 34.406MB (SLO: <35.500MB -3.1%) vs baseline: +4.6%


✅ low_match

Time: ✅ 98.943µs (SLO: <120.000µs 📉 -17.5%) vs baseline: +0.7%

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


✅ very_low_match

Time: ✅ 2.656ms (SLO: <8.500ms 📉 -68.8%) vs baseline: -0.1%

Memory: ✅ 70.362MB (SLO: <75.000MB -6.2%) vs baseline: +4.8%


sethttpmeta - 32/32

✅ all-disabled

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.9%


✅ all-enabled

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +5.0%


✅ collectipvariant_exists

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.7%


✅ no-collectipvariant

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.9%


✅ no-useragentvariant

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.7%


✅ obfuscation-no-query

Time: ✅ 40.342µs (SLO: <50.000µs 📉 -19.3%) vs baseline: -0.8%

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +5.0%


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 34.918MB (SLO: <36.500MB -4.3%) vs baseline: +5.0%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 75.865µs (SLO: <90.000µs 📉 -15.7%) vs baseline: -0.3%

Memory: ✅ 34.937MB (SLO: <36.500MB -4.3%) vs baseline: +4.7%


✅ obfuscation-send-querystring-disabled

Time: ✅ 153.920µs (SLO: <170.000µs -9.5%) vs baseline: +0.2%

Memory: ✅ 34.918MB (SLO: <36.500MB -4.3%) vs baseline: +4.8%


✅ obfuscation-worst-case-explicit-query

Time: ✅ 147.953µs (SLO: <160.000µs -7.5%) vs baseline: -0.3%

Memory: ✅ 34.918MB (SLO: <36.500MB -4.3%) vs baseline: +4.9%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 153.971µs (SLO: <170.000µs -9.4%) vs baseline: -0.3%

Memory: ✅ 34.996MB (SLO: <36.500MB -4.1%) vs baseline: +5.0%


✅ useragentvariant_exists_1

Time: ✅ 39.229µs (SLO: <50.000µs 📉 -21.5%) vs baseline: -0.9%

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.9%


✅ useragentvariant_exists_2

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

Memory: ✅ 34.937MB (SLO: <36.000MB -3.0%) vs baseline: +4.8%


✅ useragentvariant_exists_3

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

Memory: ✅ 34.859MB (SLO: <36.000MB -3.2%) vs baseline: +4.6%


✅ useragentvariant_not_exists_1

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

Memory: ✅ 34.957MB (SLO: <36.000MB -2.9%) vs baseline: +5.0%


✅ useragentvariant_not_exists_2

Time: ✅ 39.113µs (SLO: <50.000µs 📉 -21.8%) vs baseline: -0.9%

Memory: ✅ 34.898MB (SLO: <36.000MB -3.1%) vs baseline: +4.7%


span - 26/26

✅ add-event

Time: ✅ 17.128ms (SLO: <22.500ms 📉 -23.9%) vs baseline: -0.7%

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


✅ add-metrics

Time: ✅ 86.520ms (SLO: <93.500ms -7.5%) vs baseline: -0.2%

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


✅ add-tags

Time: ✅ 140.385ms (SLO: <155.000ms -9.4%) vs baseline: +0.9%

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


✅ get-context

Time: ✅ 15.918ms (SLO: <20.500ms 📉 -22.4%) vs baseline: -0.6%

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


✅ is-recording

Time: ✅ 16.530ms (SLO: <20.500ms 📉 -19.4%) vs baseline: +2.5%

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


✅ record-exception

Time: ✅ 36.022ms (SLO: <40.000ms -9.9%) vs baseline: +2.4%

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


✅ set-status

Time: ✅ 17.888ms (SLO: <22.000ms 📉 -18.7%) vs baseline: +0.7%

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


✅ start

Time: ✅ 16.024ms (SLO: <20.500ms 📉 -21.8%) vs baseline: +1.1%

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


✅ start-finish

Time: ✅ 50.762ms (SLO: <52.500ms -3.3%) vs baseline: +0.1%

Memory: ✅ 34.367MB (SLO: <35.500MB -3.2%) vs baseline: +4.6%


✅ start-finish-telemetry

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

Memory: ✅ 34.387MB (SLO: <35.500MB -3.1%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 54.276ms (SLO: <57.000ms -4.8%) vs baseline: +0.4%

Memory: ✅ 34.406MB (SLO: <35.500MB -3.1%) vs baseline: +4.7%


✅ start-traceid128

Time: ✅ 16.355ms (SLO: <22.500ms 📉 -27.3%) vs baseline: +0.8%

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


✅ update-name

Time: ✅ 16.263ms (SLO: <22.000ms 📉 -26.1%) vs baseline: -0.6%

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


tracer - 6/6

✅ large

Time: ✅ 29.190ms (SLO: <32.950ms 📉 -11.4%) vs baseline: +0.4%

Memory: ✅ 35.271MB (SLO: <36.500MB -3.4%) vs baseline: +5.2%


✅ medium

Time: ✅ 2.901ms (SLO: <3.200ms -9.3%) vs baseline: +0.8%

Memory: ✅ 34.033MB (SLO: <35.500MB -4.1%) vs baseline: +4.9%


✅ small

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

Memory: ✅ 34.013MB (SLO: <35.500MB -4.2%) vs baseline: +4.7%

ℹ️ 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

@avara1986 avara1986 merged commit bbb3aa0 into 4.0 Dec 22, 2025
537 checks passed
@avara1986 avara1986 deleted the backport-15749-to-4.0 branch December 22, 2025 16:10
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.

2 participants