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: 248 ± 5 ms.

The average import time from base is: 263 ± 7 ms.

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

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 9.192 ms (3.71%)
ddtrace.bootstrap.sitecustomize 5.123 ms (2.07%)
ddtrace.bootstrap.preload 5.123 ms (2.07%)
ddtrace.internal.remoteconfig.client 0.804 ms (0.32%)
ddtrace.internal.settings.dynamic_instrumentation 0.764 ms (0.31%)
ddtrace.internal.remoteconfig.worker 0.756 ms (0.30%)
multiprocessing.sharedctypes 0.272 ms (0.11%)
ctypes 0.272 ms (0.11%)
_ctypes 0.272 ms (0.11%)
ddtrace 4.068 ms (1.64%)
ddtrace._logger 1.424 ms (0.57%)
ddtrace.internal.telemetry 1.424 ms (0.57%)
ddtrace.internal.telemetry.writer 1.000 ms (0.40%)
ddtrace.internal.utils.version 0.747 ms (0.30%)
ddtrace.internal.runtime 0.194 ms (0.08%)
uuid 0.194 ms (0.08%)
platform 0.194 ms (0.08%)
ddtrace.internal.packages 0.059 ms (0.02%)
_sysconfigdata__linux_x86_64-linux-gnu 0.059 ms (0.02%)
ddtrace.internal.utils.formats 0.199 ms (0.08%)
ddtrace.internal.compat 0.199 ms (0.08%)
wrapt 0.199 ms (0.08%)
wrapt.importer 0.199 ms (0.08%)
importlib.metadata 0.199 ms (0.08%)
ddtrace.internal.settings._agent 0.169 ms (0.07%)
urllib.parse 0.169 ms (0.07%)
ddtrace.trace 1.018 ms (0.41%)
ddtrace._trace.filters 0.203 ms (0.08%)
ddtrace._trace.processor 0.203 ms (0.08%)
ddtrace.internal.writer 0.203 ms (0.08%)
ddtrace.internal.writer.writer 0.203 ms (0.08%)
gzip 0.203 ms (0.08%)
ddtrace.internal._unpatched 0.199 ms (0.08%)
subprocess 0.165 ms (0.07%)
contextlib 0.165 ms (0.07%)
json 0.034 ms (0.01%)
json.decoder 0.034 ms (0.01%)
re 0.034 ms (0.01%)
enum 0.034 ms (0.01%)
types 0.034 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 (e6099e7) with baseline main (08d3021)

🟡 Near SLO Breach (5 suites)
🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.677ms (SLO: <19.850ms 📉 -16.0%) vs baseline: +1.8%

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 16.305ms (SLO: <19.450ms 📉 -16.2%) vs baseline: -0.5%

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 2.094ms (SLO: <2.300ms -9.0%) vs baseline: +1.5%

Memory: ✅ 52.337MB (SLO: <53.500MB -2.2%) vs baseline: +4.5%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 4.585ms (SLO: <4.750ms -3.5%) vs baseline: ~same

Memory: ✅ 62.104MB (SLO: <65.000MB -4.5%) vs baseline: +4.9%


✅ appsec-post

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

Memory: ✅ 62.103MB (SLO: <65.000MB -4.5%) vs baseline: +4.9%


✅ appsec-telemetry

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

Memory: ✅ 62.068MB (SLO: <65.000MB -4.5%) vs baseline: +4.9%


✅ debugger

Time: ✅ 1.853ms (SLO: <2.000ms -7.3%) vs baseline: ~same

Memory: ✅ 45.198MB (SLO: <47.000MB -3.8%) vs baseline: +4.7%


✅ iast-get

Time: ✅ 1.853ms (SLO: <2.000ms -7.4%) vs baseline: -0.3%

Memory: ✅ 41.831MB (SLO: <49.000MB 📉 -14.6%) vs baseline: +5.0%


✅ profiler

Time: ✅ 1.914ms (SLO: <2.100ms -8.9%) vs baseline: -0.1%

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


✅ resource-renaming

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

Memory: ✅ 52.396MB (SLO: <53.500MB -2.1%) vs baseline: +4.6%


