Skip to content

Conversation

@christophe-papazian
Copy link
Contributor

@christophe-papazian christophe-papazian commented Nov 6, 2025

Description

  • remove appsec/iast references from non appsec/iast tests when it's not useful
  • ensuring appsec tests are in files clearly identified as owned by appsec team.
  • move appsec related tests from non appsec files to appsec files (rarely duplicate a test, with/without appsec)
  • add asm ownership to clearly identify tests files containing appsec/iast tests for mixed test files.

Basically, making sure we are accountable for ASM/AAP.

This PR will be followed by another one on the same topic (to not create huge PR)

APPSEC-59813

@christophe-papazian christophe-papazian added changelog/no-changelog A changelog entry is not required for this PR. ASM Application Security Monitoring labels Nov 6, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Nov 6, 2025

CODEOWNERS have been resolved as:

tests/tracer/test_tracer_appsec.py                                      @DataDog/asm-python
.github/CODEOWNERS                                                      @DataDog/python-guild @DataDog/apm-core-python
tests/integration/test_integration_snapshots.py                         @DataDog/apm-core-python
tests/tracer/test_endpoint_config.py                                    @DataDog/apm-sdk-capabilities-python
tests/tracer/test_processors.py                                         @DataDog/apm-sdk-capabilities-python
tests/tracer/test_trace_utils.py                                        @DataDog/apm-sdk-capabilities-python
tests/tracer/test_tracer.py                                             @DataDog/apm-sdk-capabilities-python
tests/internal/remoteconfig/test_remoteconfig_appsec_client.py          @DataDog/asm-python
tests/internal/remoteconfig/test_remoteconfig_appsec_client_e2e.py      @DataDog/asm-python

@github-actions
Copy link
Contributor

github-actions bot commented Nov 6, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

The average import time from this PR is: 254 ± 8 ms.

The average import time from base is: 256 ± 5 ms.

The import time difference between this PR and base is: -2.0 ± 0.3 ms.

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.210 ms (0.87%)
ddtrace.bootstrap.sitecustomize 1.469 ms (0.58%)
ddtrace.bootstrap.preload 1.469 ms (0.58%)
ddtrace.internal.remoteconfig.client 0.738 ms (0.29%)
ddtrace 0.740 ms (0.29%)
ddtrace.internal._unpatched 0.036 ms (0.01%)
json 0.036 ms (0.01%)
json.decoder 0.036 ms (0.01%)
re 0.036 ms (0.01%)
enum 0.036 ms (0.01%)
types 0.036 ms (0.01%)

@pr-commenter
Copy link

pr-commenter bot commented Nov 6, 2025

Performance SLOs

Comparing candidate christophe-papazian/put_appsec_tests_in_their_own_files (fab55bc) with baseline main (10e34b3)

❌ Test Failures (1 suite)
otelspan - 21/22

✅ add-event

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

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


✅ add-metrics

Time: ✅ 258.489ms (SLO: <344.800ms 📉 -25.0%) vs baseline: -0.2%

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


❌ add-tags

Time: ❌ 316.150ms (SLO: <314.000ms +0.7%) vs baseline: +0.8%

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


✅ get-context

Time: ✅ 79.015ms (SLO: <92.350ms 📉 -14.4%) vs baseline: +0.2%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 56.512ms (SLO: <67.650ms 📉 -16.5%) vs baseline: -0.6%

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


✅ set-status

Time: ✅ 42.630ms (SLO: <50.400ms 📉 -15.4%) vs baseline: -0.2%

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


✅ start

Time: ✅ 35.524ms (SLO: <43.450ms 📉 -18.2%) vs baseline: +0.2%

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


✅ start-finish

Time: ✅ 81.771ms (SLO: <88.000ms -7.1%) vs baseline: +0.3%

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


✅ start-finish-telemetry

Time: ✅ 83.377ms (SLO: <89.000ms -6.3%) vs baseline: +0.5%

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


✅ update-name

Time: ✅ 37.016ms (SLO: <45.150ms 📉 -18.0%) vs baseline: -0.1%

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

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

✅ add_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ add_inplace_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.8%


✅ add_inplace_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.7%


✅ add_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ bytearray_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ bytearray_extend_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +5.2%


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ bytes_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.4%


✅ bytes_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ bytesio_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ bytesio_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ capitalize_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ capitalize_noaspect

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

