Skip to content

refactor(appsec): move _stacktrace from _iast to _shared package#17329

Merged
gh-worker-dd-mergequeue-cf854d[bot] merged 6 commits intomainfrom
avara1986/move-stacktrace-to-shared
Apr 7, 2026
Merged

refactor(appsec): move _stacktrace from _iast to _shared package#17329
gh-worker-dd-mergequeue-cf854d[bot] merged 6 commits intomainfrom
avara1986/move-stacktrace-to-shared

Conversation

@avara1986
Copy link
Copy Markdown
Member

Summary

  • Move the native _stacktrace C extension from ddtrace/appsec/_iast/ to ddtrace/appsec/_shared/ so it can be reused by both IAST and SCA without creating a dependency from SCA into IAST internals.
  • Update all imports, build configuration (setup.py), and test references to use the new ddtrace.appsec._shared._stacktrace path.

Split out from #17156 to keep PRs incremental and reviewable.

Important: Before merging this PR, DataDog/datadog-lambda-python#761 must be merged first, since datadog-lambda-python imports ddtrace.appsec._iast._stacktrace and needs to be updated to the new path.

Test plan

  • Existing IAST stacktrace tests pass (tests/appsec/iast/test_stacktrace.py)
  • IAST memcheck tests pass (tests/appsec/iast_memcheck/test_iast_mem_check.py)
  • Architecture loading module test passes (tests/appsec/architectures/test_appsec_loading_modules.py)
  • Serverless import test passes (tests/internal/test_serverless.py)
  • Native C extension builds correctly from new path

🤖 Generated with Claude Code

Move the native _stacktrace C extension from ddtrace/appsec/_iast/ to
ddtrace/appsec/_shared/ so it can be reused by both IAST and SCA
without creating a dependency from SCA into IAST internals.

Split out from #17156 to keep PRs incremental and reviewable.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
@avara1986 avara1986 requested review from a team as code owners April 6, 2026 12:28
@cit-pr-commenter-54b7da
Copy link
Copy Markdown

cit-pr-commenter-54b7da bot commented Apr 6, 2026

Codeowners resolved as

ddtrace/appsec/_iast/__init__.py                                        @DataDog/asm-python
ddtrace/appsec/_patch_utils.py                                          @DataDog/asm-python
ddtrace/appsec/_shared/__init__.py                                      @DataDog/asm-python
ddtrace/appsec/_shared/_stacktrace.c                                    @DataDog/asm-python
ddtrace/appsec/_shared/_stacktrace.pyi                                  @DataDog/asm-python
setup.py                                                                @DataDog/python-guild
tests/appsec/architectures/test_appsec_loading_modules.py               @DataDog/asm-python
tests/appsec/iast/test_stacktrace.py                                    @DataDog/asm-python
tests/appsec/iast_memcheck/fixtures/stacktrace.py                       @DataDog/asm-python
tests/appsec/iast_memcheck/test_iast_mem_check.py                       @DataDog/asm-python
tests/appsec/integrations/flask_tests/test_iast_flask.py                @DataDog/asm-python
tests/internal/test_serverless.py                                       @DataDog/apm-serverless @DataDog/asm-python @DataDog/serverless-aws @DataDog/serverless-azure-and-gcp

@avara1986 avara1986 added changelog/no-changelog A changelog entry is not required for this PR. ASM Application Security Monitoring labels Apr 6, 2026
@pr-commenter
Copy link
Copy Markdown

pr-commenter bot commented Apr 6, 2026

Performance SLOs

Comparing candidate avara1986/move-stacktrace-to-shared (4b145d0) with baseline main (4b106fd)

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

✅ add_aspect

Time: ✅ 104.450µs (SLO: <130.000µs 📉 -19.7%) vs baseline: +2.1%

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


✅ add_inplace_aspect

Time: ✅ 102.774µs (SLO: <130.000µs 📉 -20.9%) vs baseline: +1.1%

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


✅ add_inplace_noaspect

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

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


✅ add_noaspect

Time: ✅ 50.178µs (SLO: <70.000µs 📉 -28.3%) vs baseline: +2.3%

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


✅ bytearray_aspect

Time: ✅ 254.202µs (SLO: <400.000µs 📉 -36.4%) vs baseline: -0.7%

Memory: ✅ 43.898MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ bytearray_extend_aspect

Time: ✅ 660.105µs (SLO: <800.000µs 📉 -17.5%) vs baseline: -1.3%