✅ tracer

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

Memory: ✅ 52.314MB (SLO: <53.500MB -2.2%) vs baseline: +4.7%


✅ tracer-native

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

Memory: ✅ 53.994MB (SLO: <60.000MB 📉 -10.0%) vs baseline: +4.7%


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 38.722ms (SLO: <47.150ms 📉 -17.9%) vs baseline: +0.1%

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


✅ add-metrics

Time: ✅ 259.743ms (SLO: <344.800ms 📉 -24.7%) vs baseline: ~same

Memory: ✅ 40.659MB (SLO: <47.500MB 📉 -14.4%) vs baseline: +4.5%


✅ add-tags

Time: ✅ 316.119ms (SLO: <321.000ms 🟡 -1.5%) vs baseline: -0.2%

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


✅ get-context

Time: ✅ 78.567ms (SLO: <92.350ms 📉 -14.9%) vs baseline: -0.3%

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


✅ is-recording

Time: ✅ 36.179ms (SLO: <44.500ms 📉 -18.7%) vs baseline: +0.6%

Memory: ✅ 36.215MB (SLO: <47.500MB 📉 -23.8%) vs baseline: +5.1%


✅ record-exception

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

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


✅ set-status

Time: ✅ 42.736ms (SLO: <50.400ms 📉 -15.2%) vs baseline: +0.3%

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


✅ start

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

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


✅ start-finish

Time: ✅ 82.044ms (SLO: <88.000ms -6.8%) vs baseline: +0.4%

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


✅ start-finish-telemetry

Time: ✅ 83.560ms (SLO: <89.000ms -6.1%) vs baseline: +0.1%

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


✅ update-name

Time: ✅ 37.076ms (SLO: <45.150ms 📉 -17.9%) vs baseline: +0.9%

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


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 308.593ms (SLO: <320.950ms -3.9%) vs baseline: ~same

Memory: ✅ 32.696MB (SLO: <34.500MB -5.2%) vs baseline: +4.8%


✅ deep-profiled

Time: ✅ 327.741ms (SLO: <359.150ms -8.7%) vs baseline: -0.2%

Memory: ✅ 38.269MB (SLO: <39.000MB 🟡 -1.9%) vs baseline: +4.9%


✅ medium

Time: ✅ 7.008ms (SLO: <7.400ms -5.3%) vs baseline: +0.2%

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


✅ shallow

Time: ✅ 0.941ms (SLO: <1.050ms 📉 -10.4%) vs baseline: +0.1%

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.267µs (SLO: <20.000µs 📉 -33.7%) vs baseline: -0.5%

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

Memory: ✅ 31.457MB (SLO: <33.500MB -6.1%) vs baseline: +4.6%


✅ get_item_missing

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

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


✅ set_item

Time: ✅ 24.027µs (SLO: <30.000µs 📉 -19.9%) vs baseline: -1.2%

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

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

✅ appsec-enabled

Time: ✅ 3.943ms (SLO: <4.200ms -6.1%) vs baseline: ~same

Memory: ✅ 62.443MB (SLO: <66.000MB -5.4%) vs baseline: +5.0%


✅ iast-enabled

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

Memory: ✅ 58.491MB (SLO: <60.000MB -2.5%) vs baseline: +4.8%


✅ tracer-enabled

Time: ✅ 2.048ms (SLO: <2.250ms -9.0%) vs baseline: -0.9%

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


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 80.832µs (SLO: <100.000µs 📉 -19.2%) vs baseline: +0.5%

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


✅ b3_headers

Time: ✅ 14.168µs (SLO: <20.000µs 📉 -29.2%) vs baseline: +0.2%

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


✅ b3_single_headers

Time: ✅ 13.918µs (SLO: <20.000µs 📉 -30.4%) vs baseline: +5.5%

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 64.278µs (SLO: <80.000µs 📉 -19.7%) vs baseline: +0.7%

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 67.856µs (SLO: <80.000µs 📉 -15.2%) vs baseline: +3.0%

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


✅ empty_headers

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

Memory: ✅ 31.693MB (SLO: <33.500MB -5.4%) vs baseline: +5.1%


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

