Skip to content

Conversation

@avara1986
Copy link
Member

@avara1986 avara1986 commented Nov 11, 2025

Adds a .get() method to the Block_config class to restore dictionary-like API compatibility broken by PR #15042, fixing Lambda integration failures.

PR #15042 changed Block_config from a dictionary to a class, introducing a breaking API change that caused Lambda integration to fail with:

AttributeError: 'Block_config' object has no attribute 'get'
Traceback (most recent call last):
  File "./python/lib/python3.13/site-packages/datadog_lambda/wrapper.py", line 187, in __call__
  File "./python/lib/python3.13/site-packages/datadog_lambda/asm.py", line 220, in get_asm_blocked_response
AttributeError: 'Block_config' object has no attribute 'get'

Rollback this ST PR after the merge DataDog/system-tests@f87f4dd

APPSEC-59959

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

CODEOWNERS have been resolved as:

ddtrace/appsec/_utils.py                                                @DataDog/asm-python
tests/appsec/appsec/test_appsec_utils.py                                @DataDog/asm-python

@github-actions
Copy link
Contributor

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

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

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

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.319 ms (0.98%)
ddtrace.bootstrap.sitecustomize 1.558 ms (0.66%)
ddtrace.bootstrap.preload 1.558 ms (0.66%)
ddtrace.internal.remoteconfig.client 0.686 ms (0.29%)
ddtrace 0.761 ms (0.32%)
ddtrace.internal._unpatched 0.104 ms (0.04%)
subprocess 0.073 ms (0.03%)
contextlib 0.073 ms (0.03%)
json 0.031 ms (0.01%)
json.decoder 0.031 ms (0.01%)
re 0.031 ms (0.01%)
enum 0.031 ms (0.01%)
types 0.031 ms (0.01%)

@pr-commenter
Copy link

pr-commenter bot commented Nov 11, 2025

Performance SLOs

Comparing candidate avara1986/APPSEC-59959_block_config (b920697) with baseline main (1c3361c)

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

✅ appsec

Time: ✅ 20.453ms (SLO: <22.300ms -8.3%) vs baseline: +0.2%

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


✅ exception-replay-enabled

Time: ✅ 1.333ms (SLO: <1.450ms -8.0%) vs baseline: -0.3%

Memory: ✅ 64.125MB (SLO: <67.000MB -4.3%) vs baseline: +4.7%


✅ iast

Time: ✅ 20.426ms (SLO: <22.250ms -8.2%) vs baseline: -0.3%

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


✅ profiler

Time: ✅ 15.594ms (SLO: <16.550ms -5.8%) vs baseline: +0.4%

