Skip to content

chore(aap): enforce typing in _common_module_patches#17168

Draft
florentinl wants to merge 5 commits intomainfrom
florentin.labelle/no-untyped-def-common-module-patches
Draft

chore(aap): enforce typing in _common_module_patches#17168
florentinl wants to merge 5 commits intomainfrom
florentin.labelle/no-untyped-def-common-module-patches

Conversation

@florentinl
Copy link
Copy Markdown
Contributor

Summary

  • Add typed signatures to all functions in _common_module_patches.py and remove the mypy disallow_untyped_defs = false exception
  • Defer stdlib imports (http.client, urllib.request, pathlib, types) behind TYPE_CHECKING to avoid loading them at module import time — this module can load via remote config even for non-HTTP apps
  • Replace __class__.__name__ check with isinstance for proper type narrowing in wrapped_open_ED4CF71136E15EBF

Test plan

  • hatch run lint:typing ddtrace/appsec/_common_module_patches.py passes clean
  • Existing appsec tests pass (no runtime behavior change)

🤖 Generated with Claude Code

Changelog entry type

  • No changelog needed (internal typing, no user-facing change)

florentinl and others added 5 commits March 26, 2026 11:59
Add typed signatures to all functions in _common_module_patches.py and
remove the mypy disallow_untyped_defs exception. Stdlib imports used
only for type annotations are deferred behind TYPE_CHECKING to avoid
loading http.client, urllib.request, pathlib, etc. at module import
time (this module loads via remote config even for non-HTTP apps).

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
@florentinl florentinl added the changelog/no-changelog A changelog entry is not required for this PR. label Mar 27, 2026
@cit-pr-commenter-54b7da
Copy link
Copy Markdown

Codeowners resolved as

ddtrace/appsec/_common_module_patches.py                                @DataDog/asm-python
mypy.ini                                                                @DataDog/python-guild @DataDog/apm-core-python

@pr-commenter
Copy link
Copy Markdown

pr-commenter bot commented Mar 27, 2026

Performance SLOs

Comparing candidate florentin.labelle/no-untyped-def-common-module-patches (38fd81a) with baseline main (a75e22c)

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

✅ add_aspect

Time: ✅ 102.373µs (SLO: <130.000µs 📉 -21.3%) vs baseline: +2.7%

Memory: ✅ 44.037MB (SLO: <46.000MB -4.3%) vs baseline: +5.1%


✅ add_inplace_aspect

Time: ✅ 100.541µs (SLO: <130.000µs 📉 -22.7%) vs baseline: -0.3%

Memory: ✅ 44.023MB (SLO: <46.000MB -4.3%) vs baseline: +4.5%


✅ add_inplace_noaspect

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

Memory: ✅ 43.971MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ add_noaspect

Time: ✅ 48.886µs (SLO: <70.000µs 📉 -30.2%) vs baseline: +0.7%

Memory: ✅ 43.999MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ bytearray_aspect

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

Memory: ✅ 44.005MB (SLO: <46.000MB -4.3%) vs baseline: +4.8%


✅ bytearray_extend_aspect

Time: ✅ 640.026µs (SLO: <800.000µs 📉 -20.0%) vs baseline: +1.4%

Memory: ✅ 43.923MB (SLO: <46.000MB -4.5%) vs baseline: +4.8%


✅ bytearray_extend_noaspect

Time: ✅ 264.702µs (SLO: <400.000µs 📉 -33.8%) vs baseline: +0.4%

Memory: ✅ 44.374MB (SLO: <46.000MB -3.5%) vs baseline: +5.8%


✅ bytearray_noaspect

Time: ✅ 137.383µs (SLO: <300.000µs 📉 -54.2%) vs baseline: +1.4%

Memory: ✅ 44.046MB (SLO: <46.000MB -4.2%) vs baseline: +4.9%


✅ bytes_aspect

Time: ✅ 216.917µs (SLO: <300.000µs 📉 -27.7%) vs baseline: -0.4%

Memory: ✅ 43.939MB (SLO: <46.000MB -4.5%) vs baseline: +4.6%


✅ bytes_noaspect

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

Memory: ✅ 43.970MB (SLO: <46.000MB -4.4%) vs baseline: +4.6%


✅ bytesio_aspect

Time: ✅ 3.740ms (SLO: <5.000ms 📉 -25.2%) vs baseline: -0.5%

Memory: ✅ 44.039MB (SLO: <46.000MB -4.3%) vs baseline: +4.9%


✅ bytesio_noaspect

Time: ✅ 311.098µs (SLO: <420.000µs 📉 -25.9%) vs baseline: -0.7%

Memory: ✅ 43.985MB (SLO: <46.000MB -4.4%) vs baseline: +4.8%


✅ capitalize_aspect

Time: ✅ 89.567µs (SLO: <300.000µs 📉 -70.1%) vs baseline: +0.5%

Memory: ✅ 43.964MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ capitalize_noaspect

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

Memory: ✅ 43.943MB (SLO: <46.000MB -4.5%) vs baseline: +4.7%


✅ casefold_aspect

Time: ✅ 89.214µs (SLO: <500.000µs 📉 -82.2%) vs baseline: -0.3%

Memory: ✅ 43.960MB (SLO: <46.000MB -4.4%) vs baseline: +4.6%


✅ casefold_noaspect

Time: ✅ 303.466µs (SLO: <500.000µs 📉 -39.3%) vs baseline: ~same

Memory: ✅ 44.004MB (SLO: <46.000MB -4.3%) vs baseline: +4.7%


✅ decode_aspect

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

Memory: ✅ 44.053MB (SLO: <46.000MB -4.2%) vs baseline: +4.9%


✅ decode_noaspect

Time: ✅ 153.545µs (SLO: <210.000µs 📉 -26.9%) vs baseline: +0.4%

Memory: ✅ 43.964MB (SLO: <46.000MB -4.4%) vs baseline: +4.7%


✅ encode_aspect

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

Memory: ✅ 44.068MB (SLO: <46.000MB -4.2%) vs baseline: +5.0%


✅ encode_noaspect

Time: ✅ 139.068µs (SLO: <200.000µs 📉 -30.5%) vs baseline: -1.8%

Memory: ✅ 44.009MB (SLO: <46.000MB -4.3%) vs baseline: +5.0%


✅ format_aspect

Time: ✅ 14.655ms (SLO: <19.200ms 📉 -23.7%) vs baseline: ~same