Memory: ✅ 31.693MB (SLO: <33.500MB -5.4%) vs baseline: +5.2%


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

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

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


httppropagationinject - 16/16

✅ ids_only

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

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


✅ with_all

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

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


✅ with_dd_origin

Time: ✅ 24.717µs (SLO: <30.000µs 📉 -17.6%) vs baseline: +1.3%

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


✅ with_priority_and_origin

Time: ✅ 24.228µs (SLO: <40.000µs 📉 -39.4%) vs baseline: +1.9%

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


✅ with_sampling_priority

Time: ✅ 20.759µs (SLO: <30.000µs 📉 -30.8%) vs baseline: +0.5%

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


iast_aspects - 40/40

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

Time: ✅ 28.447µs (SLO: <40.000µs 📉 -28.9%) vs baseline: -0.8%

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


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

Time: ✅ 2.647µs (SLO: <10.000µs 📉 -73.5%) vs baseline: -6.3%

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

Time: ✅ 3.206µs (SLO: <10.000µs 📉 -67.9%) vs baseline: +4.3%

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


✅ re_groups_noaspect

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

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


✅ re_match_aspect

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

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

Time: ✅ 3.495µs (SLO: <10.000µs 📉 -65.0%) vs baseline: +3.3%

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


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


iastaspects - 118/118

✅ add_aspect

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

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


✅ add_inplace_aspect

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

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


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

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


✅ bytearray_aspect

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

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


✅ bytearray_extend_aspect

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

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


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

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


✅ bytes_aspect

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

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


✅ bytes_noaspect

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

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


✅ bytesio_aspect

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

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


✅ bytesio_noaspect

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

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


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

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


✅ casefold_aspect

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

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


✅ casefold_noaspect

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

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


✅ decode_aspect

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

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


✅ decode_noaspect

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

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


✅ encode_aspect

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

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


✅ encode_noaspect

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

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


✅ format_aspect

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

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


✅ format_map_aspect

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

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


✅ format_map_noaspect

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

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


✅ format_noaspect

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

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


✅ index_aspect

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

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


✅ index_noaspect

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

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


✅ join_aspect

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

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


✅ join_noaspect

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

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


✅ ljust_aspect

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

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


✅ ljust_noaspect

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

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


✅ lower_aspect

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

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


✅ lower_noaspect

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

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


✅ lstrip_aspect

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

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


✅ lstrip_noaspect

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

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


✅ modulo_aspect

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

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


✅ modulo_aspect_for_bytearray_bytearray

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

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


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

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


✅ modulo_noaspect

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

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


✅ replace_aspect

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

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


✅ replace_noaspect

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

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


✅ repr_aspect

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

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


✅ repr_noaspect

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

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


✅ rstrip_aspect

Time: ✅ 1.906µs (SLO: <20.000µs 📉 -90.5%) vs baseline: +0.6%

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


✅ rstrip_noaspect

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

Memory: ✅ 37.395MB (SLO: <39.000MB -4.1%) vs baseline: +5.1%


✅ slice_aspect

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

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


✅ slice_noaspect

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

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


✅ stringio_aspect

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

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


✅ stringio_noaspect

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

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


✅ strip_aspect

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

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


✅ strip_noaspect

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

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


✅ swapcase_aspect

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

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


✅ swapcase_noaspect

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

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


✅ title_aspect

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

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


✅ title_noaspect

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

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


✅ translate_aspect

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

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


✅ translate_noaspect

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

Memory: ✅ 37.375MB (SLO: <39.000MB -4.2%) vs baseline: +5.4%


✅ upper_aspect

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

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


✅ upper_noaspect

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

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


iastaspectsospath - 24/24

✅ ospathbasename_aspect

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

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

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


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


iastaspectssplit - 12/12

✅ rsplit_aspect

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

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

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


✅ split_noaspect

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

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


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 339.723ms (SLO: <354.300ms -4.1%) vs baseline: -0.3%

Memory: ✅ 37.076MB (SLO: <40.000MB -7.3%) vs baseline: +5.5%


✅ cache_on

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