Memory: ✅ 43.869MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

Time: ✅ 139.076µs (SLO: <300.000µs 📉 -53.6%) vs baseline: -0.7%

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


✅ bytes_aspect

Time: ✅ 221.181µs (SLO: <300.000µs 📉 -26.3%) vs baseline: +0.2%

Memory: ✅ 43.905MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ bytes_noaspect

Time: ✅ 133.753µs (SLO: <200.000µs 📉 -33.1%) vs baseline: -0.3%

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


✅ bytesio_aspect

Time: ✅ 3.794ms (SLO: <5.000ms 📉 -24.1%) vs baseline: -0.7%

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


✅ bytesio_noaspect

Time: ✅ 318.419µs (SLO: <420.000µs 📉 -24.2%) vs baseline: +0.7%

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


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

Time: ✅ 253.065µs (SLO: <300.000µs 📉 -15.6%) vs baseline: +2.3%

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


✅ casefold_aspect

Time: ✅ 93.964µs (SLO: <500.000µs 📉 -81.2%) vs baseline: +3.8%

Memory: ✅ 43.959MB (SLO: <46.000MB -4.4%) vs baseline: +5.1%


✅ casefold_noaspect

Time: ✅ 305.571µs (SLO: <500.000µs 📉 -38.9%) vs baseline: +0.6%

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


✅ decode_aspect

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

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


✅ decode_noaspect

Time: ✅ 153.011µs (SLO: <210.000µs 📉 -27.1%) vs baseline: -0.4%

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


✅ encode_aspect

Time: ✅ 84.187µs (SLO: <200.000µs 📉 -57.9%) vs baseline: -0.3%

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


✅ encode_noaspect

Time: ✅ 143.201µs (SLO: <200.000µs 📉 -28.4%) vs baseline: +1.2%

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


✅ format_aspect

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

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


✅ format_map_aspect

Time: ✅ 16.416ms (SLO: <21.500ms 📉 -23.6%) vs baseline: -0.2%

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


✅ format_map_noaspect

Time: ✅ 378.987µs (SLO: <500.000µs 📉 -24.2%) vs baseline: +1.0%

Memory: ✅ 43.981MB (SLO: <46.000MB -4.4%) vs baseline: +5.1%


✅ format_noaspect

Time: ✅ 310.455µs (SLO: <500.000µs 📉 -37.9%) vs baseline: +0.7%

Memory: ✅ 43.888MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ index_aspect

Time: ✅ 126.240µs (SLO: <300.000µs 📉 -57.9%) vs baseline: +0.6%

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


✅ index_noaspect

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

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


✅ join_aspect

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

Memory: ✅ 43.973MB (SLO: <46.000MB -4.4%) vs baseline: +5.1%


✅ join_noaspect

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

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


✅ ljust_aspect

Time: ✅ 508.518µs (SLO: <700.000µs 📉 -27.4%) vs baseline: +1.5%

Memory: ✅ 43.979MB (SLO: <46.000MB -4.4%) vs baseline: +5.3%


✅ ljust_noaspect

Time: ✅ 262.893µs (SLO: <300.000µs 📉 -12.4%) vs baseline: +0.7%

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


✅ lower_aspect

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

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


✅ lower_noaspect

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

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


✅ lstrip_aspect

Time: ✅ 0.279ms (SLO: <3.000ms 📉 -90.7%) vs baseline: -0.6%

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


✅ lstrip_noaspect

Time: ✅ 0.201ms (SLO: <3.000ms 📉 -93.3%) vs baseline: 📈 +12.7%

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


✅ modulo_aspect

Time: ✅ 14.348ms (SLO: <18.750ms 📉 -23.5%) vs baseline: ~same

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


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 14.786ms (SLO: <19.350ms 📉 -23.6%) vs baseline: -0.2%

Memory: ✅ 44.056MB (SLO: <46.000MB -4.2%) vs baseline: +4.6%


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 14.608ms (SLO: <19.150ms 📉 -23.7%) vs baseline: -0.2%

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


✅ modulo_noaspect

Time: ✅ 0.364ms (SLO: <3.000ms 📉 -87.9%) vs baseline: +0.7%

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


✅ replace_aspect

Time: ✅ 18.388ms (SLO: <24.000ms 📉 -23.4%) vs baseline: ~same

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


✅ replace_noaspect

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

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


✅ repr_aspect

Time: ✅ 321.675µs (SLO: <420.000µs 📉 -23.4%) vs baseline: -0.6%