Memory: ✅ 37.297MB (SLO: <39.000MB -4.4%) vs baseline: +4.9%


✅ casefold_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ casefold_noaspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.1%


✅ decode_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ decode_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ encode_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ encode_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ format_aspect

Time: ✅ 3.560µs (SLO: <10.000µs 📉 -64.4%) vs baseline: +4.4%

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.8%


✅ format_map_aspect

Time: ✅ 4.065µs (SLO: <10.000µs 📉 -59.3%) vs baseline: 📈 +12.9%

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.1%


✅ format_map_noaspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +4.8%


✅ format_noaspect

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

Memory: ✅ 37.179MB (SLO: <39.000MB -4.7%) vs baseline: +4.8%


✅ index_aspect

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

Memory: ✅ 37.297MB (SLO: <39.000MB -4.4%) vs baseline: +4.8%


✅ index_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ join_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ join_noaspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ ljust_aspect

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

Memory: ✅ 37.139MB (SLO: <39.000MB -4.8%) vs baseline: +4.6%


✅ ljust_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +5.1%


✅ lower_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ lower_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ lstrip_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.5%


✅ lstrip_noaspect

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

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


✅ modulo_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.7%


✅ modulo_aspect_for_bytes

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ modulo_noaspect

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

Memory: ✅ 37.297MB (SLO: <39.000MB -4.4%) vs baseline: +4.9%


✅ replace_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.5%


✅ replace_noaspect

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

Memory: ✅ 37.356MB (SLO: <39.000MB -4.2%) vs baseline: +5.0%


✅ repr_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ repr_noaspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ rstrip_aspect

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

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


✅ rstrip_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ slice_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.8%


✅ slice_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ stringio_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ stringio_noaspect

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

Memory: ✅ 37.297MB (SLO: <39.000MB -4.4%) vs baseline: +5.1%


✅ strip_aspect

Time: ✅ 2.519µs (SLO: <20.000µs 📉 -87.4%) vs baseline: 📈 +13.2%

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ strip_noaspect

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

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


✅ swapcase_aspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +4.9%


✅ swapcase_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ title_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ title_noaspect

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

Memory: ✅ 37.316MB (SLO: <39.000MB -4.3%) vs baseline: +5.1%


✅ translate_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.8%


✅ translate_noaspect

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

Memory: ✅ 37.356MB (SLO: <39.000MB -4.2%) vs baseline: +5.0%


✅ upper_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.8%


✅ upper_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +4.9%


✅ ospathbasename_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ ospathjoin_aspect

Time: ✅ 6.918µs (SLO: <10.000µs 📉 -30.8%) vs baseline: 📈 +12.7%

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.7%


✅ ospathjoin_noaspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +5.1%


✅ ospathnormcase_aspect

Time: ✅ 3.834µs (SLO: <10.000µs 📉 -61.7%) vs baseline: 📈 +11.3%

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%


✅ ospathnormcase_noaspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ ospathsplit_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.1%


✅ ospathsplit_noaspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 37.179MB (SLO: <39.000MB -4.7%) vs baseline: +4.6%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ ospathsplitext_aspect

Time: ✅ 4.588µs (SLO: <10.000µs 📉 -54.1%) vs baseline: +3.0%

Memory: ✅ 37.297MB (SLO: <39.000MB -4.4%) vs baseline: +5.3%


✅ ospathsplitext_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.9%

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

✅ appsec

Time: ✅ 19.271ms (SLO: <22.300ms 📉 -13.6%) vs baseline: -0.2%

Memory: ✅ 66.057MB (SLO: <67.000MB 🟡 -1.4%) vs baseline: +5.0%


✅ exception-replay-enabled

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

Memory: ✅ 64.068MB (SLO: <67.000MB -4.4%) vs baseline: +4.8%


✅ iast

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

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


✅ profiler

Time: ✅ 15.402ms (SLO: <16.550ms -6.9%) vs baseline: +0.3%

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


✅ resource-renaming

Time: ✅ 19.355ms (SLO: <21.750ms 📉 -11.0%) vs baseline: +0.5%

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


✅ span-code-origin

Time: ✅ 22.839ms (SLO: <28.200ms 📉 -19.0%) vs baseline: -0.2%

Memory: ✅ 66.996MB (SLO: <69.500MB -3.6%) vs baseline: +4.5%