Memory: ✅ 35.735MB (SLO: <39.000MB -8.4%) vs baseline: +4.9%


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 154.541µs (SLO: <170.000µs -9.1%) vs baseline: -0.6%

Memory: ✅ 36.436MB (SLO: <38.500MB -5.4%) vs baseline: +5.3%


✅ import_many_cached

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

Memory: ✅ 36.470MB (SLO: <38.500MB -5.3%) vs baseline: +5.1%


✅ import_many_stdlib

Time: ✅ 1.636ms (SLO: <1.750ms -6.5%) vs baseline: +0.6%

Memory: ✅ 36.392MB (SLO: <38.500MB -5.5%) vs baseline: +4.5%


✅ import_many_stdlib_cached

Time: ✅ 0.980ms (SLO: <1.100ms 📉 -10.9%) vs baseline: -0.3%

Memory: ✅ 36.455MB (SLO: <38.500MB -5.3%) vs baseline: +4.7%


✅ import_many_unknown

Time: ✅ 834.403µs (SLO: <890.000µs -6.2%) vs baseline: +0.6%

Memory: ✅ 36.457MB (SLO: <38.500MB -5.3%) vs baseline: +4.8%


✅ import_many_unknown_cached

Time: ✅ 795.731µs (SLO: <870.000µs -8.5%) vs baseline: +1.4%

Memory: ✅ 36.466MB (SLO: <38.500MB -5.3%) vs baseline: +4.9%


✅ import_one

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

Memory: ✅ 36.374MB (SLO: <39.000MB -6.7%) vs baseline: +5.3%


✅ import_one_cache

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

Memory: ✅ 36.313MB (SLO: <38.500MB -5.7%) vs baseline: +4.3%


✅ import_one_stdlib

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

Memory: ✅ 36.282MB (SLO: <38.500MB -5.8%) vs baseline: +4.3%


✅ import_one_stdlib_cache

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

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


✅ import_one_unknown

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

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


✅ import_one_unknown_cache

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

Memory: ✅ 36.382MB (SLO: <38.500MB -5.5%) vs baseline: +4.8%


ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


samplingrules - 8/8

✅ average_match

Time: ✅ 136.983µs (SLO: <290.000µs 📉 -52.8%) vs baseline: -0.3%

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


✅ high_match

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

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


✅ low_match

Time: ✅ 98.586µs (SLO: <120.000µs 📉 -17.8%) vs baseline: ~same

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


✅ very_low_match

Time: ✅ 2.659ms (SLO: <8.500ms 📉 -68.7%) vs baseline: -0.5%

Memory: ✅ 67.855MB (SLO: <75.000MB -9.5%) vs baseline: +4.8%


sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

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

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +5.0%


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

Time: ✅ 40.645µs (SLO: <50.000µs 📉 -18.7%) vs baseline: +1.8%

Memory: ✅ 32.381MB (SLO: <34.000MB -4.8%) vs baseline: +4.7%


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 32.460MB (SLO: <34.000MB -4.5%) vs baseline: +5.1%


✅ obfuscation-regular-case-implicit-query

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

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


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 32.342MB (SLO: <34.500MB -6.3%) vs baseline: +4.6%


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.489µs (SLO: <160.000µs -7.2%) vs baseline: +0.3%

Memory: ✅ 32.381MB (SLO: <34.500MB -6.1%) vs baseline: +4.8%


✅ obfuscation-worst-case-implicit-query

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

Memory: ✅ 32.342MB (SLO: <34.500MB -6.3%) vs baseline: +4.8%


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

Memory: ✅ 32.381MB (SLO: <34.000MB -4.8%) vs baseline: +4.7%


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

Memory: ✅ 32.480MB (SLO: <34.000MB -4.5%) vs baseline: +5.2%


✅ useragentvariant_not_exists_2

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

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


span - 26/26

✅ add-event

Time: ✅ 17.281ms (SLO: <22.500ms 📉 -23.2%) vs baseline: +0.2%

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


✅ add-metrics

Time: ✅ 88.751ms (SLO: <93.500ms -5.1%) vs baseline: +0.3%

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


✅ add-tags