Memory: ✅ 44.188MB (SLO: <46.000MB -3.9%) vs baseline: +5.1%


✅ format_map_aspect

Time: ✅ 16.529ms (SLO: <21.500ms 📉 -23.1%) vs baseline: +0.5%

Memory: ✅ 44.019MB (SLO: <46.000MB -4.3%) vs baseline: +4.7%


✅ format_map_noaspect

Time: ✅ 368.441µs (SLO: <500.000µs 📉 -26.3%) vs baseline: -0.3%

Memory: ✅ 43.943MB (SLO: <46.000MB -4.5%) vs baseline: +4.7%


✅ format_noaspect

Time: ✅ 301.838µs (SLO: <500.000µs 📉 -39.6%) vs baseline: -0.5%

Memory: ✅ 44.029MB (SLO: <46.000MB -4.3%) vs baseline: +5.0%


✅ index_aspect

Time: ✅ 125.616µs (SLO: <300.000µs 📉 -58.1%) vs baseline: +4.9%

Memory: ✅ 43.978MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ index_noaspect

Time: ✅ 40.051µs (SLO: <300.000µs 📉 -86.6%) vs baseline: -1.1%

Memory: ✅ 44.044MB (SLO: <46.000MB -4.3%) vs baseline: +4.9%


✅ join_aspect

Time: ✅ 213.786µs (SLO: <300.000µs 📉 -28.7%) vs baseline: +2.0%

Memory: ✅ 44.000MB (SLO: <46.000MB -4.3%) vs baseline: +5.0%


✅ join_noaspect

Time: ✅ 142.242µs (SLO: <300.000µs 📉 -52.6%) vs baseline: -1.8%

Memory: ✅ 43.949MB (SLO: <46.000MB -4.5%) vs baseline: +4.9%


✅ ljust_aspect

Time: ✅ 576.814µs (SLO: <700.000µs 📉 -17.6%) vs baseline: 📈 +17.6%

Memory: ✅ 43.997MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ ljust_noaspect

Time: ✅ 255.253µs (SLO: <300.000µs 📉 -14.9%) vs baseline: +1.1%

Memory: ✅ 43.964MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ lower_aspect

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

Memory: ✅ 43.918MB (SLO: <46.000MB -4.5%) vs baseline: +4.7%


✅ lower_noaspect

Time: ✅ 234.221µs (SLO: <300.000µs 📉 -21.9%) vs baseline: -0.3%

Memory: ✅ 43.864MB (SLO: <46.000MB -4.6%) vs baseline: +4.8%


✅ lstrip_aspect

Time: ✅ 0.267ms (SLO: <3.000ms 📉 -91.1%) vs baseline: -0.1%

Memory: ✅ 43.942MB (SLO: <46.000MB -4.5%) vs baseline: +4.8%


✅ lstrip_noaspect

Time: ✅ 0.176ms (SLO: <3.000ms 📉 -94.1%) vs baseline: -1.6%

Memory: ✅ 43.986MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ modulo_aspect

Time: ✅ 14.273ms (SLO: <18.750ms 📉 -23.9%) vs baseline: -1.0%

Memory: ✅ 44.140MB (SLO: <46.000MB -4.0%) vs baseline: +5.1%


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 14.851ms (SLO: <19.350ms 📉 -23.3%) vs baseline: +0.9%

Memory: ✅ 44.048MB (SLO: <46.000MB -4.2%) vs baseline: +4.7%


✅ modulo_aspect_for_bytes

Time: ✅ 14.426ms (SLO: <18.900ms 📉 -23.7%) vs baseline: +0.3%