Memory: ✅ 43.924MB (SLO: <46.000MB -4.5%) vs baseline: +5.1%


✅ repr_noaspect

Time: ✅ 46.608µs (SLO: <90.000µs 📉 -48.2%) vs baseline: -0.4%

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


✅ rstrip_aspect

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

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


✅ rstrip_noaspect

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

Memory: ✅ 43.854MB (SLO: <46.000MB -4.7%) vs baseline: +4.6%


✅ slice_aspect

Time: ✅ 189.822µs (SLO: <300.000µs 📉 -36.7%) vs baseline: +3.1%

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


✅ slice_noaspect

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

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


✅ stringio_aspect

Time: ✅ 3.840ms (SLO: <5.000ms 📉 -23.2%) vs baseline: ~same

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


✅ stringio_noaspect

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

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


✅ strip_aspect

Time: ✅ 280.855µs (SLO: <350.000µs 📉 -19.8%) vs baseline: -0.6%

Memory: ✅ 43.862MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ strip_noaspect

Time: ✅ 177.342µs (SLO: <240.000µs 📉 -26.1%) vs baseline: ~same

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


✅ swapcase_aspect

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

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


✅ swapcase_noaspect

Time: ✅ 269.908µs (SLO: <400.000µs 📉 -32.5%) vs baseline: -0.4%

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


✅ title_aspect

Time: ✅ 325.596µs (SLO: <500.000µs 📉 -34.9%) vs baseline: +0.7%

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


✅ title_noaspect

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

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


✅ translate_aspect

Time: ✅ 499.631µs (SLO: <700.000µs 📉 -28.6%) vs baseline: +1.6%

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


✅ translate_noaspect

Time: ✅ 425.528µs (SLO: <500.000µs 📉 -14.9%) vs baseline: -0.7%

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


✅ upper_aspect

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

Memory: ✅ 44.018MB (SLO: <46.000MB -4.3%) vs baseline: +5.4%


✅ upper_noaspect

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

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


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 518.528µs (SLO: <700.000µs 📉 -25.9%) vs baseline: 📈 +23.1%

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

Time: ✅ 624.877µs (SLO: <700.000µs 📉 -10.7%) vs baseline: +0.4%

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


✅ ospathjoin_noaspect

Time: ✅ 636.285µs (SLO: <700.000µs -9.1%) vs baseline: +1.0%

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


✅ ospathnormcase_aspect

Time: ✅ 351.435µs (SLO: <700.000µs 📉 -49.8%) vs baseline: -0.3%

Memory: ✅ 43.894MB (SLO: <46.000MB -4.6%) vs baseline: +4.7%


✅ ospathnormcase_noaspect

Time: ✅ 357.525µs (SLO: <700.000µs 📉 -48.9%) vs baseline: -1.6%

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

Time: ✅ 494.988µs (SLO: <700.000µs 📉 -29.3%) vs baseline: +0.4%

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


✅ ospathsplitdrive_aspect

Time: ✅ 373.392µs (SLO: <700.000µs 📉 -46.7%) vs baseline: -1.1%

Memory: ✅ 44.001MB (SLO: <46.000MB -4.3%) vs baseline: +5.2%


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

Time: ✅ 466.273µs (SLO: <700.000µs 📉 -33.4%) vs baseline: +0.1%

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


📈 iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 169.293µs (SLO: <250.000µs 📉 -32.3%) vs baseline: 📈 +10.9%

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


✅ rsplit_noaspect

Time: ✅ 161.539µs (SLO: <250.000µs 📉 -35.4%) vs baseline: +1.2%

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


✅ split_aspect

Time: ✅ 150.194µs (SLO: <250.000µs 📉 -39.9%) vs baseline: -1.1%

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


✅ split_noaspect

Time: ✅ 157.796µs (SLO: <250.000µs 📉 -36.9%) vs baseline: -0.5%

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


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

Time: ✅ 157.314µs (SLO: <250.000µs 📉 -37.1%) vs baseline: +0.8%

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

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

✅ appsec

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

Memory: ✅ 69.540MB (SLO: <73.500MB -5.4%) vs baseline: +4.9%


✅ exception-replay-enabled

Time: ✅ 1.328ms (SLO: <1.450ms -8.4%) vs baseline: ~same

Memory: ✅ 67.682MB (SLO: <71.500MB -5.3%) vs baseline: +4.9%