✅ tracer

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

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


✅ tracer-and-profiler

Time: ✅ 21.258ms (SLO: <23.500ms -9.5%) vs baseline: +0.3%

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


✅ tracer-dont-create-db-spans

Time: ✅ 19.260ms (SLO: <21.500ms 📉 -10.4%) vs baseline: -0.6%

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


✅ tracer-minimal

Time: ✅ 16.714ms (SLO: <17.500ms -4.5%) vs baseline: +0.6%

Memory: ✅ 65.858MB (SLO: <67.000MB 🟡 -1.7%) vs baseline: +4.5%


✅ tracer-native

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

Memory: ✅ 67.594MB (SLO: <72.500MB -6.8%) vs baseline: +4.9%


✅ tracer-no-caches

Time: ✅ 17.325ms (SLO: <19.650ms 📉 -11.8%) vs baseline: +0.2%

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


✅ tracer-no-databases

Time: ✅ 18.741ms (SLO: <20.100ms -6.8%) vs baseline: +0.1%

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


✅ tracer-no-middleware

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

Memory: ✅ 65.860MB (SLO: <67.000MB 🟡 -1.7%) vs baseline: +4.7%


✅ tracer-no-templates

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

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.591ms (SLO: <19.850ms 📉 -16.4%) vs baseline: +1.7%

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

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

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.075ms (SLO: <2.300ms -9.8%) vs baseline: +0.4%

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


✅ errortracking-enabled-user

Time: ✅ 2.077ms (SLO: <2.250ms -7.7%) vs baseline: +0.6%

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


✅ tracer-enabled

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

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


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 4.592ms (SLO: <4.750ms -3.3%) vs baseline: -0.3%

Memory: ✅ 62.089MB (SLO: <65.000MB -4.5%) vs baseline: +5.0%


✅ appsec-post

Time: ✅ 6.612ms (SLO: <6.750ms -2.0%) vs baseline: -0.3%

Memory: ✅ 62.169MB (SLO: <65.000MB -4.4%) vs baseline: +5.0%


✅ appsec-telemetry

Time: ✅ 4.587ms (SLO: <4.750ms -3.4%) vs baseline: -0.4%

Memory: ✅ 61.976MB (SLO: <65.000MB -4.7%) vs baseline: +4.9%


✅ debugger

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

Memory: ✅ 45.246MB (SLO: <47.000MB -3.7%) vs baseline: +5.0%


✅ iast-get

Time: ✅ 1.859ms (SLO: <2.000ms -7.0%) vs baseline: -0.4%

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


✅ profiler

Time: ✅ 1.912ms (SLO: <2.100ms -9.0%) vs baseline: -0.3%

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


✅ resource-renaming

Time: ✅ 3.375ms (SLO: <3.650ms -7.5%) vs baseline: -0.4%

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


✅ tracer

Time: ✅ 3.359ms (SLO: <3.650ms -8.0%) vs baseline: -0.5%

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


✅ tracer-native

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

Memory: ✅ 54.001MB (SLO: <60.000MB -10.0%) vs baseline: +4.8%


🟡 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.382µs (SLO: <20.000µs 📉 -83.1%) vs baseline: +9.0%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.8%


✅ 1-count-metrics-100-times

Time: ✅ 206.391µs (SLO: <220.000µs -6.2%) vs baseline: +1.0%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.8%


✅ 1-distribution-metric-1-times

Time: ✅ 3.359µs (SLO: <20.000µs 📉 -83.2%) vs baseline: -2.5%

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ 1-distribution-metrics-100-times

Time: ✅ 217.573µs (SLO: <220.000µs 🟡 -1.1%) vs baseline: -0.7%

Memory: ✅ 31.575MB (SLO: <34.000MB -7.1%) vs baseline: +4.9%


✅ 1-gauge-metric-1-times

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

Memory: ✅ 31.615MB (SLO: <34.000MB -7.0%) vs baseline: +5.2%


✅ 1-gauge-metrics-100-times

Time: ✅ 136.573µs (SLO: <150.000µs -9.0%) vs baseline: -0.8%

Memory: ✅ 31.497MB (SLO: <34.000MB -7.4%) vs baseline: +4.8%


✅ 1-rate-metric-1-times

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

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.8%


✅ 1-rate-metrics-100-times

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

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ 100-count-metrics-100-times