Time: ✅ 142.882ms (SLO: <155.000ms -7.8%) vs baseline: +0.6%

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


✅ get-context

Time: ✅ 16.285ms (SLO: <20.500ms 📉 -20.6%) vs baseline: +1.5%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 35.570ms (SLO: <40.000ms 📉 -11.1%) vs baseline: +1.1%

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


✅ set-status

Time: ✅ 17.829ms (SLO: <22.000ms 📉 -19.0%) vs baseline: +0.8%

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


✅ start

Time: ✅ 15.984ms (SLO: <20.500ms 📉 -22.0%) vs baseline: -0.1%

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


✅ start-finish

Time: ✅ 51.060ms (SLO: <52.500ms -2.7%) vs baseline: +0.5%

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


✅ start-finish-telemetry

Time: ✅ 52.027ms (SLO: <54.500ms -4.5%) vs baseline: ~same

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


✅ start-finish-traceid128

Time: ✅ 53.783ms (SLO: <57.000ms -5.6%) vs baseline: -0.2%

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


✅ start-traceid128

Time: ✅ 16.461ms (SLO: <22.500ms 📉 -26.8%) vs baseline: +0.6%

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


✅ update-name

Time: ✅ 16.519ms (SLO: <22.000ms 📉 -24.9%) vs baseline: +0.8%

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

ℹ️ Scenarios Missing SLO Configuration (55 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-appsec
  • djangosimple-baseline
  • djangosimple-exception-replay-enabled
  • djangosimple-iast
  • djangosimple-profiler
  • djangosimple-resource-renaming
  • djangosimple-span-code-origin
  • djangosimple-tracer
  • djangosimple-tracer-and-profiler
  • djangosimple-tracer-dont-create-db-spans
  • djangosimple-tracer-minimal
  • djangosimple-tracer-native
  • djangosimple-tracer-no-caches
  • djangosimple-tracer-no-databases
  • djangosimple-tracer-no-middleware
  • djangosimple-tracer-no-templates
  • errortrackingdjangosimple-baseline
  • errortrackingflasksqli-baseline
  • flasksimple-baseline
  • flasksqli-baseline
  • iastpropagation-no-propagation
  • otelsdkspan-add-event
  • otelsdkspan-add-link
  • otelsdkspan-add-metrics
  • otelsdkspan-add-tags
  • otelsdkspan-get-context
  • otelsdkspan-is-recording
  • otelsdkspan-record-exception
  • otelsdkspan-set-status
  • otelsdkspan-start
  • otelsdkspan-start-finish
  • otelsdkspan-start-finish-telemetry
  • otelsdkspan-update-name
  • telemetryaddmetric-1-count-metric-1-times
  • telemetryaddmetric-1-count-metrics-100-times
  • telemetryaddmetric-1-distribution-metric-1-times
  • telemetryaddmetric-1-distribution-metrics-100-times
  • telemetryaddmetric-1-gauge-metric-1-times
  • telemetryaddmetric-1-gauge-metrics-100-times
  • telemetryaddmetric-1-rate-metric-1-times
  • telemetryaddmetric-1-rate-metrics-100-times
  • telemetryaddmetric-100-count-metrics-100-times
  • telemetryaddmetric-100-distribution-metrics-100-times
  • telemetryaddmetric-100-gauge-metrics-100-times
  • telemetryaddmetric-100-rate-metrics-100-times
  • telemetryaddmetric-flush-1-metric
  • telemetryaddmetric-flush-100-metrics
  • telemetryaddmetric-flush-1000-metrics
  • tracer-large
  • tracer-medium
  • tracer-small

@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
@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
@christophe-papazian christophe-papazian merged commit 5ad5469 into main Nov 14, 2025
433 of 435 checks passed
@christophe-papazian christophe-papazian deleted the christophe-papazian/put_appsec_tests_in_their_own_files branch November 14, 2025 10:48
christophe-papazian added a commit that referenced this pull request Nov 14, 2025
## Description

part 2 of #15155

- removing appsec reference from non appsec specific tests
- moving appsec tests in their own files
- shared test files ownership to the python guild

APPSEC-59813
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