✅ iast

Time: ✅ 19.651ms (SLO: <22.250ms 📉 -11.7%) vs baseline: -0.3%

Memory: ✅ 69.501MB (SLO: <75.000MB -7.3%) vs baseline: +4.9%


✅ profiler

Time: ✅ 15.140ms (SLO: <16.550ms -8.5%) vs baseline: +0.3%

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


✅ resource-renaming

Time: ✅ 19.626ms (SLO: <21.750ms -9.8%) vs baseline: ~same

Memory: ✅ 69.521MB (SLO: <73.500MB -5.4%) vs baseline: +5.0%


✅ span-code-origin

Time: ✅ 20.300ms (SLO: <28.200ms 📉 -28.0%) vs baseline: +2.0%

Memory: ✅ 69.472MB (SLO: <75.000MB -7.4%) vs baseline: +4.8%


✅ tracer

Time: ✅ 19.747ms (SLO: <21.750ms -9.2%) vs baseline: -0.2%

Memory: ✅ 69.501MB (SLO: <75.000MB -7.3%) vs baseline: +4.9%


✅ tracer-and-profiler

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

Memory: ✅ 71.546MB (SLO: <75.000MB -4.6%) vs baseline: +4.9%


✅ tracer-dont-create-db-spans

Time: ✅ 19.765ms (SLO: <21.500ms -8.1%) vs baseline: ~same

Memory: ✅ 69.530MB (SLO: <75.000MB -7.3%) vs baseline: +5.1%


✅ tracer-minimal

Time: ✅ 16.837ms (SLO: <17.500ms -3.8%) vs baseline: -0.4%