Time: ✅ 20.143ms (SLO: <22.000ms -8.4%) vs baseline: -1.3%

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.269ms (SLO: <2.300ms 🟡 -1.3%) vs baseline: +1.4%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +5.1%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.413ms (SLO: <1.550ms -8.9%) vs baseline: +0.6%

Memory: ✅ 31.615MB (SLO: <34.000MB -7.0%) vs baseline: +5.3%


✅ 100-rate-metrics-100-times

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

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +5.0%


✅ flush-1-metric

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ flush-100-metrics

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

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.7%


✅ flush-1000-metrics

Time: ✅ 2.137ms (SLO: <2.500ms 📉 -14.5%) vs baseline: +0.3%

Memory: ✅ 32.676MB (SLO: <34.500MB -5.3%) vs baseline: +4.7%

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

⚠️ context_with_data_listeners

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

Memory: ✅ 31.516MB (SLO: <33.500MB -5.9%) vs baseline: +4.6%


✅ context_with_data_no_listeners

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +5.1%


✅ get_item_exists

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

Memory: ✅ 31.477MB (SLO: <33.500MB -6.0%) vs baseline: +4.8%


✅ get_item_missing

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

Memory: ✅ 31.477MB (SLO: <33.500MB -6.0%) vs baseline: +4.5%


✅ set_item

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

Memory: ✅ 31.497MB (SLO: <33.500MB -6.0%) vs baseline: +4.8%

✅ All Tests Passing (14 suites)
flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 3.949ms (SLO: <4.200ms -6.0%) vs baseline: -0.5%

Memory: ✅ 62.344MB (SLO: <66.000MB -5.5%) vs baseline: +5.1%


✅ iast-enabled

Time: ✅ 2.434ms (SLO: <2.800ms 📉 -13.1%) vs baseline: +0.6%

Memory: ✅ 58.393MB (SLO: <60.000MB -2.7%) vs baseline: +4.5%


✅ tracer-enabled

Time: ✅ 2.063ms (SLO: <2.250ms -8.3%) vs baseline: ~same

Memory: ✅ 52.670MB (SLO: <54.500MB -3.4%) vs baseline: +4.8%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.444µs (SLO: <100.000µs 📉 -18.6%) vs baseline: +1.3%

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +5.0%


✅ b3_headers

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


✅ b3_single_headers

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +4.7%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 64.370µs (SLO: <80.000µs 📉 -19.5%) vs baseline: +1.3%

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.7%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.964µs (SLO: <80.000µs 📉 -16.3%) vs baseline: +2.2%

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +4.9%


✅ empty_headers

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


✅ full_t_id_datadog_headers

Time: ✅ 22.985µs (SLO: <30.000µs 📉 -23.4%) vs baseline: +2.1%

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.7%


✅ invalid_priority_header

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +5.1%


✅ invalid_span_id_header

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.7%


✅ invalid_tags_header

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

Memory: ✅ 31.556MB (SLO: <33.500MB -5.8%) vs baseline: +4.7%


✅ invalid_trace_id_header

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +5.1%


✅ large_header_no_matches

Time: ✅ 27.650µs (SLO: <30.000µs -7.8%) vs baseline: +0.4%

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +5.0%


✅ large_valid_headers_all

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

Memory: ✅ 31.674MB (SLO: <33.500MB -5.5%) vs baseline: +4.8%


✅ medium_header_no_matches

Time: ✅ 9.826µs (SLO: <20.000µs 📉 -50.9%) vs baseline: -0.8%

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +5.0%


✅ medium_valid_headers_all

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.9%


✅ none_propagation_style

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

Memory: ✅ 31.634MB (SLO: <33.500MB -5.6%) vs baseline: +4.9%


✅ tracecontext_headers

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

Memory: ✅ 31.634MB (SLO: <33.500MB -5.6%) vs baseline: +5.1%


✅ valid_headers_all

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +4.8%


✅ valid_headers_basic

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


✅ wsgi_empty_headers

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.7%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 31.536MB (SLO: <33.500MB -5.9%) vs baseline: +4.7%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +5.0%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 31.654MB (SLO: <33.500MB -5.5%) vs baseline: +5.0%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 31.634MB (SLO: <33.500MB -5.6%) vs baseline: +5.2%


✅ wsgi_large_header_no_matches

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.9%