Memory: ✅ 53.906MB (SLO: <54.500MB 🟡 -1.1%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 20.515ms (SLO: <21.750ms -5.7%) vs baseline: -0.2%

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


✅ span-code-origin

Time: ✅ 25.034ms (SLO: <28.200ms 📉 -11.2%) vs baseline: -1.2%

Memory: ✅ 67.144MB (SLO: <69.500MB -3.4%) vs baseline: +4.9%


✅ tracer

Time: ✅ 20.472ms (SLO: <21.750ms -5.9%) vs baseline: -0.2%

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


✅ tracer-and-profiler

Time: ✅ 22.722ms (SLO: <23.500ms -3.3%) vs baseline: +0.1%

Memory: ✅ 67.979MB (SLO: <68.000MB 🟡 ~same) vs baseline: +5.1%


✅ tracer-dont-create-db-spans

Time: ✅ 19.319ms (SLO: <21.500ms 📉 -10.1%) vs baseline: -0.2%

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


✅ tracer-minimal

Time: ✅ 16.644ms (SLO: <17.500ms -4.9%) vs baseline: +0.3%

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


✅ tracer-native

Time: ✅ 20.415ms (SLO: <21.750ms -6.1%) vs baseline: -0.4%

Memory: ✅ 67.987MB (SLO: <72.500MB -6.2%) vs baseline: +4.8%


✅ tracer-no-caches

Time: ✅ 18.437ms (SLO: <19.650ms -6.2%) vs baseline: ~same

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


✅ tracer-no-databases

Time: ✅ 18.748ms (SLO: <20.100ms -6.7%) vs baseline: ~same

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


✅ tracer-no-middleware

Time: ✅ 20.141ms (SLO: <21.500ms -6.3%) vs baseline: ~same

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


✅ tracer-no-templates

Time: ✅ 20.228ms (SLO: <22.000ms -8.1%) vs baseline: ~same

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 18.151ms (SLO: <19.850ms -8.6%) vs baseline: +0.3%

Memory: ✅ 66.111MB (SLO: <66.500MB 🟡 -0.6%) vs baseline: +5.0%


✅ errortracking-enabled-user

Time: ✅ 18.224ms (SLO: <19.400ms -6.1%) vs baseline: +0.9%

Memory: ✅ 66.159MB (SLO: <66.500MB 🟡 -0.5%) vs baseline: +5.1%


✅ tracer-enabled

Time: ✅ 18.063ms (SLO: <19.450ms -7.1%) vs baseline: ~same

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.070ms (SLO: <2.300ms -10.0%) vs baseline: +0.5%

Memory: ✅ 52.376MB (SLO: <53.500MB -2.1%) vs baseline: +4.4%


✅ errortracking-enabled-user

Time: ✅ 2.072ms (SLO: <2.250ms -7.9%) vs baseline: +0.2%

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


✅ tracer-enabled

Time: ✅ 2.073ms (SLO: <2.300ms -9.9%) vs baseline: +0.6%

Memory: ✅ 52.376MB (SLO: <53.500MB -2.1%) vs baseline: +4.5%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 4.589ms (SLO: <4.750ms -3.4%) vs baseline: -1.0%

Memory: ✅ 62.361MB (SLO: <65.000MB -4.1%) vs baseline: +4.9%


✅ appsec-post

Time: ✅ 6.628ms (SLO: <6.750ms 🟡 -1.8%) vs baseline: -0.4%

Memory: ✅ 62.284MB (SLO: <65.000MB -4.2%) vs baseline: +4.7%


✅ appsec-telemetry

Time: ✅ 4.599ms (SLO: <4.750ms -3.2%) vs baseline: -0.3%

Memory: ✅ 62.362MB (SLO: <65.000MB -4.1%) vs baseline: +4.8%


✅ debugger

Time: ✅ 1.855ms (SLO: <2.000ms -7.3%) vs baseline: -0.5%

Memory: ✅ 45.187MB (SLO: <47.000MB -3.9%) vs baseline: +4.9%


✅ iast-get

Time: ✅ 1.857ms (SLO: <2.000ms -7.2%) vs baseline: -0.5%

Memory: ✅ 42.082MB (SLO: <49.000MB 📉 -14.1%) vs baseline: +4.8%


✅ profiler

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

Memory: ✅ 46.676MB (SLO: <47.000MB 🟡 -0.7%) vs baseline: +5.1%


✅ resource-renaming

Time: ✅ 3.370ms (SLO: <3.650ms -7.7%) vs baseline: -0.3%

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


✅ tracer

Time: ✅ 3.345ms (SLO: <3.650ms -8.4%) vs baseline: -0.9%

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


✅ tracer-native

Time: ✅ 3.353ms (SLO: <3.650ms -8.1%) vs baseline: -0.4%

Memory: ✅ 54.310MB (SLO: <60.000MB -9.5%) vs baseline: +4.8%


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 308.880ms (SLO: <320.950ms -3.8%) vs baseline: +0.3%

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


✅ deep-profiled

Time: ✅ 328.360ms (SLO: <359.150ms -8.6%) vs baseline: +0.2%

Memory: ✅ 38.469MB (SLO: <39.000MB 🟡 -1.4%) vs baseline: +6.8%


✅ medium

Time: ✅ 7.009ms (SLO: <7.400ms -5.3%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.948ms (SLO: <1.050ms -9.7%) vs baseline: +0.9%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%

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

⚠️ context_with_data_listeners

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

Memory: ✅ 31.890MB (SLO: <33.500MB -4.8%) vs baseline: +5.1%


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

Time: ✅ 24.002µs (SLO: <30.000µs 📉 -20.0%) vs baseline: -0.9%

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

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

✅ appsec-enabled

Time: ✅ 3.965ms (SLO: <4.200ms -5.6%) vs baseline: -0.2%

Memory: ✅ 62.266MB (SLO: <66.000MB -5.7%) vs baseline: +4.7%


✅ iast-enabled

Time: ✅ 2.431ms (SLO: <2.800ms 📉 -13.2%) vs baseline: -0.4%

Memory: ✅ 58.687MB (SLO: <60.000MB -2.2%) vs baseline: +4.5%


✅ tracer-enabled

Time: ✅ 2.057ms (SLO: <2.250ms -8.6%) vs baseline: -0.3%

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


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.282µs (SLO: <100.000µs 📉 -18.7%) vs baseline: -0.3%

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ b3_headers

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.8%


✅ b3_single_headers

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.0%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.1%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 68.311µs (SLO: <80.000µs 📉 -14.6%) vs baseline: +3.1%

Memory: ✅ 31.890MB (SLO: <33.500MB -4.8%) vs baseline: +4.7%


✅ empty_headers

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

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ full_t_id_datadog_headers

Time: ✅ 22.785µs (SLO: <30.000µs 📉 -24.1%) vs baseline: -0.6%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.8%


✅ invalid_priority_header

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

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ invalid_span_id_header

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ invalid_tags_header

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ invalid_trace_id_header

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.6%


✅ large_header_no_matches

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

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ large_valid_headers_all

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.2%


✅ medium_header_no_matches

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ medium_valid_headers_all

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

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +4.9%


✅ valid_headers_all

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

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.9%


✅ valid_headers_basic

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.3%


✅ wsgi_empty_headers

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.2%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.1%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.8%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.8%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +5.0%


✅ wsgi_large_header_no_matches

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +5.2%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.5%


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.5%


✅ wsgi_valid_headers_basic

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

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.6%


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 22.059µs (SLO: <30.000µs 📉 -26.5%) vs baseline: +5.5%

Memory: ✅ 31.929MB (SLO: <33.500MB -4.7%) vs baseline: +4.9%


✅ with_all

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ with_dd_origin

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +5.1%


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

Time: ✅ 27.020µs (SLO: <40.000µs 📉 -32.4%) vs baseline: +1.5%

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


✅ with_tags_invalid

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

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.7%


✅ with_tags_max_size

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

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.5%


iast_aspects - 40/40

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

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

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


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

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

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

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

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


✅ re_groups_noaspect

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

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


✅ re_match_aspect

Time: ✅ 2.673µs (SLO: <10.000µs 📉 -73.3%) vs baseline: -2.1%

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

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

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


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


iastaspects - 118/118

✅ add_aspect

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

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


✅ add_inplace_aspect

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

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


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

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


✅ bytearray_aspect

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

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


✅ bytearray_extend_aspect

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

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


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

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


✅ bytes_aspect

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

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


✅ bytes_noaspect

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

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


✅ bytesio_aspect

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

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


✅ bytesio_noaspect

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

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


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

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


✅ casefold_aspect

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

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


✅ casefold_noaspect

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

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


✅ decode_aspect

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

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


✅ decode_noaspect

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

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


✅ encode_aspect

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

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


✅ encode_noaspect

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

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


✅ format_aspect

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

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


✅ format_map_aspect

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

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


✅ format_map_noaspect

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

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


✅ format_noaspect

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

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


✅ index_aspect

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

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


✅ index_noaspect

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

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


✅ join_aspect

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

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


✅ join_noaspect

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

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


✅ ljust_aspect

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

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


✅ ljust_noaspect

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

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


✅ lower_aspect

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

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


✅ lower_noaspect

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

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


✅ lstrip_aspect

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

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


✅ lstrip_noaspect

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

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


✅ modulo_aspect

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

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


✅ modulo_aspect_for_bytearray_bytearray

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

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


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

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


✅ modulo_noaspect

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

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


✅ replace_aspect

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

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


✅ replace_noaspect

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

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


✅ repr_aspect

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

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


✅ repr_noaspect

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

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


✅ rstrip_aspect

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

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


✅ rstrip_noaspect

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

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


✅ slice_aspect

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

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


✅ slice_noaspect

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

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


✅ stringio_aspect

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

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


✅ stringio_noaspect

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

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


✅ strip_aspect

Time: ✅ 2.390µs (SLO: <20.000µs 📉 -88.1%) vs baseline: +6.9%

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


✅ strip_noaspect

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

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


✅ swapcase_aspect

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

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


✅ swapcase_noaspect

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

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


✅ title_aspect

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

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


✅ title_noaspect

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

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


✅ translate_aspect

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

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


✅ translate_noaspect

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

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


✅ upper_aspect

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

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


✅ upper_noaspect

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

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


iastaspectsospath - 24/24

✅ ospathbasename_aspect

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

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

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


✅ ospathsplitdrive_noaspect

Time: ✅ 0.691µs (SLO: <10.000µs 📉 -93.1%) vs baseline: -1.8%

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


iastaspectssplit - 12/12

✅ rsplit_aspect

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

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

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


✅ split_noaspect

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

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


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

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


iastpropagation - 2/2

✅ no-propagation

Time: ✅ 48.399µs (SLO: <60.000µs 📉 -19.3%) vs baseline: -0.3%

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


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.145ms (SLO: <42.000ms -4.4%) vs baseline: -0.5%

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


✅ add-link

Time: ✅ 36.892ms (SLO: <38.550ms -4.3%) vs baseline: +1.6%

Memory: ✅ 34.269MB (SLO: <39.000MB 📉 -12.1%) vs baseline: +4.7%


✅ add-metrics

Time: ✅ 220.563ms (SLO: <232.000ms -4.9%) vs baseline: +0.6%

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


✅ add-tags

Time: ✅ 213.023ms (SLO: <221.600ms -3.9%) vs baseline: +1.0%

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


✅ get-context

Time: ✅ 28.994ms (SLO: <31.300ms -7.4%) vs baseline: -0.2%

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


✅ is-recording

Time: ✅ 29.611ms (SLO: <31.000ms -4.5%) vs baseline: +1.9%

Memory: ✅ 34.269MB (SLO: <39.000MB 📉 -12.1%) vs baseline: +4.7%


✅ record-exception

Time: ✅ 63.314ms (SLO: <65.850ms -3.9%) vs baseline: +0.4%

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


✅ set-status

Time: ✅ 32.486ms (SLO: <34.150ms -4.9%) vs baseline: +1.6%

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


✅ start

Time: ✅ 29.410ms (SLO: <30.150ms -2.5%) vs baseline: +1.9%

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


✅ start-finish

Time: ✅ 34.469ms (SLO: <35.350ms -2.5%) vs baseline: +1.6%

Memory: ✅ 34.288MB (SLO: <39.000MB 📉 -12.1%) vs baseline: +4.7%


✅ start-finish-telemetry

Time: ✅ 33.864ms (SLO: <35.450ms -4.5%) vs baseline: +0.2%

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


✅ update-name

Time: ✅ 31.282ms (SLO: <33.400ms -6.3%) vs baseline: +1.0%

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


otelspan - 22/22

✅ add-event

Time: ✅ 40.458ms (SLO: <47.150ms 📉 -14.2%) vs baseline: ~same

Memory: ✅ 43.589MB (SLO: <47.000MB -7.3%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 318.652ms (SLO: <344.800ms -7.6%) vs baseline: +0.8%

Memory: ✅ 651.026MB (SLO: <675.000MB -3.6%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 290.179ms (SLO: <314.000ms -7.6%) vs baseline: +0.9%

Memory: ✅ 652.423MB (SLO: <675.000MB -3.3%) vs baseline: +4.7%


✅ get-context

Time: ✅ 80.918ms (SLO: <92.350ms 📉 -12.4%) vs baseline: +1.0%

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


✅ is-recording

Time: ✅ 38.382ms (SLO: <44.500ms 📉 -13.7%) vs baseline: +0.8%

Memory: ✅ 42.945MB (SLO: <47.500MB -9.6%) vs baseline: +5.0%


✅ record-exception

Time: ✅ 58.332ms (SLO: <67.650ms 📉 -13.8%) vs baseline: -0.6%

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


✅ set-status

Time: ✅ 43.989ms (SLO: <50.400ms 📉 -12.7%) vs baseline: ~same

Memory: ✅ 42.961MB (SLO: <47.000MB -8.6%) vs baseline: +5.0%


✅ start

Time: ✅ 37.312ms (SLO: <43.450ms 📉 -14.1%) vs baseline: ~same

Memory: ✅ 42.975MB (SLO: <47.000MB -8.6%) vs baseline: +4.8%


✅ start-finish

Time: ✅ 81.750ms (SLO: <88.000ms -7.1%) vs baseline: ~same

Memory: ✅ 34.426MB (SLO: <46.500MB 📉 -26.0%) vs baseline: +5.2%


✅ start-finish-telemetry

Time: ✅ 83.838ms (SLO: <89.000ms -5.8%) vs baseline: +0.4%

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


✅ update-name

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

Memory: ✅ 43.282MB (SLO: <47.000MB -7.9%) vs baseline: +4.9%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 342.569ms (SLO: <354.300ms -3.3%) vs baseline: ~same

Memory: ✅ 37.477MB (SLO: <40.000MB -6.3%) vs baseline: +5.0%


✅ cache_on

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

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


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 156.390µs (SLO: <170.000µs -8.0%) vs baseline: +1.2%

Memory: ✅ 36.781MB (SLO: <38.500MB -4.5%) vs baseline: +5.7%


✅ import_many_cached

Time: ✅ 121.576µs (SLO: <130.000µs -6.5%) vs baseline: -0.4%

Memory: ✅ 36.708MB (SLO: <38.500MB -4.7%) vs baseline: +4.4%


✅ import_many_stdlib

Time: ✅ 1.618ms (SLO: <1.750ms -7.5%) vs baseline: +0.9%

Memory: ✅ 37.264MB (SLO: <38.500MB -3.2%) vs baseline: +6.4%


✅ import_many_stdlib_cached

Time: ✅ 0.983ms (SLO: <1.100ms 📉 -10.6%) vs baseline: +0.8%

Memory: ✅ 36.639MB (SLO: <38.500MB -4.8%) vs baseline: +3.7%


✅ import_many_unknown

Time: ✅ 836.235µs (SLO: <890.000µs -6.0%) vs baseline: +0.1%

Memory: ✅ 37.232MB (SLO: <38.500MB -3.3%) vs baseline: +5.5%


✅ import_many_unknown_cached

Time: ✅ 792.545µs (SLO: <870.000µs -8.9%) vs baseline: ~same

Memory: ✅ 36.862MB (SLO: <38.500MB -4.3%) vs baseline: +4.5%


✅ import_one

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

Memory: ✅ 36.739MB (SLO: <39.000MB -5.8%) vs baseline: +4.8%


✅ import_one_cache

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

Memory: ✅ 36.764MB (SLO: <38.500MB -4.5%) vs baseline: +4.6%


✅ import_one_stdlib

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

Memory: ✅ 36.724MB (SLO: <38.500MB -4.6%) vs baseline: +4.5%


✅ import_one_stdlib_cache

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

Memory: ✅ 37.128MB (SLO: <38.500MB -3.6%) vs baseline: +5.8%


✅ import_one_unknown

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

Memory: ✅ 37.224MB (SLO: <38.500MB -3.3%) vs baseline: +6.0%


✅ import_one_unknown_cache

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

Memory: ✅ 37.123MB (SLO: <38.500MB -3.6%) vs baseline: +5.7%


ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

Memory: ✅ 31.457MB (SLO: <34.000MB -7.5%) vs baseline: +4.8%


✅ long_window

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

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


✅ low_rate_limit

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

Memory: ✅ 31.457MB (SLO: <34.000MB -7.5%) vs baseline: +4.7%


✅ no_rate_limit

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

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


✅ short_window

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

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


samplingrules - 8/8

✅ average_match

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

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ high_match

Time: ✅ 175.952µs (SLO: <480.000µs 📉 -63.3%) vs baseline: +0.9%

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


✅ low_match

Time: ✅ 98.749µs (SLO: <120.000µs 📉 -17.7%) vs baseline: -0.4%

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


✅ very_low_match

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

Memory: ✅ 67.949MB (SLO: <75.000MB -9.4%) vs baseline: +4.7%


sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

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

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


✅ collectipvariant_exists

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

Memory: ✅ 32.303MB (SLO: <34.000MB -5.0%) vs baseline: +4.5%


✅ no-collectipvariant

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

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +4.7%


✅ no-useragentvariant

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

Memory: ✅ 32.401MB (SLO: <34.000MB -4.7%) vs baseline: +5.0%


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 32.735MB (SLO: <34.000MB -3.7%) vs baseline: +4.9%


✅ obfuscation-regular-case-implicit-query

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

Memory: ✅ 32.735MB (SLO: <34.000MB -3.7%) vs baseline: +5.0%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 32.735MB (SLO: <34.500MB -5.1%) vs baseline: +4.9%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 32.794MB (SLO: <34.500MB -4.9%) vs baseline: +4.9%


✅ obfuscation-worst-case-implicit-query

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

Memory: ✅ 32.775MB (SLO: <34.500MB -5.0%) vs baseline: +5.0%


✅ useragentvariant_exists_1

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

Memory: ✅ 32.362MB (SLO: <34.000MB -4.8%) vs baseline: +5.0%


✅ useragentvariant_exists_2

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

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +5.0%


✅ useragentvariant_exists_3

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

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +4.6%


✅ useragentvariant_not_exists_1

Time: ✅ 39.506µs (SLO: <50.000µs 📉 -21.0%) vs baseline: +0.4%

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


✅ useragentvariant_not_exists_2

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

Memory: ✅ 32.401MB (SLO: <34.000MB -4.7%) vs baseline: +5.2%


span - 26/26

✅ add-event

Time: ✅ 20.017ms (SLO: <22.500ms 📉 -11.0%) vs baseline: +0.1%

Memory: ✅ 48.541MB (SLO: <53.000MB -8.4%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 90.301ms (SLO: <93.500ms -3.4%) vs baseline: +0.3%

Memory: ✅ 735.961MB (SLO: <961.000MB 📉 -23.4%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 146.198ms (SLO: <155.000ms -5.7%) vs baseline: -1.2%

Memory: ✅ 735.859MB (SLO: <962.500MB 📉 -23.5%) vs baseline: +4.9%


✅ get-context

Time: ✅ 18.421ms (SLO: <20.500ms 📉 -10.1%) vs baseline: +0.3%

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


✅ is-recording

Time: ✅ 18.611ms (SLO: <20.500ms -9.2%) vs baseline: +0.3%

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


✅ record-exception

Time: ✅ 37.491ms (SLO: <40.000ms -6.3%) vs baseline: ~same

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


✅ set-status

Time: ✅ 20.307ms (SLO: <22.000ms -7.7%) vs baseline: +0.6%

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


✅ start

Time: ✅ 18.320ms (SLO: <20.500ms 📉 -10.6%) vs baseline: +0.3%

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


✅ start-finish

Time: ✅ 50.498ms (SLO: <52.500ms -3.8%) vs baseline: -0.5%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.9%


✅ start-finish-telemetry

Time: ✅ 51.874ms (SLO: <54.500ms -4.8%) vs baseline: ~same

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 53.864ms (SLO: <57.000ms -5.5%) vs baseline: ~same

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


✅ start-traceid128

Time: ✅ 18.725ms (SLO: <22.500ms 📉 -16.8%) vs baseline: +0.5%

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


✅ update-name

Time: ✅ 18.742ms (SLO: <22.000ms 📉 -14.8%) vs baseline: -0.1%

Memory: ✅ 47.887MB (SLO: <53.000MB -9.6%) vs baseline: +4.9%


telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.177µs (SLO: <20.000µs 📉 -84.1%) vs baseline: +6.5%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +5.0%


✅ 1-count-metrics-100-times

Time: ✅ 206.141µs (SLO: <220.000µs -6.3%) vs baseline: +0.7%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.8%


✅ 1-distribution-metric-1-times

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

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.8%


✅ 1-distribution-metrics-100-times

Time: ✅ 212.441µs (SLO: <220.000µs -3.4%) vs baseline: -0.3%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.8%


✅ 1-gauge-metric-1-times

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

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.8%


✅ 1-gauge-metrics-100-times

Time: ✅ 137.313µs (SLO: <150.000µs -8.5%) vs baseline: ~same

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.0%


✅ 1-rate-metric-1-times

Time: ✅ 3.315µs (SLO: <20.000µs 📉 -83.4%) vs baseline: +6.4%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ 1-rate-metrics-100-times

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

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ 100-count-metrics-100-times

Time: ✅ 20.821ms (SLO: <22.000ms -5.4%) vs baseline: +1.1%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.225ms (SLO: <2.300ms -3.2%) vs baseline: -1.3%

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.9%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.415ms (SLO: <1.550ms -8.7%) vs baseline: +1.1%

Memory: ✅ 31.870MB (SLO: <34.000MB -6.3%) vs baseline: +4.8%


✅ 100-rate-metrics-100-times

Time: ✅ 2.221ms (SLO: <2.550ms 📉 -12.9%) vs baseline: +0.9%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +4.9%


✅ flush-1-metric

Time: ✅ 4.756µs (SLO: <20.000µs 📉 -76.2%) vs baseline: +5.4%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +5.0%


✅ flush-100-metrics

Time: ✅ 176.941µs (SLO: <250.000µs 📉 -29.2%) vs baseline: +0.7%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.8%


✅ flush-1000-metrics

Time: ✅ 2.149ms (SLO: <2.500ms 📉 -14.1%) vs baseline: +0.6%

Memory: ✅ 32.637MB (SLO: <34.500MB -5.4%) vs baseline: +4.7%


tracer - 6/6

✅ large

Time: ✅ 29.126ms (SLO: <32.950ms 📉 -11.6%) vs baseline: +0.7%

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


✅ medium

Time: ✅ 2.907ms (SLO: <3.200ms -9.2%) vs baseline: +1.6%

Memory: ✅ 31.457MB (SLO: <34.000MB -7.5%) vs baseline: +4.8%


✅ small

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) 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

@avara1986 avara1986 marked this pull request as ready for review November 11, 2025 13:55
@avara1986 avara1986 requested a review from a team as a code owner November 11, 2025 13:55
@avara1986 avara1986 changed the title chore(waf): fix block_config aompatibility chore(waf): fix block_config_compatibility Nov 11, 2025
@avara1986 avara1986 changed the title chore(waf): fix block_config_compatibility chore(waf): fix block_config compatibility Nov 12, 2025
@avara1986 avara1986 enabled auto-merge (squash) November 12, 2025 13:18
Copy link
Member

@jandro996 jandro996 left a comment

Choose a reason for hiding this comment

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

LGTM

@avara1986 avara1986 merged commit b828f70 into main Nov 12, 2025
973 checks passed
@avara1986 avara1986 deleted the avara1986/APPSEC-59959_block_config branch November 12, 2025 13:39
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