Memory: ✅ 69.481MB (SLO: <75.000MB -7.4%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 19.675ms (SLO: <21.750ms -9.5%) vs baseline: +0.5%

Memory: ✅ 69.521MB (SLO: <72.500MB -4.1%) vs baseline: +4.9%


✅ tracer-no-caches

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

Memory: ✅ 69.481MB (SLO: <75.000MB -7.4%) vs baseline: +4.9%


✅ tracer-no-databases

Time: ✅ 19.315ms (SLO: <20.100ms -3.9%) vs baseline: ~same

Memory: ✅ 69.462MB (SLO: <75.000MB -7.4%) vs baseline: +4.7%


✅ tracer-no-middleware

Time: ✅ 19.469ms (SLO: <21.500ms -9.4%) vs baseline: +0.3%

Memory: ✅ 69.501MB (SLO: <75.000MB -7.3%) vs baseline: +4.8%


✅ tracer-no-templates

Time: ✅ 19.895ms (SLO: <22.000ms -9.6%) vs baseline: +1.5%

Memory: ✅ 69.520MB (SLO: <73.500MB -5.4%) vs baseline: +4.9%


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 312.814ms (SLO: <320.950ms -2.5%) vs baseline: +0.5%

Memory: ✅ 37.513MB (SLO: <38.750MB -3.2%) vs baseline: +4.7%


✅ deep-profiled

Time: ✅ 329.193ms (SLO: <359.150ms -8.3%) vs baseline: -0.2%

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


✅ medium

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

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


✅ shallow

Time: ✅ 1.025ms (SLO: <1.050ms -2.4%) vs baseline: +1.3%

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


🟡 tracer - 6/6

✅ large

Time: ✅ 31.576ms (SLO: <32.950ms -4.2%) vs baseline: +0.7%

Memory: ✅ 37.906MB (SLO: <39.250MB -3.4%) vs baseline: +4.7%


✅ medium

Time: ✅ 3.154ms (SLO: <3.200ms 🟡 -1.4%) vs baseline: +1.0%

Memory: ✅ 36.294MB (SLO: <38.750MB -6.3%) vs baseline: +4.8%


✅ small

Time: ✅ 361.613µs (SLO: <370.000µs -2.3%) vs baseline: +2.9%

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.610µs (SLO: <20.000µs 📉 -32.0%) vs baseline: -0.3%

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

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

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


⚠️ packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

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

Memory: ✅ 41.415MB (SLO: <46.000MB -10.0%) vs baseline: +5.6%


✅ import_many_cached

Time: ✅ 122.603µs (SLO: <130.000µs -5.7%) vs baseline: +0.6%

Memory: ✅ 41.412MB (SLO: <46.000MB -10.0%) vs baseline: +5.3%


✅ import_many_stdlib

Time: ✅ 0.807ms (SLO: <1.750ms 📉 -53.9%) vs baseline: +0.7%

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


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.188ms (SLO: <1.100ms 📉 -82.9%) vs baseline: +0.7%

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


✅ import_many_unknown

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

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


✅ import_many_unknown_cached

Time: ✅ 792.592µs (SLO: <870.000µs -8.9%) vs baseline: +0.2%

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


✅ import_one

Time: ✅ 20.237µs (SLO: <30.000µs 📉 -32.5%) vs baseline: +1.8%

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


✅ import_one_cache

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

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


✅ import_one_stdlib

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

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


✅ import_one_stdlib_cache

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

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


✅ import_one_unknown

Time: ✅ 45.890µs (SLO: <50.000µs -8.2%) vs baseline: ~same

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


✅ import_one_unknown_cache

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

Memory: ✅ 41.345MB (SLO: <43.000MB -3.8%) vs baseline: +4.9%

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

✅ fork-10

Time: ✅ 2.181s (SLO: <2.300s -5.2%) vs baseline: +2.1%

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


errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

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

Memory: ✅ 69.028MB (SLO: <75.000MB -8.0%) vs baseline: +4.9%


✅ errortracking-enabled-user

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

Memory: ✅ 69.126MB (SLO: <75.000MB -7.8%) vs baseline: +5.0%


✅ tracer-enabled

Time: ✅ 16.434ms (SLO: <19.450ms 📉 -15.5%) vs baseline: -0.4%

Memory: ✅ 69.068MB (SLO: <75.000MB -7.9%) vs baseline: +5.0%


errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.099ms (SLO: <2.300ms -8.7%) vs baseline: +0.2%

Memory: ✅ 56.329MB (SLO: <60.000MB -6.1%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 2.096ms (SLO: <2.250ms -6.8%) vs baseline: +0.1%

Memory: ✅ 56.497MB (SLO: <60.000MB -5.8%) vs baseline: +5.2%


✅ tracer-enabled

Time: ✅ 2.093ms (SLO: <2.300ms -9.0%) vs baseline: +0.2%

Memory: ✅ 56.310MB (SLO: <60.000MB -6.1%) vs baseline: +4.7%


flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.390ms (SLO: <4.750ms 📉 -28.6%) vs baseline: ~same

Memory: ✅ 56.628MB (SLO: <66.500MB 📉 -14.8%) vs baseline: +4.8%


✅ appsec-post

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

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


✅ appsec-telemetry

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

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


✅ debugger

Time: ✅ 1.881ms (SLO: <2.000ms -5.9%) vs baseline: ~same

Memory: ✅ 49.295MB (SLO: <51.500MB -4.3%) vs baseline: +5.0%


✅ iast-get

Time: ✅ 1.874ms (SLO: <2.000ms -6.3%) vs baseline: +0.2%

Memory: ✅ 46.050MB (SLO: <49.000MB -6.0%) vs baseline: +4.8%


✅ profiler

Time: ✅ 1.922ms (SLO: <2.100ms -8.5%) vs baseline: ~same

Memory: ✅ 52.380MB (SLO: <53.500MB -2.1%) vs baseline: +4.7%


✅ resource-renaming

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

Memory: ✅ 56.553MB (SLO: <60.000MB -5.7%) vs baseline: +4.7%


✅ tracer

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

Memory: ✅ 56.669MB (SLO: <60.000MB -5.6%) vs baseline: +5.0%


✅ tracer-native

Time: ✅ 3.350ms (SLO: <3.650ms -8.2%) vs baseline: ~same

Memory: ✅ 56.609MB (SLO: <60.000MB -5.7%) vs baseline: +4.8%


flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.090ms (SLO: <4.200ms 📉 -50.2%) vs baseline: -0.2%

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


✅ iast-enabled

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

Memory: ✅ 56.450MB (SLO: <62.500MB -9.7%) vs baseline: +4.8%


✅ tracer-enabled

Time: ✅ 2.085ms (SLO: <2.250ms -7.3%) vs baseline: -0.2%

Memory: ✅ 56.428MB (SLO: <60.000MB -6.0%) vs baseline: +4.9%


forktime - 4/4

✅ baseline

Time: ✅ 1.941ms (SLO: <3.000ms 📉 -35.3%) vs baseline: +3.4%

Memory: ✅ 29.236MB (SLO: <33.000MB 📉 -11.4%) vs baseline: +4.8%


✅ configured

Time: ✅ 8.813ms (SLO: <13.000ms 📉 -32.2%) vs baseline: +0.2%

Memory: ✅ 56.589MB (SLO: <60.000MB -5.7%) vs baseline: +5.0%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 77.662µs (SLO: <100.000µs 📉 -22.3%) vs baseline: +0.3%

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

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

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 63.833µs (SLO: <80.000µs 📉 -20.2%) vs baseline: +0.5%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.026µs (SLO: <30.000µs -9.9%) vs baseline: -0.3%

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 21.049µs (SLO: <30.000µs 📉 -29.8%) vs baseline: +5.4%

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


✅ with_all

Time: ✅ 27.262µs (SLO: <40.000µs 📉 -31.8%) vs baseline: +1.2%

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


iastpropagation - 8/8

✅ no-propagation

Time: ✅ 48.148µs (SLO: <60.000µs 📉 -19.8%) vs baseline: +0.8%

Memory: ✅ 40.167MB (SLO: <42.000MB -4.4%) vs baseline: +5.0%


✅ propagation_enabled

Time: ✅ 135.960µs (SLO: <190.000µs 📉 -28.4%) vs baseline: -0.4%

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


✅ propagation_enabled_100

Time: ✅ 1.583ms (SLO: <2.300ms 📉 -31.2%) vs baseline: +0.3%

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


✅ propagation_enabled_1000

Time: ✅ 29.429ms (SLO: <34.550ms 📉 -14.8%) vs baseline: +0.6%

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


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.581ms (SLO: <42.000ms -3.4%) vs baseline: -0.1%

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


✅ add-link

Time: ✅ 36.542ms (SLO: <38.550ms -5.2%) vs baseline: -0.4%

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


✅ add-metrics

Time: ✅ 221.888ms (SLO: <232.000ms -4.4%) vs baseline: +0.9%

Memory: ✅ 38.869MB (SLO: <40.750MB -4.6%) vs baseline: +4.0%


✅ add-tags

Time: ✅ 211.863ms (SLO: <221.600ms -4.4%) vs baseline: ~same

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


✅ get-context

Time: ✅ 29.043ms (SLO: <31.300ms -7.2%) vs baseline: -1.3%

Memory: ✅ 38.948MB (SLO: <40.750MB -4.4%) vs baseline: +4.5%


✅ is-recording

Time: ✅ 29.232ms (SLO: <31.000ms -5.7%) vs baseline: +0.3%

Memory: ✅ 38.810MB (SLO: <40.750MB -4.8%) vs baseline: +4.3%


✅ record-exception

Time: ✅ 63.497ms (SLO: <65.850ms -3.6%) vs baseline: -0.1%

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


✅ set-status

Time: ✅ 32.164ms (SLO: <34.150ms -5.8%) vs baseline: +0.5%

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


✅ start

Time: ✅ 29.216ms (SLO: <30.150ms -3.1%) vs baseline: +1.2%

Memory: ✅ 38.968MB (SLO: <40.750MB -4.4%) vs baseline: +4.5%


✅ start-finish

Time: ✅ 34.220ms (SLO: <35.350ms -3.2%) vs baseline: +0.6%

Memory: ✅ 38.987MB (SLO: <40.750MB -4.3%) vs baseline: +4.4%


✅ start-finish-telemetry

Time: ✅ 34.244ms (SLO: <35.450ms -3.4%) vs baseline: +0.5%

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


✅ update-name

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

Memory: ✅ 38.968MB (SLO: <40.750MB -4.4%) vs baseline: +4.6%


otelspan - 22/22

✅ add-event

Time: ✅ 38.281ms (SLO: <47.150ms 📉 -18.8%) vs baseline: -0.5%

Memory: ✅ 41.387MB (SLO: <47.000MB 📉 -11.9%) vs baseline: +5.2%


✅ add-metrics

Time: ✅ 234.443ms (SLO: <344.800ms 📉 -32.0%) vs baseline: -0.2%

Memory: ✅ 45.881MB (SLO: <47.500MB -3.4%) vs baseline: +5.2%


✅ add-tags

Time: ✅ 269.368ms (SLO: <330.000ms 📉 -18.4%) vs baseline: -0.4%

Memory: ✅ 45.782MB (SLO: <47.500MB -3.6%) vs baseline: +4.7%


✅ get-context

Time: ✅ 80.978ms (SLO: <92.350ms 📉 -12.3%) vs baseline: -0.3%

Memory: ✅ 41.622MB (SLO: <46.500MB 📉 -10.5%) vs baseline: +5.1%


✅ is-recording

Time: ✅ 36.583ms (SLO: <44.500ms 📉 -17.8%) vs baseline: -0.3%

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


✅ record-exception

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

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


✅ set-status

Time: ✅ 42.750ms (SLO: <50.400ms 📉 -15.2%) vs baseline: -0.2%

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


✅ start

Time: ✅ 37.350ms (SLO: <43.450ms 📉 -14.0%) vs baseline: +2.9%

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


✅ start-finish

Time: ✅ 85.560ms (SLO: <90.000ms -4.9%) vs baseline: +0.2%

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


✅ start-finish-telemetry

Time: ✅ 86.949ms (SLO: <91.000ms -4.5%) vs baseline: -0.3%

Memory: ✅ 38.889MB (SLO: <46.500MB 📉 -16.4%) vs baseline: +5.1%


✅ update-name

Time: ✅ 37.711ms (SLO: <45.150ms 📉 -16.5%) vs baseline: -0.3%

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 344.060ms (SLO: <354.300ms -2.9%) vs baseline: ~same

Memory: ✅ 42.405MB (SLO: <46.000MB -7.8%) vs baseline: +5.2%


✅ cache_on

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

Memory: ✅ 40.831MB (SLO: <46.000MB 📉 -11.2%) vs baseline: +5.2%


rand - 2/2

✅ rand128bits

Time: ✅ 0.181µs (SLO: <21.000µs 📉 -99.1%) vs baseline: -1.2%


✅ rand64bits

Time: ✅ 0.123µs (SLO: <15.000µs 📉 -99.2%) vs baseline: +0.4%


ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

Memory: ✅ 36.707MB (SLO: <38.000MB -3.4%) vs baseline: +5.1%


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


samplingrules - 8/8

✅ average_match

Time: ✅ 149.641µs (SLO: <290.000µs 📉 -48.4%) vs baseline: +0.1%

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


✅ high_match

Time: ✅ 198.756µs (SLO: <480.000µs 📉 -58.6%) vs baseline: +1.1%

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


✅ low_match

Time: ✅ 99.617µs (SLO: <120.000µs 📉 -17.0%) vs baseline: -0.3%

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


✅ very_low_match

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

Memory: ✅ 78.873MB (SLO: <85.000MB -7.2%) vs baseline: +4.8%


sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

Time: ✅ 39.738µs (SLO: <50.000µs 📉 -20.5%) vs baseline: +1.6%

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


✅ collectipvariant_exists

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

Memory: ✅ 37.120MB (SLO: <38.750MB -4.2%) vs baseline: +4.7%


✅ no-collectipvariant

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

Memory: ✅ 37.336MB (SLO: <38.750MB -3.6%) vs baseline: +5.5%


✅ no-useragentvariant

Time: ✅ 37.809µs (SLO: <50.000µs 📉 -24.4%) vs baseline: -0.3%

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


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 37.532MB (SLO: <38.750MB -3.1%) vs baseline: +4.7%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 75.967µs (SLO: <90.000µs 📉 -15.6%) vs baseline: -0.7%

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


✅ obfuscation-send-querystring-disabled

Time: ✅ 154.219µs (SLO: <170.000µs -9.3%) vs baseline: -0.3%

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


✅ obfuscation-worst-case-explicit-query

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

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


✅ obfuscation-worst-case-implicit-query

Time: ✅ 154.967µs (SLO: <170.000µs -8.8%) vs baseline: -0.4%

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


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

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


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 86.198ms (SLO: <93.500ms -7.8%) vs baseline: -1.0%

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


✅ add-tags

Time: ✅ 146.532ms (SLO: <155.000ms -5.5%) vs baseline: +1.0%

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


✅ get-context

Time: ✅ 16.962ms (SLO: <20.500ms 📉 -17.3%) vs baseline: +0.7%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.364ms (SLO: <41.000ms 📉 -11.3%) vs baseline: ~same

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


✅ set-status

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

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


✅ start

Time: ✅ 17.590ms (SLO: <20.500ms 📉 -14.2%) vs baseline: +3.9%

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


✅ start-finish

Time: ✅ 54.361ms (SLO: <56.000ms -2.9%) vs baseline: -0.4%

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


✅ start-finish-telemetry

Time: ✅ 55.759ms (SLO: <58.000ms -3.9%) vs baseline: ~same

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


✅ start-finish-traceid128

Time: ✅ 56.965ms (SLO: <60.000ms -5.1%) vs baseline: ~same

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


✅ start-traceid128

Time: ✅ 16.982ms (SLO: <22.500ms 📉 -24.5%) vs baseline: +0.4%

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


✅ update-name

Time: ✅ 17.508ms (SLO: <22.000ms 📉 -20.4%) vs baseline: +0.2%

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


telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 2.364µs (SLO: <20.000µs 📉 -88.2%) vs baseline: +8.1%

Memory: ✅ 36.215MB (SLO: <38.000MB -4.7%) vs baseline: +4.9%


✅ 1-count-metrics-100-times

Time: ✅ 153.762µs (SLO: <220.000µs 📉 -30.1%) vs baseline: -0.2%

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 166.051µs (SLO: <230.000µs 📉 -27.8%) vs baseline: -0.2%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 138.106µs (SLO: <150.000µs -7.9%) vs baseline: +0.5%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 169.192µs (SLO: <250.000µs 📉 -32.3%) vs baseline: +0.3%

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


✅ 100-count-metrics-100-times

Time: ✅ 15.510ms (SLO: <22.000ms 📉 -29.5%) vs baseline: +1.1%

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


✅ 100-distribution-metrics-100-times

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

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


✅ 100-gauge-metrics-100-times

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

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


✅ 100-rate-metrics-100-times

Time: ✅ 1.753ms (SLO: <2.550ms 📉 -31.3%) vs baseline: -1.2%

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


✅ flush-1-metric

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

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


✅ flush-100-metrics

Time: ✅ 178.398µs (SLO: <250.000µs 📉 -28.6%) vs baseline: +0.5%

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


✅ flush-1000-metrics

Time: ✅ 2.225ms (SLO: <2.500ms 📉 -11.0%) vs baseline: -0.2%

Memory: ✅ 37.061MB (SLO: <38.750MB -4.4%) vs baseline: +4.7%

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

Copy link
Copy Markdown
Contributor

@rithikanarayan rithikanarayan left a comment

Choose a reason for hiding this comment

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

LGTM from serverless side

@avara1986
Copy link
Copy Markdown
Member Author

/merge

@gh-worker-devflow-routing-ef8351
Copy link
Copy Markdown

gh-worker-devflow-routing-ef8351 bot commented Apr 7, 2026

View all feedbacks in Devflow UI.

2026-04-07 07:41:02 UTC ℹ️ Start processing command /merge


2026-04-07 07:41:07 UTC ℹ️ MergeQueue: pull request added to the queue

The expected merge time in main is approximately 57m (p90).


2026-04-07 08:31:34 UTCMergeQueue: This merge request is not mergeable, blocked by github

PR can't be merged according to github policy

…race-to-shared

# Conflicts:
#	ddtrace/appsec/_iast/taint_sinks/_base.py
#	tests/appsec/architectures/test_appsec_loading_modules.py
@datadog-datadog-prod-us1
Copy link
Copy Markdown
Contributor

datadog-datadog-prod-us1 bot commented Apr 7, 2026

✅ Tests

🎉 All green!

❄️ No new flaky tests detected
🧪 All tests passed

This comment will be updated automatically if new data arrives.
🔗 Commit SHA: 4b145d0 | Docs | Datadog PR Page | Was this helpful? React with 👍/👎 or give us feedback!

@avara1986
Copy link
Copy Markdown
Member Author

/merge

@gh-worker-devflow-routing-ef8351
Copy link
Copy Markdown

gh-worker-devflow-routing-ef8351 bot commented Apr 7, 2026

View all feedbacks in Devflow UI.

2026-04-07 12:44:37 UTC ℹ️ Start processing command /merge


2026-04-07 12:44:41 UTC ℹ️ MergeQueue: pull request added to the queue

The expected merge time in main is approximately 56m (p90).


2026-04-07 13:35:36 UTC ℹ️ MergeQueue: This merge request was merged

@gh-worker-dd-mergequeue-cf854d gh-worker-dd-mergequeue-cf854d bot merged commit 78a8fa3 into main Apr 7, 2026
1111 checks passed
@gh-worker-dd-mergequeue-cf854d gh-worker-dd-mergequeue-cf854d bot deleted the avara1986/move-stacktrace-to-shared branch April 7, 2026 13:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

ASM Application Security Monitoring 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.

5 participants