✅ wsgi_large_valid_headers_all

Time: ✅ 30.038µs (SLO: <40.000µs 📉 -24.9%) vs baseline: +1.1%

Memory: ✅ 31.654MB (SLO: <33.500MB -5.5%) vs baseline: +5.0%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


✅ wsgi_medium_valid_headers_all

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

Memory: ✅ 31.556MB (SLO: <33.500MB -5.8%) vs baseline: +4.7%


✅ wsgi_valid_headers_all

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +5.1%


✅ wsgi_valid_headers_basic

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


httppropagationinject - 16/16

✅ ids_only

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

Memory: ✅ 31.634MB (SLO: <33.500MB -5.6%) vs baseline: +5.0%


✅ with_all

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +4.7%


✅ with_dd_origin

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

Memory: ✅ 31.516MB (SLO: <33.500MB -5.9%) vs baseline: +4.5%


✅ with_priority_and_origin

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.8%


✅ with_sampling_priority

Time: ✅ 21.317µs (SLO: <30.000µs 📉 -28.9%) vs baseline: +3.0%

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +4.9%


✅ with_tags

Time: ✅ 25.765µs (SLO: <40.000µs 📉 -35.6%) vs baseline: +0.6%

Memory: ✅ 31.654MB (SLO: <33.500MB -5.5%) vs baseline: +4.9%


✅ with_tags_invalid

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +4.7%


✅ with_tags_max_size

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +5.1%


iast_aspects - 40/40

✅ re_expand_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ re_expand_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.0%


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

Memory: ✅ 36.864MB (SLO: <39.000MB -5.5%) vs baseline: +4.0%


✅ re_finditer_aspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +4.8%


✅ re_finditer_noaspect

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

Memory: ✅ 36.825MB (SLO: <39.000MB -5.6%) vs baseline: +3.9%


✅ re_fullmatch_aspect

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

Memory: ✅ 37.198MB (SLO: <39.000MB -4.6%) vs baseline: +4.7%


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +5.1%


✅ re_group_noaspect

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

Memory: ✅ 37.336MB (SLO: <39.000MB -4.3%) vs baseline: +5.7%


✅ re_groups_aspect

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ re_groups_noaspect

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

Memory: ✅ 37.041MB (SLO: <39.000MB -5.0%) vs baseline: +4.7%


✅ re_match_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.7%


✅ re_match_noaspect

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

Memory: ✅ 37.080MB (SLO: <39.000MB -4.9%) vs baseline: +4.2%


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

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

Memory: ✅ 37.257MB (SLO: <39.000MB -4.5%) vs baseline: +4.6%


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +4.9%


✅ re_subn_noaspect

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

Memory: ✅ 37.238MB (SLO: <39.000MB -4.5%) vs baseline: +5.6%


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 37.159MB (SLO: <39.000MB -4.7%) vs baseline: +5.8%


✅ rsplit_noaspect

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

Memory: ✅ 37.120MB (SLO: <39.000MB -4.8%) vs baseline: +4.5%


✅ split_aspect

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

Memory: ✅ 37.080MB (SLO: <39.000MB -4.9%) vs baseline: +5.1%


✅ split_noaspect

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

Memory: ✅ 37.041MB (SLO: <39.000MB -5.0%) vs baseline: +4.2%


✅ splitlines_aspect

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

Memory: ✅ 37.277MB (SLO: <39.000MB -4.4%) vs baseline: +6.2%


✅ splitlines_noaspect

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

Memory: ✅ 36.903MB (SLO: <39.000MB -5.4%) vs baseline: +4.4%


iastpropagation - 2/2

✅ no-propagation

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

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


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.520ms (SLO: <42.000ms -3.5%) vs baseline: -0.2%

Memory: ✅ 34.406MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +4.9%


✅ add-link

Time: ✅ 36.787ms (SLO: <38.550ms -4.6%) vs baseline: +1.3%