Memory: ✅ 44.049MB (SLO: <46.000MB -4.2%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 14.622ms (SLO: <19.150ms 📉 -23.6%) vs baseline: +0.4%

Memory: ✅ 44.077MB (SLO: <46.000MB -4.2%) vs baseline: +4.9%


✅ modulo_noaspect

Time: ✅ 0.361ms (SLO: <3.000ms 📉 -88.0%) vs baseline: +0.5%

Memory: ✅ 43.969MB (SLO: <46.000MB -4.4%) vs baseline: +5.0%


✅ replace_aspect

Time: ✅ 18.304ms (SLO: <24.000ms 📉 -23.7%) vs baseline: -0.7%

Memory: ✅ 44.102MB (SLO: <46.000MB -4.1%) vs baseline: +5.0%


✅ replace_noaspect

Time: ✅ 280.759µs (SLO: <400.000µs 📉 -29.8%) vs baseline: +0.8%

Memory: ✅ 44.009MB (SLO: <46.000MB -4.3%) vs baseline: +4.9%


✅ repr_aspect

Time: ✅ 308.723µs (SLO: <420.000µs 📉 -26.5%) vs baseline: +0.5%

Memory: ✅ 43.978MB (SLO: <46.000MB -4.4%) vs baseline: +4.7%


✅ repr_noaspect

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

Memory: ✅ 43.997MB (SLO: <46.000MB -4.4%) vs baseline: +4.8%


✅ rstrip_aspect

Time: ✅ 381.104µs (SLO: <500.000µs 📉 -23.8%) vs baseline: -1.0%

Memory: ✅ 43.985MB (SLO: <46.000MB -4.4%) vs baseline: +4.7%


✅ rstrip_noaspect

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

Memory: ✅ 43.926MB (SLO: <46.000MB -4.5%) vs baseline: +4.9%


✅ slice_aspect

Time: ✅ 182.405µs (SLO: <300.000µs 📉 -39.2%) vs baseline: -0.6%

Memory: ✅ 43.944MB (SLO: <46.000MB -4.5%) vs baseline: +4.7%


✅ slice_noaspect

Time: ✅ 53.779µs (SLO: <90.000µs 📉 -40.2%) vs baseline: -0.8%

Memory: ✅ 44.005MB (SLO: <46.000MB -4.3%) vs baseline: +5.1%


✅ stringio_aspect

Time: ✅ 4.381ms (SLO: <5.000ms 📉 -12.4%) vs baseline: 📈 +14.6%

Memory: ✅ 44.049MB (SLO: <46.000MB -4.2%) vs baseline: +4.8%


✅ stringio_noaspect

Time: ✅ 344.735µs (SLO: <500.000µs 📉 -31.1%) vs baseline: +0.1%

Memory: ✅ 44.043MB (SLO: <46.000MB -4.3%) vs baseline: +4.9%


✅ strip_aspect

Time: ✅ 269.786µs (SLO: <350.000µs 📉 -22.9%) vs baseline: +0.7%

Memory: ✅ 43.925MB (SLO: <46.000MB -4.5%) vs baseline: +4.8%


✅ strip_noaspect

Time: ✅ 177.882µs (SLO: <240.000µs 📉 -25.9%) vs baseline: +1.4%

Memory: ✅ 44.006MB (SLO: <46.000MB -4.3%) vs baseline: +4.9%


✅ swapcase_aspect

Time: ✅ 330.072µs (SLO: <500.000µs 📉 -34.0%) vs baseline: +0.3%

Memory: ✅ 43.965MB (SLO: <46.000MB -4.4%) vs baseline: +4.7%


✅ swapcase_noaspect

Time: ✅ 270.862µs (SLO: <400.000µs 📉 -32.3%) vs baseline: +0.4%

Memory: ✅ 43.982MB (SLO: <46.000MB -4.4%) vs baseline: +4.9%


✅ title_aspect

Time: ✅ 318.224µs (SLO: <500.000µs 📉 -36.4%) vs baseline: ~same

Memory: ✅ 43.998MB (SLO: <46.000MB -4.4%) vs baseline: +4.8%


✅ title_noaspect

Time: ✅ 256.961µs (SLO: <400.000µs 📉 -35.8%) vs baseline: ~same

Memory: ✅ 43.966MB (SLO: <46.000MB -4.4%) vs baseline: +4.8%


✅ translate_aspect

Time: ✅ 490.929µs (SLO: <700.000µs 📉 -29.9%) vs baseline: +0.8%

Memory: ✅ 44.003MB (SLO: <46.000MB -4.3%) vs baseline: +5.0%


✅ translate_noaspect

Time: ✅ 423.484µs (SLO: <500.000µs 📉 -15.3%) vs baseline: -1.1%

Memory: ✅ 44.024MB (SLO: <46.000MB -4.3%) vs baseline: +5.0%


✅ upper_aspect

Time: ✅ 294.620µs (SLO: <500.000µs 📉 -41.1%) vs baseline: +0.9%

Memory: ✅ 43.939MB (SLO: <46.000MB -4.5%) vs baseline: +4.8%


✅ upper_noaspect

Time: ✅ 235.379µs (SLO: <400.000µs 📉 -41.2%) vs baseline: +0.6%

Memory: ✅ 43.910MB (SLO: <46.000MB -4.5%) vs baseline: +4.8%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 512.582µs (SLO: <700.000µs 📉 -26.8%) vs baseline: 📈 +21.0%

Memory: ✅ 43.747MB (SLO: <46.000MB -4.9%) vs baseline: +4.1%


✅ ospathbasename_noaspect

Time: ✅ 429.920µs (SLO: <700.000µs 📉 -38.6%) vs baseline: +0.2%

Memory: ✅ 43.789MB (SLO: <46.000MB -4.8%) vs baseline: +4.9%


✅ ospathjoin_aspect

Time: ✅ 622.059µs (SLO: <700.000µs 📉 -11.1%) vs baseline: ~same

Memory: ✅ 43.864MB (SLO: <46.000MB -4.6%) vs baseline: +5.0%


✅ ospathjoin_noaspect

Time: ✅ 629.871µs (SLO: <700.000µs 📉 -10.0%) vs baseline: ~same

Memory: ✅ 43.715MB (SLO: <46.000MB -5.0%) vs baseline: +4.0%


✅ ospathnormcase_aspect

Time: ✅ 347.794µs (SLO: <700.000µs 📉 -50.3%) vs baseline: ~same

Memory: ✅ 43.761MB (SLO: <46.000MB -4.9%) vs baseline: +4.1%


✅ ospathnormcase_noaspect

Time: ✅ 356.681µs (SLO: <700.000µs 📉 -49.0%) vs baseline: -0.2%

Memory: ✅ 43.791MB (SLO: <46.000MB -4.8%) vs baseline: +4.4%


✅ ospathsplit_aspect

Time: ✅ 485.454µs (SLO: <700.000µs 📉 -30.6%) vs baseline: -0.5%

Memory: ✅ 43.974MB (SLO: <46.000MB -4.4%) vs baseline: +4.6%


✅ ospathsplit_noaspect

Time: ✅ 497.817µs (SLO: <700.000µs 📉 -28.9%) vs baseline: ~same

Memory: ✅ 43.715MB (SLO: <46.000MB -5.0%) vs baseline: +4.0%


✅ ospathsplitdrive_aspect

Time: ✅ 371.811µs (SLO: <700.000µs 📉 -46.9%) vs baseline: -0.2%

Memory: ✅ 43.780MB (SLO: <46.000MB -4.8%) vs baseline: +4.1%


✅ ospathsplitdrive_noaspect

Time: ✅ 73.270µs (SLO: <700.000µs 📉 -89.5%) vs baseline: +0.3%

Memory: ✅ 43.758MB (SLO: <46.000MB -4.9%) vs baseline: +4.8%


✅ ospathsplitext_aspect

Time: ✅ 452.974µs (SLO: <700.000µs 📉 -35.3%) vs baseline: -0.7%

Memory: ✅ 43.704MB (SLO: <46.000MB -5.0%) vs baseline: +3.8%


✅ ospathsplitext_noaspect

Time: ✅ 459.905µs (SLO: <700.000µs 📉 -34.3%) vs baseline: -1.0%

Memory: ✅ 43.608MB (SLO: <46.000MB -5.2%) vs baseline: +4.4%

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

✅ appsec

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

Memory: ✅ 68.896MB (SLO: <73.500MB -6.3%) vs baseline: +4.9%


✅ exception-replay-enabled

Time: ✅ 1.324ms (SLO: <1.450ms -8.7%) vs baseline: -0.4%

Memory: ✅ 66.679MB (SLO: <71.500MB -6.7%) vs baseline: +4.7%


✅ iast

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

Memory: ✅ 68.903MB (SLO: <75.000MB -8.1%) vs baseline: +4.8%


✅ profiler

Time: ✅ 15.078ms (SLO: <16.550ms -8.9%) vs baseline: -0.2%

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


✅ resource-renaming

Time: ✅ 19.622ms (SLO: <21.750ms -9.8%) vs baseline: -0.3%

Memory: ✅ 68.874MB (SLO: <73.500MB -6.3%) vs baseline: +4.7%


✅ span-code-origin

Time: ✅ 20.117ms (SLO: <28.200ms 📉 -28.7%) vs baseline: +1.5%

Memory: ✅ 68.710MB (SLO: <75.000MB -8.4%) vs baseline: +4.9%


✅ tracer

Time: ✅ 19.737ms (SLO: <21.750ms -9.3%) vs baseline: -0.2%

Memory: ✅ 68.788MB (SLO: <75.000MB -8.3%) vs baseline: +4.7%


✅ tracer-and-profiler

Time: ✅ 21.098ms (SLO: <23.500ms 📉 -10.2%) vs baseline: +0.4%

Memory: ✅ 70.708MB (SLO: <75.000MB -5.7%) vs baseline: +5.0%


✅ tracer-dont-create-db-spans

Time: ✅ 19.855ms (SLO: <21.500ms -7.7%) vs baseline: +0.7%

Memory: ✅ 68.888MB (SLO: <75.000MB -8.1%) vs baseline: +4.8%


✅ tracer-minimal

Time: ✅ 16.785ms (SLO: <17.500ms -4.1%) vs baseline: -0.7%

Memory: ✅ 68.803MB (SLO: <75.000MB -8.3%) vs baseline: +5.1%


✅ tracer-native

Time: ✅ 19.671ms (SLO: <21.750ms -9.6%) vs baseline: +0.6%

Memory: ✅ 68.834MB (SLO: <72.500MB -5.1%) vs baseline: +5.0%


✅ tracer-no-caches

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

Memory: ✅ 68.709MB (SLO: <75.000MB -8.4%) vs baseline: +5.0%


✅ tracer-no-databases

Time: ✅ 19.333ms (SLO: <20.100ms -3.8%) vs baseline: ~same

Memory: ✅ 68.646MB (SLO: <75.000MB -8.5%) vs baseline: +4.9%


✅ tracer-no-middleware

Time: ✅ 19.448ms (SLO: <21.500ms -9.5%) vs baseline: ~same

Memory: ✅ 68.699MB (SLO: <75.000MB -8.4%) vs baseline: +4.9%


✅ tracer-no-templates

Time: ✅ 19.673ms (SLO: <22.000ms 📉 -10.6%) vs baseline: +0.9%

Memory: ✅ 68.730MB (SLO: <73.500MB -6.5%) vs baseline: +5.1%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.358ms (SLO: <4.750ms 📉 -29.3%) vs baseline: -0.2%

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


✅ appsec-post

Time: ✅ 2.875ms (SLO: <6.750ms 📉 -57.4%) vs baseline: +0.2%

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


✅ appsec-telemetry

Time: ✅ 3.361ms (SLO: <4.750ms 📉 -29.2%) vs baseline: +0.2%

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


✅ debugger

Time: ✅ 1.879ms (SLO: <2.000ms -6.0%) vs baseline: +0.3%

Memory: ✅ 49.237MB (SLO: <51.500MB -4.4%) vs baseline: +4.8%


✅ iast-get

Time: ✅ 1.872ms (SLO: <2.000ms -6.4%) vs baseline: ~same

Memory: ✅ 46.026MB (SLO: <49.000MB -6.1%) vs baseline: +4.8%


✅ profiler

Time: ✅ 1.916ms (SLO: <2.100ms -8.8%) vs baseline: ~same

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


✅ resource-renaming

Time: ✅ 3.338ms (SLO: <3.650ms -8.5%) vs baseline: +0.1%

Memory: ✅ 56.078MB (SLO: <60.000MB -6.5%) vs baseline: +4.9%


✅ tracer

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

Memory: ✅ 56.129MB (SLO: <60.000MB -6.5%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 3.351ms (SLO: <3.650ms -8.2%) vs baseline: +0.3%

Memory: ✅ 56.200MB (SLO: <60.000MB -6.3%) vs baseline: +5.0%


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 311.947ms (SLO: <320.950ms -2.8%) vs baseline: +0.4%

Memory: ✅ 37.552MB (SLO: <38.750MB -3.1%) vs baseline: +4.9%


✅ deep-profiled

Time: ✅ 331.881ms (SLO: <359.150ms -7.6%) vs baseline: -0.2%

Memory: ✅ 43.824MB (SLO: <46.000MB -4.7%) vs baseline: +4.8%


✅ medium

Time: ✅ 7.274ms (SLO: <7.400ms 🟡 -1.7%) vs baseline: ~same

Memory: ✅ 36.294MB (SLO: <38.000MB -4.5%) vs baseline: +4.2%


✅ shallow

Time: ✅ 1.019ms (SLO: <1.050ms -2.9%) vs baseline: +2.0%

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +4.3%

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.661µs (SLO: <20.000µs 📉 -31.7%) vs baseline: +0.2%

Memory: ✅ 36.313MB (SLO: <38.000MB -4.4%) vs baseline: +4.9%


✅ context_with_data_no_listeners

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +4.8%


✅ get_item_exists

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

Memory: ✅ 36.294MB (SLO: <38.000MB -4.5%) vs baseline: +4.7%


✅ get_item_missing

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

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +4.7%


✅ set_item

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

Memory: ✅ 36.313MB (SLO: <38.000MB -4.4%) vs baseline: +4.7%


⚠️ packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 154.623µs (SLO: <170.000µs -9.0%) vs baseline: -0.6%

Memory: ✅ 41.418MB (SLO: <46.000MB -10.0%) vs baseline: +5.1%


✅ import_many_cached

Time: ✅ 121.802µs (SLO: <130.000µs -6.3%) vs baseline: +0.4%

Memory: ✅ 41.200MB (SLO: <46.000MB 📉 -10.4%) vs baseline: +4.0%


✅ import_many_stdlib

Time: ✅ 0.781ms (SLO: <1.750ms 📉 -55.4%) vs baseline: ~same

Memory: ✅ 41.297MB (SLO: <46.000MB 📉 -10.2%) vs baseline: +4.4%


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.178ms (SLO: <1.100ms 📉 -83.9%) vs baseline: +0.4%

Memory: ✅ 41.353MB (SLO: <46.000MB 📉 -10.1%) vs baseline: +4.4%


✅ import_many_unknown

Time: ✅ 832.959µs (SLO: <890.000µs -6.4%) vs baseline: +0.9%

Memory: ✅ 41.683MB (SLO: <46.000MB -9.4%) vs baseline: +4.8%


✅ import_many_unknown_cached

Time: ✅ 785.071µs (SLO: <870.000µs -9.8%) vs baseline: -0.3%

Memory: ✅ 41.616MB (SLO: <46.000MB -9.5%) vs baseline: +4.7%


✅ import_one

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

Memory: ✅ 41.292MB (SLO: <46.000MB 📉 -10.2%) vs baseline: +4.6%


✅ import_one_cache

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

Memory: ✅ 41.378MB (SLO: <46.000MB 📉 -10.0%) vs baseline: +5.0%


✅ import_one_stdlib

Time: ✅ 18.707µs (SLO: <20.000µs -6.5%) vs baseline: -0.2%

Memory: ✅ 41.402MB (SLO: <46.000MB -10.0%) vs baseline: +5.2%


✅ import_one_stdlib_cache

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

Memory: ✅ 41.312MB (SLO: <46.000MB 📉 -10.2%) vs baseline: +4.2%


✅ import_one_unknown

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

Memory: ✅ 41.266MB (SLO: <46.000MB 📉 -10.3%) vs baseline: +4.1%


✅ import_one_unknown_cache

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

Memory: ✅ 41.450MB (SLO: <43.000MB -3.6%) vs baseline: +4.6%

✅ All Tests Passing (18 suites)
codeprovenancefork - 2/2

✅ fork-10

Time: ✅ 2.138s (SLO: <2.300s -7.0%) vs baseline: +2.3%

Memory: ✅ 17.400MB (SLO: <20.000MB 📉 -13.0%) vs baseline: +4.7%


errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.327ms (SLO: <19.850ms 📉 -17.7%) vs baseline: -0.3%

Memory: ✅ 68.538MB (SLO: <75.000MB -8.6%) vs baseline: +4.8%


✅ errortracking-enabled-user

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

Memory: ✅ 68.538MB (SLO: <75.000MB -8.6%) vs baseline: +4.7%


✅ tracer-enabled

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

Memory: ✅ 68.518MB (SLO: <75.000MB -8.6%) vs baseline: +4.9%


errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.083ms (SLO: <2.300ms -9.4%) vs baseline: -0.4%

Memory: ✅ 56.171MB (SLO: <60.000MB -6.4%) vs baseline: +5.0%


✅ errortracking-enabled-user

Time: ✅ 2.093ms (SLO: <2.250ms -7.0%) vs baseline: +0.1%

Memory: ✅ 56.092MB (SLO: <60.000MB -6.5%) vs baseline: +4.8%


✅ tracer-enabled

Time: ✅ 2.089ms (SLO: <2.300ms -9.2%) vs baseline: +0.3%

Memory: ✅ 56.073MB (SLO: <60.000MB -6.5%) vs baseline: +5.0%


flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.082ms (SLO: <4.200ms 📉 -50.4%) vs baseline: -0.2%

Memory: ✅ 56.151MB (SLO: <66.000MB 📉 -14.9%) vs baseline: +4.9%


✅ iast-enabled

Time: ✅ 2.087ms (SLO: <2.800ms 📉 -25.5%) vs baseline: +0.3%

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


✅ tracer-enabled

Time: ✅ 2.087ms (SLO: <2.250ms -7.2%) vs baseline: +0.5%

Memory: ✅ 56.112MB (SLO: <60.000MB -6.5%) vs baseline: +4.8%


forktime - 4/4

✅ baseline

Time: ✅ 1.960ms (SLO: <3.000ms 📉 -34.7%) vs baseline: +5.0%

Memory: ✅ 29.216MB (SLO: <33.000MB 📉 -11.5%) vs baseline: +4.9%


✅ configured

Time: ✅ 8.632ms (SLO: <13.000ms 📉 -33.6%) vs baseline: -0.4%

Memory: ✅ 56.058MB (SLO: <60.000MB -6.6%) vs baseline: +4.8%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 80.640µs (SLO: <100.000µs 📉 -19.4%) vs baseline: +5.3%

Memory: ✅ 36.451MB (SLO: <38.000MB -4.1%) vs baseline: +5.1%


✅ b3_headers

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

Memory: ✅ 36.412MB (SLO: <38.000MB -4.2%) vs baseline: +5.0%


✅ b3_single_headers

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

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.5%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 61.205µs (SLO: <80.000µs 📉 -23.5%) vs baseline: -0.2%

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +4.5%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 63.148µs (SLO: <80.000µs 📉 -21.1%) vs baseline: +0.2%

Memory: ✅ 36.431MB (SLO: <38.000MB -4.1%) vs baseline: +4.8%


✅ empty_headers

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +5.0%


✅ full_t_id_datadog_headers

Time: ✅ 21.228µs (SLO: <30.000µs 📉 -29.2%) vs baseline: -0.5%

Memory: ✅ 36.412MB (SLO: <38.000MB -4.2%) vs baseline: +5.1%


✅ invalid_priority_header

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

Memory: ✅ 36.274MB (SLO: <38.000MB -4.5%) vs baseline: +4.3%


✅ invalid_span_id_header

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

Memory: ✅ 36.471MB (SLO: <38.000MB -4.0%) vs baseline: +5.1%


✅ invalid_tags_header

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

Memory: ✅ 36.471MB (SLO: <38.000MB -4.0%) vs baseline: +5.1%


✅ invalid_trace_id_header

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

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +4.9%


✅ large_header_no_matches

Time: ✅ 27.016µs (SLO: <30.000µs -9.9%) vs baseline: ~same

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.9%


✅ large_valid_headers_all

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

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +4.7%


✅ medium_header_no_matches

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +4.9%


✅ medium_valid_headers_all

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

Memory: ✅ 36.412MB (SLO: <38.000MB -4.2%) vs baseline: +5.0%


✅ none_propagation_style

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

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.9%


✅ tracecontext_headers

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +4.9%


✅ valid_headers_all

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

Memory: ✅ 36.431MB (SLO: <38.000MB -4.1%) vs baseline: +4.9%


✅ valid_headers_basic

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +5.1%


✅ wsgi_empty_headers

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

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +5.2%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +4.8%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +5.0%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +5.0%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.6%


✅ wsgi_large_header_no_matches

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

Memory: ✅ 36.510MB (SLO: <38.000MB -3.9%) vs baseline: +5.0%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +4.6%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +4.9%


✅ wsgi_medium_valid_headers_all

Time: ✅ 10.945µs (SLO: <20.000µs 📉 -45.3%) vs baseline: -0.1%

Memory: ✅ 36.431MB (SLO: <38.000MB -4.1%) vs baseline: +5.2%


✅ wsgi_valid_headers_all

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

Memory: ✅ 36.274MB (SLO: <38.000MB -4.5%) vs baseline: +4.6%


✅ wsgi_valid_headers_basic

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +4.9%


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 20.972µs (SLO: <30.000µs 📉 -30.1%) vs baseline: +4.3%

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +4.8%


✅ with_all

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

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.6%


✅ with_dd_origin

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

Memory: ✅ 36.431MB (SLO: <38.000MB -4.1%) vs baseline: +5.4%


✅ with_priority_and_origin

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

Memory: ✅ 36.412MB (SLO: <38.000MB -4.2%) vs baseline: +5.1%


✅ with_sampling_priority

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

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +5.0%


✅ with_tags

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

Memory: ✅ 36.392MB (SLO: <38.000MB -4.2%) vs baseline: +5.0%


✅ with_tags_invalid

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

Memory: ✅ 36.274MB (SLO: <38.000MB -4.5%) vs baseline: +4.6%


✅ with_tags_max_size

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

Memory: ✅ 36.313MB (SLO: <38.000MB -4.4%) vs baseline: +4.9%


iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 154.358µs (SLO: <250.000µs 📉 -38.3%) vs baseline: +3.3%

Memory: ✅ 43.812MB (SLO: <46.000MB -4.8%) vs baseline: +4.6%


✅ rsplit_noaspect

Time: ✅ 156.248µs (SLO: <250.000µs 📉 -37.5%) vs baseline: +0.6%

Memory: ✅ 43.785MB (SLO: <46.000MB -4.8%) vs baseline: +5.1%


✅ split_aspect

Time: ✅ 148.146µs (SLO: <250.000µs 📉 -40.7%) vs baseline: -1.9%

Memory: ✅ 43.745MB (SLO: <46.000MB -4.9%) vs baseline: +4.9%


✅ split_noaspect

Time: ✅ 153.190µs (SLO: <250.000µs 📉 -38.7%) vs baseline: +1.1%

Memory: ✅ 43.686MB (SLO: <46.000MB -5.0%) vs baseline: +5.0%


✅ splitlines_aspect

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

Memory: ✅ 43.710MB (SLO: <46.000MB -5.0%) vs baseline: +4.9%


✅ splitlines_noaspect

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

Memory: ✅ 43.784MB (SLO: <46.000MB -4.8%) vs baseline: +4.2%


iastpropagation - 8/8

✅ no-propagation

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

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


✅ propagation_enabled

Time: ✅ 135.609µs (SLO: <190.000µs 📉 -28.6%) vs baseline: +0.9%

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


✅ propagation_enabled_100

Time: ✅ 1.549ms (SLO: <2.300ms 📉 -32.6%) vs baseline: -0.3%

Memory: ✅ 40.147MB (SLO: <42.000MB -4.4%) vs baseline: +4.9%


✅ propagation_enabled_1000

Time: ✅ 28.905ms (SLO: <34.550ms 📉 -16.3%) vs baseline: ~same

Memory: ✅ 40.187MB (SLO: <42.000MB -4.3%) vs baseline: +4.9%


otelsdkspan - 24/24

✅ add-event

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

Memory: ✅ 39.125MB (SLO: <40.750MB -4.0%) vs baseline: +4.9%


✅ add-link

Time: ✅ 36.427ms (SLO: <38.550ms -5.5%) vs baseline: +0.2%

Memory: ✅ 39.184MB (SLO: <40.750MB -3.8%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 218.950ms (SLO: <232.000ms -5.6%) vs baseline: -0.9%

Memory: ✅ 39.125MB (SLO: <40.750MB -4.0%) vs baseline: +5.2%


✅ add-tags

Time: ✅ 212.021ms (SLO: <221.600ms -4.3%) vs baseline: +0.6%

Memory: ✅ 39.204MB (SLO: <40.750MB -3.8%) vs baseline: +5.2%


✅ get-context

Time: ✅ 29.126ms (SLO: <31.300ms -6.9%) vs baseline: +0.2%

Memory: ✅ 39.125MB (SLO: <40.750MB -4.0%) vs baseline: +4.8%


✅ is-recording

Time: ✅ 29.245ms (SLO: <31.000ms -5.7%) vs baseline: ~same

Memory: ✅ 39.164MB (SLO: <40.750MB -3.9%) vs baseline: +4.6%


✅ record-exception

Time: ✅ 63.163ms (SLO: <65.850ms -4.1%) vs baseline: -0.4%

Memory: ✅ 39.105MB (SLO: <40.750MB -4.0%) vs baseline: +4.5%


✅ set-status

Time: ✅ 31.936ms (SLO: <34.150ms -6.5%) vs baseline: +0.1%

Memory: ✅ 39.145MB (SLO: <40.750MB -3.9%) vs baseline: +4.9%


✅ start

Time: ✅ 29.421ms (SLO: <30.150ms -2.4%) vs baseline: +2.2%

Memory: ✅ 39.145MB (SLO: <40.750MB -3.9%) vs baseline: +4.9%


✅ start-finish

Time: ✅ 34.146ms (SLO: <35.350ms -3.4%) vs baseline: +0.4%

Memory: ✅ 39.145MB (SLO: <40.750MB -3.9%) vs baseline: +4.9%


✅ start-finish-telemetry

Time: ✅ 34.146ms (SLO: <35.450ms -3.7%) vs baseline: +0.6%

Memory: ✅ 39.145MB (SLO: <40.750MB -3.9%) vs baseline: +4.9%


✅ update-name

Time: ✅ 31.235ms (SLO: <33.400ms -6.5%) vs baseline: +0.9%

Memory: ✅ 39.204MB (SLO: <40.750MB -3.8%) vs baseline: +4.8%


otelspan - 22/22

✅ add-event

Time: ✅ 38.231ms (SLO: <47.150ms 📉 -18.9%) vs baseline: +0.4%

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


✅ add-metrics

Time: ✅ 258.983ms (SLO: <344.800ms 📉 -24.9%) vs baseline: +0.5%

Memory: ✅ 45.880MB (SLO: <47.500MB -3.4%) vs baseline: +4.7%


✅ add-tags

Time: ✅ 308.401ms (SLO: <330.000ms -6.5%) vs baseline: ~same

Memory: ✅ 45.932MB (SLO: <47.500MB -3.3%) vs baseline: +4.7%


✅ get-context

Time: ✅ 80.687ms (SLO: <92.350ms 📉 -12.6%) vs baseline: ~same

Memory: ✅ 41.870MB (SLO: <46.500MB -10.0%) vs baseline: +5.3%


✅ is-recording

Time: ✅ 36.640ms (SLO: <44.500ms 📉 -17.7%) vs baseline: -0.1%

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


✅ record-exception

Time: ✅ 56.672ms (SLO: <67.650ms 📉 -16.2%) vs baseline: +0.3%

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


✅ set-status

Time: ✅ 43.267ms (SLO: <50.400ms 📉 -14.2%) vs baseline: +0.5%

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


✅ start

Time: ✅ 37.410ms (SLO: <43.450ms 📉 -13.9%) vs baseline: +3.8%

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


✅ start-finish

Time: ✅ 84.961ms (SLO: <90.000ms -5.6%) vs baseline: +0.3%

Memory: ✅ 39.125MB (SLO: <46.500MB 📉 -15.9%) vs baseline: +5.4%


✅ start-finish-telemetry

Time: ✅ 86.490ms (SLO: <91.000ms -5.0%) vs baseline: +0.5%

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


✅ update-name

Time: ✅ 37.618ms (SLO: <45.150ms 📉 -16.7%) vs baseline: +0.2%

Memory: ✅ 41.492MB (SLO: <47.000MB 📉 -11.7%) vs baseline: +5.1%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 343.625ms (SLO: <354.300ms -3.0%) vs baseline: -0.1%

Memory: ✅ 42.465MB (SLO: <46.000MB -7.7%) vs baseline: +4.7%


✅ cache_on

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

Memory: ✅ 41.921MB (SLO: <46.000MB -8.9%) vs baseline: +6.0%


ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 36.667MB (SLO: <38.000MB -3.5%) vs baseline: +4.9%


✅ high_rate_limit

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

Memory: ✅ 36.648MB (SLO: <38.000MB -3.6%) vs baseline: +4.8%


✅ long_window

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

Memory: ✅ 36.667MB (SLO: <38.000MB -3.5%) vs baseline: +4.8%


✅ low_rate_limit

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

Memory: ✅ 36.628MB (SLO: <38.000MB -3.6%) vs baseline: +4.8%


✅ no_rate_limit

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

Memory: ✅ 36.687MB (SLO: <38.000MB -3.5%) vs baseline: +4.9%


✅ short_window

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

Memory: ✅ 36.667MB (SLO: <38.000MB -3.5%) vs baseline: +4.9%


samplingrules - 8/8

✅ average_match

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

Memory: ✅ 36.333MB (SLO: <38.000MB -4.4%) vs baseline: +4.9%


✅ high_match

Time: ✅ 194.486µs (SLO: <480.000µs 📉 -59.5%) vs baseline: +0.4%

Memory: ✅ 36.372MB (SLO: <38.000MB -4.3%) vs baseline: +5.0%


✅ low_match

Time: ✅ 100.118µs (SLO: <120.000µs 📉 -16.6%) vs baseline: +0.3%

Memory: ✅ 701.725MB (SLO: <780.000MB 📉 -10.0%) vs baseline: +4.9%


✅ very_low_match

Time: ✅ 2.880ms (SLO: <8.500ms 📉 -66.1%) vs baseline: +0.2%

Memory: ✅ 79.003MB (SLO: <85.000MB -7.1%) vs baseline: +5.0%


sethttpmeta - 32/32

✅ all-disabled

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

Memory: ✅ 37.238MB (SLO: <38.750MB -3.9%) vs baseline: +4.9%


✅ all-enabled

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

Memory: ✅ 37.257MB (SLO: <38.750MB -3.9%) vs baseline: +4.9%


✅ collectipvariant_exists

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

Memory: ✅ 37.297MB (SLO: <38.750MB -3.8%) vs baseline: +5.1%


✅ no-collectipvariant

Time: ✅ 38.368µs (SLO: <50.000µs 📉 -23.3%) vs baseline: +0.3%

Memory: ✅ 37.218MB (SLO: <38.750MB -4.0%) vs baseline: +5.0%


✅ no-useragentvariant

Time: ✅ 36.709µs (SLO: <50.000µs 📉 -26.6%) vs baseline: -1.2%

Memory: ✅ 37.139MB (SLO: <38.750MB -4.2%) vs baseline: +4.5%


✅ obfuscation-no-query

Time: ✅ 38.304µs (SLO: <50.000µs 📉 -23.4%) vs baseline: -0.7%

Memory: ✅ 37.257MB (SLO: <38.750MB -3.9%) vs baseline: +5.1%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 74.016µs (SLO: <90.000µs 📉 -17.8%) vs baseline: -0.5%

Memory: ✅ 37.611MB (SLO: <38.750MB -2.9%) vs baseline: +5.2%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 74.780µs (SLO: <90.000µs 📉 -16.9%) vs baseline: -0.6%

Memory: ✅ 37.572MB (SLO: <38.750MB -3.0%) vs baseline: +4.9%


✅ obfuscation-send-querystring-disabled

Time: ✅ 152.492µs (SLO: <170.000µs 📉 -10.3%) vs baseline: -0.3%

Memory: ✅ 37.572MB (SLO: <38.750MB -3.0%) vs baseline: +4.8%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 37.670MB (SLO: <38.750MB -2.8%) vs baseline: +5.0%


✅ obfuscation-worst-case-implicit-query

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

Memory: ✅ 37.591MB (SLO: <38.750MB -3.0%) vs baseline: +4.9%


✅ useragentvariant_exists_1

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

Memory: ✅ 37.316MB (SLO: <38.750MB -3.7%) vs baseline: +5.3%


✅ useragentvariant_exists_2

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

Memory: ✅ 37.179MB (SLO: <38.750MB -4.1%) vs baseline: +4.5%


✅ useragentvariant_exists_3

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

Memory: ✅ 37.218MB (SLO: <38.750MB -4.0%) vs baseline: +5.1%


✅ useragentvariant_not_exists_1

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

Memory: ✅ 37.277MB (SLO: <38.750MB -3.8%) vs baseline: +5.0%


✅ useragentvariant_not_exists_2

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

Memory: ✅ 37.139MB (SLO: <38.750MB -4.2%) vs baseline: +4.6%


span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 86.385ms (SLO: <93.500ms -7.6%) vs baseline: +0.3%

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


✅ add-tags

Time: ✅ 145.301ms (SLO: <155.000ms -6.3%) vs baseline: +0.5%

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


✅ get-context

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

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


✅ is-recording

Time: ✅ 16.816ms (SLO: <20.500ms 📉 -18.0%) vs baseline: ~same

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


✅ record-exception

Time: ✅ 35.739ms (SLO: <41.000ms 📉 -12.8%) vs baseline: +0.2%

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


✅ set-status

Time: ✅ 18.499ms (SLO: <22.000ms 📉 -15.9%) vs baseline: -0.2%

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


✅ start

Time: ✅ 17.382ms (SLO: <20.500ms 📉 -15.2%) vs baseline: +4.9%

Memory: ✅ 38.668MB (SLO: <53.000MB 📉 -27.0%) vs baseline: +5.3%


✅ start-finish

Time: ✅ 53.934ms (SLO: <56.000ms -3.7%) vs baseline: +0.1%

Memory: ✅ 36.255MB (SLO: <38.000MB -4.6%) vs baseline: +4.0%


✅ start-finish-telemetry

Time: ✅ 54.962ms (SLO: <58.000ms -5.2%) vs baseline: ~same

Memory: ✅ 36.294MB (SLO: <38.000MB -4.5%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 56.231ms (SLO: <60.000ms -6.3%) vs baseline: ~same

Memory: ✅ 36.235MB (SLO: <38.000MB -4.6%) vs baseline: +4.7%


✅ start-traceid128

Time: ✅ 16.853ms (SLO: <22.500ms 📉 -25.1%) vs baseline: +1.0%

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


✅ update-name

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

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


telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 2.265µs (SLO: <20.000µs 📉 -88.7%) vs baseline: +8.3%

Memory: ✅ 36.510MB (SLO: <38.000MB -3.9%) vs baseline: +4.5%


✅ 1-count-metrics-100-times

Time: ✅ 149.269µs (SLO: <220.000µs 📉 -32.2%) vs baseline: -0.3%

Memory: ✅ 36.510MB (SLO: <38.000MB -3.9%) vs baseline: +4.5%


✅ 1-distribution-metric-1-times

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

Memory: ✅ 36.628MB (SLO: <38.000MB -3.6%) vs baseline: +4.7%


✅ 1-distribution-metrics-100-times

Time: ✅ 163.537µs (SLO: <230.000µs 📉 -28.9%) vs baseline: +0.3%

Memory: ✅ 36.648MB (SLO: <38.000MB -3.6%) vs baseline: +5.0%


✅ 1-gauge-metric-1-times

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

Memory: ✅ 36.549MB (SLO: <38.000MB -3.8%) vs baseline: +4.6%


✅ 1-gauge-metrics-100-times

Time: ✅ 138.025µs (SLO: <150.000µs -8.0%) vs baseline: +1.5%

Memory: ✅ 36.353MB (SLO: <38.000MB -4.3%) vs baseline: +4.0%


✅ 1-rate-metric-1-times

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

Memory: ✅ 36.608MB (SLO: <38.000MB -3.7%) vs baseline: +4.9%


✅ 1-rate-metrics-100-times

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

Memory: ✅ 36.510MB (SLO: <38.000MB -3.9%) vs baseline: +4.4%


✅ 100-count-metrics-100-times

Time: ✅ 15.187ms (SLO: <22.000ms 📉 -31.0%) vs baseline: -0.7%

Memory: ✅ 36.687MB (SLO: <38.000MB -3.5%) vs baseline: +5.1%


✅ 100-distribution-metrics-100-times

Time: ✅ 1.752ms (SLO: <2.550ms 📉 -31.3%) vs baseline: ~same

Memory: ✅ 36.648MB (SLO: <38.000MB -3.6%) vs baseline: +4.6%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.421ms (SLO: <1.550ms -8.4%) vs baseline: +0.5%

Memory: ✅ 36.608MB (SLO: <38.000MB -3.7%) vs baseline: +4.9%


✅ 100-rate-metrics-100-times

Time: ✅ 1.715ms (SLO: <2.550ms 📉 -32.7%) vs baseline: +0.2%

Memory: ✅ 36.589MB (SLO: <38.000MB -3.7%) vs baseline: +4.7%


✅ flush-1-metric

Time: ✅ 3.686µs (SLO: <20.000µs 📉 -81.6%) vs baseline: +2.9%

Memory: ✅ 36.687MB (SLO: <38.000MB -3.5%) vs baseline: +4.9%


✅ flush-100-metrics

Time: ✅ 182.265µs (SLO: <250.000µs 📉 -27.1%) vs baseline: +1.1%

Memory: ✅ 36.726MB (SLO: <38.000MB -3.4%) vs baseline: +4.7%


✅ flush-1000-metrics

Time: ✅ 2.269ms (SLO: <2.500ms -9.2%) vs baseline: +0.2%

Memory: ✅ 37.473MB (SLO: <38.750MB -3.3%) vs baseline: +4.9%


tracer - 6/6

✅ large

Time: ✅ 31.380ms (SLO: <32.950ms -4.8%) vs baseline: +0.8%

Memory: ✅ 37.473MB (SLO: <39.250MB -4.5%) vs baseline: +4.5%


✅ medium

Time: ✅ 3.088ms (SLO: <3.200ms -3.5%) vs baseline: +0.3%

Memory: ✅ 36.274MB (SLO: <38.750MB -6.4%) vs baseline: +4.7%


✅ small

Time: ✅ 360.360µs (SLO: <370.000µs -2.6%) vs baseline: +2.8%

Memory: ✅ 36.333MB (SLO: <38.750MB -6.2%) vs baseline: +5.0%

ℹ️ Scenarios Missing SLO Configuration (46 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
  • iast_aspects-re_expand_aspect
  • iast_aspects-re_expand_noaspect
  • iast_aspects-re_findall_aspect
  • iast_aspects-re_findall_noaspect
  • iast_aspects-re_finditer_aspect
  • iast_aspects-re_finditer_noaspect
  • iast_aspects-re_fullmatch_aspect
  • iast_aspects-re_fullmatch_noaspect
  • iast_aspects-re_group_aspect
  • iast_aspects-re_group_noaspect
  • iast_aspects-re_groups_aspect
  • iast_aspects-re_groups_noaspect
  • iast_aspects-re_match_aspect
  • iast_aspects-re_match_noaspect
  • iast_aspects-re_search_aspect
  • iast_aspects-re_search_noaspect
  • iast_aspects-re_sub_aspect
  • iast_aspects-re_sub_noaspect
  • iast_aspects-re_subn_aspect
  • iast_aspects-re_subn_noaspect
  • 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

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.

1 participant