Memory: ✅ 34.446MB (SLO: <39.000MB 📉 -11.7%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 219.541ms (SLO: <232.000ms -5.4%) vs baseline: -1.0%

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 212.637ms (SLO: <221.600ms -4.0%) vs baseline: +1.1%

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.6%


✅ get-context

Time: ✅ 29.266ms (SLO: <31.300ms -6.5%) vs baseline: +0.7%

Memory: ✅ 34.308MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.8%


✅ is-recording

Time: ✅ 29.127ms (SLO: <31.000ms -6.0%) vs baseline: +0.3%

Memory: ✅ 34.406MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 64.081ms (SLO: <65.850ms -2.7%) vs baseline: +1.5%

Memory: ✅ 34.308MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.5%


✅ set-status

Time: ✅ 32.028ms (SLO: <34.150ms -6.2%) vs baseline: -0.3%

Memory: ✅ 34.465MB (SLO: <39.000MB 📉 -11.6%) vs baseline: +5.2%


✅ start

Time: ✅ 28.839ms (SLO: <30.150ms -4.3%) vs baseline: +0.5%

Memory: ✅ 34.367MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


✅ start-finish

Time: ✅ 33.988ms (SLO: <35.350ms -3.9%) vs baseline: +0.3%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


✅ start-finish-telemetry

Time: ✅ 34.427ms (SLO: <35.450ms -2.9%) vs baseline: +1.1%

Memory: ✅ 34.367MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.0%


✅ update-name

Time: ✅ 31.484ms (SLO: <33.400ms -5.7%) vs baseline: +1.5%

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.6%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 338.047ms (SLO: <354.300ms -4.6%) vs baseline: -1.1%

Memory: ✅ 37.866MB (SLO: <40.000MB -5.3%) vs baseline: +4.9%


✅ cache_on

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

Memory: ✅ 37.276MB (SLO: <39.000MB -4.4%) vs baseline: +5.1%


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 154.848µs (SLO: <170.000µs -8.9%) vs baseline: -0.1%

Memory: ✅ 36.378MB (SLO: <38.500MB -5.5%) vs baseline: +5.0%


✅ import_many_cached

Time: ✅ 121.011µs (SLO: <130.000µs -6.9%) vs baseline: -0.2%

Memory: ✅ 36.517MB (SLO: <38.500MB -5.1%) vs baseline: +5.5%


✅ import_many_stdlib

Time: ✅ 1.634ms (SLO: <1.750ms -6.7%) vs baseline: -0.8%

Memory: ✅ 36.558MB (SLO: <38.500MB -5.0%) vs baseline: +5.0%


✅ import_many_stdlib_cached

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

Memory: ✅ 36.775MB (SLO: <38.500MB -4.5%) vs baseline: +5.9%


✅ import_many_unknown

Time: ✅ 833.237µs (SLO: <890.000µs -6.4%) vs baseline: -0.5%

Memory: ✅ 36.258MB (SLO: <38.500MB -5.8%) vs baseline: +4.4%


✅ import_many_unknown_cached

Time: ✅ 796.487µs (SLO: <870.000µs -8.4%) vs baseline: +0.5%

Memory: ✅ 36.423MB (SLO: <38.500MB -5.4%) vs baseline: +5.0%


✅ import_one

Time: ✅ 19.782µs (SLO: <30.000µs 📉 -34.1%) vs baseline: -0.3%

Memory: ✅ 36.343MB (SLO: <39.000MB -6.8%) vs baseline: +5.0%


✅ import_one_cache

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

Memory: ✅ 36.461MB (SLO: <38.500MB -5.3%) vs baseline: +5.6%


✅ import_one_stdlib

Time: ✅ 18.742µs (SLO: <20.000µs -6.3%) vs baseline: +0.2%

Memory: ✅ 36.504MB (SLO: <38.500MB -5.2%) vs baseline: +5.5%


✅ import_one_stdlib_cache

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

Memory: ✅ 36.335MB (SLO: <38.500MB -5.6%) vs baseline: +4.8%


✅ import_one_unknown

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

Memory: ✅ 36.411MB (SLO: <38.500MB -5.4%) vs baseline: +5.0%


✅ import_one_unknown_cache

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

Memory: ✅ 36.321MB (SLO: <38.500MB -5.7%) vs baseline: +5.0%


ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.7%


✅ high_rate_limit

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +5.1%


✅ long_window

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.7%


✅ low_rate_limit

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.7%


✅ no_rate_limit

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

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.9%


✅ short_window

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

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.9%


recursivecomputation - 8/8

✅ deep

Time: ✅ 308.040ms (SLO: <320.950ms -4.0%) vs baseline: ~same

Memory: ✅ 32.676MB (SLO: <34.500MB -5.3%) vs baseline: +4.8%


✅ deep-profiled

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

Memory: ✅ 37.218MB (SLO: <39.000MB -4.6%) vs baseline: +4.9%


✅ medium

Time: ✅ 6.900ms (SLO: <7.400ms -6.8%) vs baseline: -0.3%

Memory: ✅ 31.497MB (SLO: <34.000MB -7.4%) vs baseline: +4.9%


✅ shallow

Time: ✅ 0.916ms (SLO: <1.050ms 📉 -12.7%) vs baseline: -0.8%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.8%


samplingrules - 8/8

✅ average_match

Time: ✅ 137.225µs (SLO: <290.000µs 📉 -52.7%) vs baseline: -0.2%

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ high_match

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

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.8%


✅ low_match

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

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


✅ very_low_match

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

Memory: ✅ 67.930MB (SLO: <75.000MB -9.4%) vs baseline: +5.1%


span - 26/26

✅ add-event

Time: ✅ 17.426ms (SLO: <22.500ms 📉 -22.6%) vs baseline: +1.2%

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


✅ add-metrics

Time: ✅ 89.127ms (SLO: <93.500ms -4.7%) vs baseline: ~same

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


✅ add-tags

Time: ✅ 142.346ms (SLO: <155.000ms -8.2%) vs baseline: -0.6%

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


✅ get-context

Time: ✅ 16.340ms (SLO: <20.500ms 📉 -20.3%) vs baseline: +1.7%

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


✅ is-recording

Time: ✅ 16.535ms (SLO: <20.500ms 📉 -19.3%) vs baseline: +1.0%

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


✅ record-exception

Time: ✅ 36.011ms (SLO: <40.000ms -10.0%) vs baseline: +1.9%

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


✅ set-status

Time: ✅ 17.983ms (SLO: <22.000ms 📉 -18.3%) vs baseline: +1.6%

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


✅ start

Time: ✅ 16.092ms (SLO: <20.500ms 📉 -21.5%) vs baseline: +0.9%

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


✅ start-finish

Time: ✅ 50.983ms (SLO: <52.500ms -2.9%) vs baseline: +0.4%

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ start-finish-telemetry

Time: ✅ 52.221ms (SLO: <54.500ms -4.2%) vs baseline: -0.4%

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 53.723ms (SLO: <57.000ms -5.7%) vs baseline: -0.1%

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ start-traceid128

Time: ✅ 16.630ms (SLO: <22.500ms 📉 -26.1%) vs baseline: +1.4%

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


✅ update-name

Time: ✅ 16.652ms (SLO: <22.000ms 📉 -24.3%) vs baseline: +1.6%

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


tracer - 6/6

✅ large

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

Memory: ✅ 32.676MB (SLO: <34.500MB -5.3%) vs baseline: +4.7%


✅ medium

Time: ✅ 2.882ms (SLO: <3.200ms -9.9%) vs baseline: +0.5%

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +4.9%


✅ small

Time: ✅ 325.045µs (SLO: <370.000µs 📉 -12.1%) vs baseline: ~same

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +4.9%

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

@christophe-papazian christophe-papazian marked this pull request as ready for review November 7, 2025 14:39
@christophe-papazian christophe-papazian requested review from a team as code owners November 7, 2025 14:39
@christophe-papazian christophe-papazian requested review from emmettbutler, mabdinur and rachelyangdog and removed request for rachelyangdog November 7, 2025 14:39
@christophe-papazian christophe-papazian enabled auto-merge (squash) November 7, 2025 14:45
@ownership-prod ownership-prod bot requested review from a team and KowalskiThomas November 7, 2025 14:56
@avara1986
Copy link
Member

LGTM @christophe-papazian!

Copy link
Collaborator

@emmettbutler emmettbutler left a comment

Choose a reason for hiding this comment

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

very nice, thank you

Copy link
Contributor

@mabdinur mabdinur left a comment

Choose a reason for hiding this comment

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

Left some nits. Overall I love this change. In a follow up PR can we also introduce a new api for configuring asm/iast that doesn't require importing the global tracer?

Something like would be nice:

def configure_security_products(...): 
  **** 

Or we can just avoid exposing a programmatic api for enabling asm/iast (my preference). I think this would better align with next gen efforts

@christophe-papazian christophe-papazian enabled auto-merge (squash) November 13, 2025 10:16
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.

7 participants