Skip to content

Conversation

@avara1986
Copy link
Member

Description

This PR introduces two environment variables to significantly reduce memory usage in IAST taint tracking operations, particularly for join_aspect with large strings or many items.

New Environment Variables

  1. DD_IAST_TRUNCATION_MAX_VALUE_LENGTH (default: 250)
    Limits the size of Source.value stored in TaintRange objects, preventing unbounded string storage.

  2. DD_IAST_MAX_RANGE_COUNT (default: 10)
    Limits the number of TaintRange objects per TaintedObject, preventing memory growth when joining many items.

Performance Improvements

Memory Overhead (join_long_items: 1000 iterations, 10 items × 1KB each)

Metric Before After Improvement
Baseline (no IAST) 20.31 KB 20.31 KB -
With IAST N/A (unbounded) 43.42 KB Bounded
IAST Overhead Scales with string size 23.11 KB (+113.8%) 23 bytes/iter
Source.value storage Up to 10KB+ per range Max 250 chars 97.5% reduction
Max ranges per object 100 10 90% reduction

String Size Scaling Test

String Size # Items Ranges (Before) Ranges (After) Memory Scaling
5 chars 500 ~999 ≤10 Independent of size ✅
500 chars 500 ~999 ≤10 Independent of size ✅
5000 chars 500 ~999 ≤10 Independent of size ✅

Allocation Reduction

Operation TaintRange Allocations (Before) TaintRange Allocations (After)
Join 5 items 8 ranges × unlimited 8 ranges (limited to 10)
Join 100 items 198 ranges × unlimited 10 ranges (capped)
5000 iterations × 100 items 990,000 allocations 50,000 allocations (-95%)

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

CODEOWNERS have been resolved as:

tests/appsec/iast/aspects/test_join_aspect_memory_optimizations.py      @DataDog/asm-python
ddtrace/appsec/_constants.py                                            @DataDog/asm-python
ddtrace/appsec/_iast/_taint_tracking/aspects/aspect_operator_add.cpp    @DataDog/asm-python
ddtrace/appsec/_iast/_taint_tracking/taint_tracking/source.cpp          @DataDog/asm-python
ddtrace/appsec/_iast/_taint_tracking/taint_tracking/source.h            @DataDog/asm-python
ddtrace/appsec/_iast/_taint_tracking/taint_tracking/tainted_object.cpp  @DataDog/asm-python
ddtrace/appsec/_iast/_taint_tracking/taint_tracking/tainted_object.h    @DataDog/asm-python
ddtrace/appsec/_iast/reporter.py                                        @DataDog/asm-python
ddtrace/internal/settings/asm.py                                        @DataDog/asm-python
tests/appsec/iast/test_reporter.py                                      @DataDog/asm-python
tests/appsec/iast_memcheck/test_iast_mem_check.py                       @DataDog/asm-python

@github-actions
Copy link
Contributor

github-actions bot commented Dec 11, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

The average import time from base is: 267 ± 6 ms.

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

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 8.426 ms (3.31%)
ddtrace 4.887 ms (1.92%)
ddtrace._logger 2.686 ms (1.06%)
ddtrace.internal.telemetry 2.469 ms (0.97%)
ddtrace.internal.telemetry.writer 1.721 ms (0.68%)
ddtrace.internal.utils.version 0.882 ms (0.35%)
ddtrace.version 0.745 ms (0.29%)
ddtrace.vendor.packaging.version 0.137 ms (0.05%)
ddtrace.internal.runtime 0.245 ms (0.10%)
uuid 0.245 ms (0.10%)
platform 0.213 ms (0.08%)
ddtrace.internal.packages 0.243 ms (0.10%)
_sysconfigdata__linux_x86_64-linux-gnu 0.078 ms (0.03%)
ddtrace.internal.module 0.048 ms (0.02%)
ddtrace.internal.wrapping.context 0.048 ms (0.02%)
ddtrace.internal.wrapping 0.028 ms (0.01%)
contextvars 0.021 ms (0.01%)
_contextvars 0.021 ms (0.01%)
sysconfig 0.032 ms (0.01%)
http.client 0.098 ms (0.04%)
ssl 0.098 ms (0.04%)
ddtrace.internal.utils.http 0.061 ms (0.02%)
ddtrace.internal.telemetry.metrics_namespaces 0.057 ms (0.02%)
ddtrace.internal.encoding 0.046 ms (0.02%)
ddtrace.internal._encoding 0.046 ms (0.02%)
ddtrace.internal.settings._telemetry 0.035 ms (0.01%)
ddtrace.internal.settings._agent 0.363 ms (0.14%)
urllib.parse 0.218 ms (0.09%)
ddtrace.internal.settings._core 0.103 ms (0.04%)
ddtrace.internal.native 0.074 ms (0.03%)
ddtrace.internal.native._native 0.074 ms (0.03%)
socket 0.042 ms (0.02%)
_socket 0.042 ms (0.02%)
ddtrace.internal.utils.formats 0.328 ms (0.13%)
ddtrace.internal.compat 0.328 ms (0.13%)
wrapt 0.328 ms (0.13%)
wrapt.importer 0.328 ms (0.13%)
importlib.metadata 0.328 ms (0.13%)
zipfile 0.042 ms (0.02%)
shutil 0.042 ms (0.02%)
importlib.metadata._adapters 0.042 ms (0.02%)
email.message 0.042 ms (0.02%)
email.utils 0.042 ms (0.02%)
email._parseaddr 0.042 ms (0.02%)
calendar 0.042 ms (0.02%)
importlib.metadata._meta 0.027 ms (0.01%)
ddtrace.internal.logger 0.217 ms (0.09%)
dataclasses 0.146 ms (0.06%)
inspect 0.106 ms (0.04%)
dis 0.018 ms (0.01%)
opcode 0.018 ms (0.01%)
_opcode 0.018 ms (0.01%)
ddtrace.trace 1.036 ms (0.41%)
ddtrace._trace.filters 0.599 ms (0.24%)
ddtrace._trace.processor 0.599 ms (0.24%)
ddtrace.internal.writer 0.367 ms (0.14%)
ddtrace.internal.writer.writer 0.367 ms (0.14%)
gzip 0.184 ms (0.07%)
ddtrace.internal.dogstatsd 0.093 ms (0.04%)
ddtrace.vendor.dogstatsd 0.093 ms (0.04%)
ddtrace.vendor.dogstatsd.base 0.093 ms (0.04%)
queue 0.027 ms (0.01%)
heapq 0.027 ms (0.01%)
_heapq 0.027 ms (0.01%)
ddtrace._trace.sampler 0.188 ms (0.07%)
ddtrace._trace.span 0.188 ms (0.07%)
ddtrace._trace._span_pointer 0.079 ms (0.03%)
hashlib 0.049 ms (0.02%)
_hashlib 0.049 ms (0.02%)
ddtrace.internal.core 0.067 ms (0.03%)
ddtrace.internal.core.event_hub 0.067 ms (0.03%)
ddtrace._trace.tracer 0.126 ms (0.05%)
ddtrace.internal.processor.endpoint_call_counter 0.038 ms (0.01%)
ddtrace.internal.debug 0.032 ms (0.01%)
ddtrace._trace.context 0.071 ms (0.03%)
ddtrace._trace._span_link 0.038 ms (0.01%)
ddtrace.internal._unpatched 0.372 ms (0.15%)
subprocess 0.216 ms (0.08%)
contextlib 0.198 ms (0.08%)
fcntl 0.018 ms (0.01%)
json 0.120 ms (0.05%)
json.decoder 0.120 ms (0.05%)
re 0.099 ms (0.04%)
enum 0.099 ms (0.04%)
types 0.048 ms (0.02%)
json.scanner 0.022 ms (0.01%)
_json 0.022 ms (0.01%)
threading 0.035 ms (0.01%)
ddtrace.internal.settings._config 0.062 ms (0.02%)
ddtrace.internal.gitmetadata 0.042 ms (0.02%)
ddtrace.ext.ci 0.042 ms (0.02%)
ddtrace.ext.git 0.042 ms (0.02%)
ddtrace.internal.settings.endpoint_config 0.020 ms (0.01%)
ddtrace._monkey 0.041 ms (0.02%)
ddtrace.bootstrap.sitecustomize 3.504 ms (1.38%)
ddtrace.bootstrap.preload 2.901 ms (1.14%)
ddtrace.internal.remoteconfig.client 0.843 ms (0.33%)
multiprocessing 0.281 ms (0.11%)
multiprocessing.context 0.281 ms (0.11%)
multiprocessing.reduction 0.281 ms (0.11%)
pickle 0.281 ms (0.11%)
_pickle 0.219 ms (0.09%)
ddtrace.internal.settings.profiling 0.198 ms (0.08%)
ddtrace.vendor.psutil 0.089 ms (0.04%)
ddtrace.vendor.psutil._pslinux 0.024 ms (0.01%)
resource 0.024 ms (0.01%)
ddtrace.internal.datadog.profiling.ddup 0.043 ms (0.02%)
ddtrace.internal.datadog.profiling.ddup._ddup 0.043 ms (0.02%)
ddtrace.internal.symbol_db.remoteconfig 0.102 ms (0.04%)
ddtrace.internal.ipc 0.036 ms (0.01%)
ddtrace.internal.core.crashtracking 0.076 ms (0.03%)
ddtrace.internal.settings.dynamic_instrumentation 0.040 ms (0.02%)
ddtrace.internal.remoteconfig.worker 0.038 ms (0.01%)
ddtrace.internal.settings.symbol_db 0.037 ms (0.01%)
ddtrace.internal.products 0.034 ms (0.01%)
multiprocessing.sharedctypes 0.034 ms (0.01%)
ddtrace.internal.remoteconfig._connectors 0.034 ms (0.01%)
shlex 0.209 ms (0.08%)
ddtrace._trace.trace_handlers 0.158 ms (0.06%)
ddtrace._trace._inferred_proxy 0.076 ms (0.03%)
ddtrace.propagation.http 0.076 ms (0.03%)
ddtrace.bootstrap.cloning 0.062 ms (0.02%)

@pr-commenter
Copy link

pr-commenter bot commented Dec 11, 2025

Performance SLOs

Comparing candidate avara1986/APPSEC-60212_env_vars (d1e8ffd) with baseline main (077da61)

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

✅ add_aspect

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

Memory: ✅ 38.516MB (SLO: <41.500MB -7.2%) vs baseline: +4.4%


✅ add_inplace_aspect

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

Memory: ✅ 38.596MB (SLO: <41.500MB -7.0%) vs baseline: +5.2%


✅ add_inplace_noaspect

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

Memory: ✅ 38.525MB (SLO: <41.500MB -7.2%) vs baseline: +4.6%


✅ add_noaspect

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

Memory: ✅ 38.543MB (SLO: <41.500MB -7.1%) vs baseline: +4.7%


✅ bytearray_aspect

Time: ✅ 1.263µs (SLO: <10.000µs 📉 -87.4%) vs baseline: -3.5%

Memory: ✅ 38.673MB (SLO: <41.500MB -6.8%) vs baseline: +5.2%


✅ bytearray_extend_aspect

Time: ✅ 1.459µs (SLO: <10.000µs 📉 -85.4%) vs baseline: -1.5%

Memory: ✅ 38.533MB (SLO: <41.500MB -7.2%) vs baseline: +4.7%


✅ bytearray_extend_noaspect

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

Memory: ✅ 38.443MB (SLO: <41.500MB -7.4%) vs baseline: +4.2%


✅ bytearray_noaspect

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

Memory: ✅ 38.477MB (SLO: <41.500MB -7.3%) vs baseline: +4.4%


✅ bytes_aspect

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

Memory: ✅ 38.420MB (SLO: <41.500MB -7.4%) vs baseline: +4.4%


✅ bytes_noaspect

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

Memory: ✅ 38.429MB (SLO: <41.500MB -7.4%) vs baseline: +4.3%


✅ bytesio_aspect

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

Memory: ✅ 38.610MB (SLO: <41.500MB -7.0%) vs baseline: +5.3%


✅ bytesio_noaspect

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

Memory: ✅ 38.492MB (SLO: <41.500MB -7.2%) vs baseline: +4.7%


✅ capitalize_aspect

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

Memory: ✅ 38.485MB (SLO: <41.500MB -7.3%) vs baseline: +4.7%


✅ capitalize_noaspect

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

Memory: ✅ 38.555MB (SLO: <41.500MB -7.1%) vs baseline: +4.8%


✅ casefold_aspect

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

Memory: ✅ 38.579MB (SLO: <41.500MB -7.0%) vs baseline: +4.7%


✅ casefold_noaspect

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

Memory: ✅ 38.609MB (SLO: <41.500MB -7.0%) vs baseline: +4.9%


✅ decode_aspect

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

Memory: ✅ 38.427MB (SLO: <41.500MB -7.4%) vs baseline: +4.7%


✅ decode_noaspect

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

Memory: ✅ 38.597MB (SLO: <41.500MB -7.0%) vs baseline: +5.0%


✅ encode_aspect

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

Memory: ✅ 38.537MB (SLO: <41.500MB -7.1%) vs baseline: +4.2%


✅ encode_noaspect

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

Memory: ✅ 38.571MB (SLO: <41.500MB -7.1%) vs baseline: +4.9%


✅ format_aspect

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

Memory: ✅ 38.524MB (SLO: <41.500MB -7.2%) vs baseline: +4.0%


✅ format_map_aspect

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

Memory: ✅ 38.578MB (SLO: <41.500MB -7.0%) vs baseline: +5.2%


✅ format_map_noaspect

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

Memory: ✅ 38.668MB (SLO: <41.500MB -6.8%) vs baseline: +5.2%


✅ format_noaspect

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

Memory: ✅ 38.584MB (SLO: <41.500MB -7.0%) vs baseline: +5.0%


✅ index_aspect

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

Memory: ✅ 38.629MB (SLO: <41.500MB -6.9%) vs baseline: +5.0%


✅ index_noaspect

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

Memory: ✅ 38.574MB (SLO: <41.500MB -7.0%) vs baseline: +4.9%


✅ join_aspect

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

Memory: ✅ 38.480MB (SLO: <41.500MB -7.3%) vs baseline: +4.5%


✅ join_noaspect

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

Memory: ✅ 38.556MB (SLO: <41.500MB -7.1%) vs baseline: +5.0%


✅ ljust_aspect

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

Memory: ✅ 38.666MB (SLO: <41.500MB -6.8%) vs baseline: +4.9%


✅ ljust_noaspect

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

Memory: ✅ 38.655MB (SLO: <41.500MB -6.9%) vs baseline: +5.0%


✅ lower_aspect

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

Memory: ✅ 38.675MB (SLO: <41.500MB -6.8%) vs baseline: +4.8%


✅ lower_noaspect

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

Memory: ✅ 38.486MB (SLO: <41.500MB -7.3%) vs baseline: +4.4%


✅ lstrip_aspect

Time: ✅ 2.202µs (SLO: <20.000µs 📉 -89.0%) vs baseline: +1.1%

Memory: ✅ 38.604MB (SLO: <41.500MB -7.0%) vs baseline: +4.6%


✅ lstrip_noaspect

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

Memory: ✅ 38.607MB (SLO: <41.500MB -7.0%) vs baseline: +4.8%


✅ modulo_aspect

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

Memory: ✅ 38.568MB (SLO: <41.500MB -7.1%) vs baseline: +4.7%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 38.786MB (SLO: <41.500MB -6.5%) vs baseline: +5.7%


✅ modulo_aspect_for_bytes

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

Memory: ✅ 38.528MB (SLO: <41.500MB -7.2%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 38.546MB (SLO: <41.500MB -7.1%) vs baseline: +4.6%


✅ modulo_noaspect

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

Memory: ✅ 38.430MB (SLO: <41.500MB -7.4%) vs baseline: +4.4%


✅ replace_aspect

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

Memory: ✅ 38.605MB (SLO: <41.500MB -7.0%) vs baseline: +5.1%


✅ replace_noaspect

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

Memory: ✅ 38.388MB (SLO: <41.500MB -7.5%) vs baseline: +4.1%


✅ repr_aspect

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

Memory: ✅ 38.617MB (SLO: <41.500MB -6.9%) vs baseline: +4.6%


✅ repr_noaspect

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

Memory: ✅ 38.587MB (SLO: <41.500MB -7.0%) vs baseline: +4.9%


✅ rstrip_aspect

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

Memory: ✅ 38.443MB (SLO: <41.500MB -7.4%) vs baseline: +4.5%


✅ rstrip_noaspect

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

Memory: ✅ 38.523MB (SLO: <41.500MB -7.2%) vs baseline: +5.1%


✅ slice_aspect

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

Memory: ✅ 38.517MB (SLO: <41.500MB -7.2%) vs baseline: +4.6%


✅ slice_noaspect

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

Memory: ✅ 38.392MB (SLO: <41.500MB -7.5%) vs baseline: +4.4%


✅ stringio_aspect

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

Memory: ✅ 38.415MB (SLO: <41.500MB -7.4%) vs baseline: +4.5%


✅ stringio_noaspect

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

Memory: ✅ 38.478MB (SLO: <41.500MB -7.3%) vs baseline: +4.3%


✅ strip_aspect

Time: ✅ 2.408µs (SLO: <20.000µs 📉 -88.0%) vs baseline: 📈 +11.7%

Memory: ✅ 38.558MB (SLO: <41.500MB -7.1%) vs baseline: +4.6%


✅ strip_noaspect

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

Memory: ✅ 38.446MB (SLO: <41.500MB -7.4%) vs baseline: +4.0%


✅ swapcase_aspect

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

Memory: ✅ 38.691MB (SLO: <41.500MB -6.8%) vs baseline: +5.2%


✅ swapcase_noaspect

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

Memory: ✅ 38.405MB (SLO: <41.500MB -7.5%) vs baseline: +4.2%


✅ title_aspect

Time: ✅ 2.509µs (SLO: <10.000µs 📉 -74.9%) vs baseline: +6.0%

Memory: ✅ 38.488MB (SLO: <41.500MB -7.3%) vs baseline: +4.3%


✅ title_noaspect

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

Memory: ✅ 38.648MB (SLO: <41.500MB -6.9%) vs baseline: +5.0%


✅ translate_aspect

Time: ✅ 3.207µs (SLO: <10.000µs 📉 -67.9%) vs baseline: -1.5%

Memory: ✅ 38.602MB (SLO: <41.500MB -7.0%) vs baseline: +4.9%


✅ translate_noaspect

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

Memory: ✅ 38.597MB (SLO: <41.500MB -7.0%) vs baseline: +4.9%


✅ upper_aspect

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

Memory: ✅ 38.555MB (SLO: <41.500MB -7.1%) vs baseline: +4.8%


✅ upper_noaspect

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

Memory: ✅ 38.408MB (SLO: <41.500MB -7.5%) vs baseline: +4.6%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 4.986µs (SLO: <10.000µs 📉 -50.1%) vs baseline: 📈 +18.2%

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +4.8%


✅ ospathbasename_noaspect

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

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +4.8%


✅ ospathjoin_aspect

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

Memory: ✅ 38.633MB (SLO: <41.000MB -5.8%) vs baseline: +5.5%


✅ ospathjoin_noaspect

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

Memory: ✅ 38.496MB (SLO: <41.000MB -6.1%) vs baseline: +4.6%


✅ ospathnormcase_aspect

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

Memory: ✅ 38.594MB (SLO: <41.000MB -5.9%) vs baseline: +4.8%


✅ ospathnormcase_noaspect

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

Memory: ✅ 38.516MB (SLO: <41.000MB -6.1%) vs baseline: +4.4%


✅ ospathsplit_aspect

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

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +4.6%


✅ ospathsplit_noaspect

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

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +5.0%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 38.614MB (SLO: <41.000MB -5.8%) vs baseline: +4.8%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 38.535MB (SLO: <41.000MB -6.0%) vs baseline: +4.8%


✅ ospathsplitext_aspect

Time: ✅ 4.489µs (SLO: <10.000µs 📉 -55.1%) vs baseline: -2.6%

Memory: ✅ 38.516MB (SLO: <41.000MB -6.1%) vs baseline: +4.6%


✅ ospathsplitext_noaspect

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

Memory: ✅ 38.594MB (SLO: <41.000MB -5.9%) vs baseline: +4.6%


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.534µs (SLO: <20.000µs 📉 -82.3%) vs baseline: 📈 +17.2%

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


✅ 1-count-metrics-100-times

Time: ✅ 208.854µs (SLO: <220.000µs -5.1%) vs baseline: +0.4%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.4%


✅ 1-distribution-metric-1-times

Time: ✅ 3.432µs (SLO: <20.000µs 📉 -82.8%) vs baseline: +1.8%

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.4%


✅ 1-distribution-metrics-100-times

Time: ✅ 220.216µs (SLO: <230.000µs -4.3%) vs baseline: +0.7%

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


✅ 1-gauge-metric-1-times

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

Memory: ✅ 34.741MB (SLO: <35.500MB -2.1%) vs baseline: +4.4%


✅ 1-gauge-metrics-100-times

Time: ✅ 137.262µs (SLO: <150.000µs -8.5%) vs baseline: +0.6%

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.9%


✅ 1-rate-metric-1-times

Time: ✅ 3.238µs (SLO: <20.000µs 📉 -83.8%) vs baseline: +1.4%

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.8%


✅ 1-rate-metrics-100-times

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

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.7%


✅ 100-count-metrics-100-times

Time: ✅ 20.683ms (SLO: <22.000ms -6.0%) vs baseline: -0.2%

Memory: ✅ 34.977MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.2%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.289ms (SLO: <2.550ms 📉 -10.3%) vs baseline: -1.5%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.412ms (SLO: <1.550ms -8.9%) vs baseline: +1.2%

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


✅ 100-rate-metrics-100-times

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

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.0%


✅ flush-1-metric

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

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


✅ flush-100-metrics

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

Memory: ✅ 35.173MB (SLO: <35.500MB 🟡 -0.9%) vs baseline: +4.8%


✅ flush-1000-metrics

Time: ✅ 2.170ms (SLO: <2.500ms 📉 -13.2%) vs baseline: -0.1%

Memory: ✅ 36.078MB (SLO: <36.500MB 🟡 -1.2%) vs baseline: +5.0%

🟡 Near SLO Breach (15 suites)
🟡 coreapiscenario - 10/10 (1 unstable)

⚠️ context_with_data_listeners

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

Memory: ✅ 34.819MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.6%


✅ context_with_data_no_listeners

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

Memory: ✅ 34.741MB (SLO: <35.500MB -2.1%) vs baseline: +4.7%


✅ get_item_exists

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.9%


✅ get_item_missing

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

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.6%


✅ set_item

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +5.3%


🟡 djangosimple - 30/30

✅ appsec

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

Memory: ✅ 68.184MB (SLO: <70.500MB -3.3%) vs baseline: +4.6%


✅ exception-replay-enabled

Time: ✅ 1.358ms (SLO: <1.450ms -6.3%) vs baseline: -0.8%

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


✅ iast

Time: ✅ 19.549ms (SLO: <22.250ms 📉 -12.1%) vs baseline: -0.5%

Memory: ✅ 68.282MB (SLO: <70.000MB -2.5%) vs baseline: +4.9%


✅ profiler

Time: ✅ 15.440ms (SLO: <16.550ms -6.7%) vs baseline: +0.7%

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


✅ resource-renaming

Time: ✅ 19.437ms (SLO: <21.750ms 📉 -10.6%) vs baseline: -0.4%

Memory: ✅ 68.341MB (SLO: <70.500MB -3.1%) vs baseline: +4.8%


✅ span-code-origin

Time: ✅ 20.002ms (SLO: <28.200ms 📉 -29.1%) vs baseline: +1.6%

Memory: ✅ 68.094MB (SLO: <71.000MB -4.1%) vs baseline: +4.6%


✅ tracer

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

Memory: ✅ 68.223MB (SLO: <70.000MB -2.5%) vs baseline: +4.8%


✅ tracer-and-profiler

Time: ✅ 21.732ms (SLO: <23.500ms -7.5%) vs baseline: ~same

Memory: ✅ 69.226MB (SLO: <71.000MB -2.5%) vs baseline: +4.9%


✅ tracer-dont-create-db-spans

Time: ✅ 19.594ms (SLO: <21.500ms -8.9%) vs baseline: -0.3%

Memory: ✅ 68.203MB (SLO: <70.000MB -2.6%) vs baseline: +4.6%


✅ tracer-minimal

Time: ✅ 16.801ms (SLO: <17.500ms -4.0%) vs baseline: ~same

Memory: ✅ 67.908MB (SLO: <70.000MB -3.0%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 19.487ms (SLO: <21.750ms 📉 -10.4%) vs baseline: -0.5%

Memory: ✅ 68.321MB (SLO: <72.500MB -5.8%) vs baseline: +5.1%


✅ tracer-no-caches

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

Memory: ✅ 67.928MB (SLO: <70.000MB -3.0%) vs baseline: +4.5%


✅ tracer-no-databases

Time: ✅ 19.100ms (SLO: <20.100ms -5.0%) vs baseline: +0.2%

Memory: ✅ 67.908MB (SLO: <70.000MB -3.0%) vs baseline: +4.7%


✅ tracer-no-middleware

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

Memory: ✅ 68.144MB (SLO: <70.000MB -2.7%) vs baseline: +4.7%


✅ tracer-no-templates

Time: ✅ 19.642ms (SLO: <22.000ms 📉 -10.7%) vs baseline: +1.5%

Memory: ✅ 68.144MB (SLO: <70.500MB -3.3%) vs baseline: +4.7%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.256ms (SLO: <19.850ms 📉 -18.1%) vs baseline: -0.6%

Memory: ✅ 69.874MB (SLO: <70.000MB 🟡 -0.2%) vs baseline: +4.9%


✅ errortracking-enabled-user

Time: ✅ 16.303ms (SLO: <19.400ms 📉 -16.0%) vs baseline: -0.3%

Memory: ✅ 69.893MB (SLO: <70.000MB 🟡 -0.2%) vs baseline: +5.0%


✅ tracer-enabled

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

Memory: ✅ 69.852MB (SLO: <70.000MB 🟡 -0.2%) vs baseline: +4.8%


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.065ms (SLO: <2.300ms 📉 -10.2%) vs baseline: -0.2%

Memory: ✅ 55.640MB (SLO: <56.500MB 🟡 -1.5%) vs baseline: +4.6%


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 2.060ms (SLO: <2.300ms 📉 -10.4%) vs baseline: ~same

Memory: ✅ 55.679MB (SLO: <56.500MB 🟡 -1.5%) vs baseline: +4.9%


🟡 flasksimple - 18/18

✅ appsec-get

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

Memory: ✅ 55.389MB (SLO: <66.500MB 📉 -16.7%) vs baseline: +4.7%


✅ appsec-post

Time: ✅ 2.852ms (SLO: <6.750ms 📉 -57.7%) vs baseline: ~same

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


✅ appsec-telemetry

Time: ✅ 3.395ms (SLO: <4.750ms 📉 -28.5%) vs baseline: +0.3%

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


✅ debugger

Time: ✅ 1.869ms (SLO: <2.000ms -6.6%) vs baseline: +0.1%

Memory: ✅ 47.766MB (SLO: <49.500MB -3.5%) vs baseline: +4.5%


✅ iast-get

Time: ✅ 1.856ms (SLO: <2.000ms -7.2%) vs baseline: -0.2%

Memory: ✅ 44.913MB (SLO: <49.000MB -8.3%) vs baseline: +5.2%


✅ profiler

Time: ✅ 1.906ms (SLO: <2.100ms -9.2%) vs baseline: -0.1%

Memory: ✅ 48.866MB (SLO: <50.000MB -2.3%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 3.357ms (SLO: <3.650ms -8.0%) vs baseline: ~same

Memory: ✅ 55.526MB (SLO: <56.000MB 🟡 -0.8%) vs baseline: +5.1%


✅ tracer

Time: ✅ 3.371ms (SLO: <3.650ms -7.6%) vs baseline: -0.1%

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


✅ tracer-native

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

Memory: ✅ 55.294MB (SLO: <60.000MB -7.8%) vs baseline: +4.7%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.062ms (SLO: <4.200ms 📉 -50.9%) vs baseline: ~same

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


✅ iast-enabled

Time: ✅ 2.067ms (SLO: <2.800ms 📉 -26.2%) vs baseline: +0.2%

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


✅ tracer-enabled

Time: ✅ 2.056ms (SLO: <2.250ms -8.6%) vs baseline: -0.2%

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.739µs (SLO: <100.000µs 📉 -18.3%) vs baseline: +0.2%

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


✅ b3_headers

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +5.3%


✅ b3_single_headers

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

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +5.5%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

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

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 69.428µs (SLO: <80.000µs 📉 -13.2%) vs baseline: +4.4%

Memory: ✅ 34.977MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.2%


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

Time: ✅ 22.802µs (SLO: <30.000µs 📉 -24.0%) vs baseline: +0.8%

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


✅ invalid_priority_header

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.2%


✅ invalid_span_id_header

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

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +5.0%


✅ invalid_tags_header

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

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.8%


✅ invalid_trace_id_header

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

Memory: ✅ 34.859MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.9%


✅ large_header_no_matches

Time: ✅ 27.570µs (SLO: <30.000µs -8.1%) vs baseline: -0.8%

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.6%


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.4%


✅ none_propagation_style

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

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.4%


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.3%


✅ valid_headers_basic

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

Memory: ✅ 34.996MB (SLO: <35.500MB 🟡 -1.4%) vs baseline: +5.2%


✅ wsgi_empty_headers

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.5%


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

Memory: ✅ 34.878MB (SLO: <35.500MB 🟡 -1.8%) vs baseline: +4.9%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +5.3%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.5%


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 21.732µs (SLO: <30.000µs 📉 -27.6%) vs baseline: +4.5%

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +5.2%


✅ with_all

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

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.5%


✅ with_dd_origin

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

Memory: ✅ 34.957MB (SLO: <35.500MB 🟡 -1.5%) vs baseline: +4.4%


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

Time: ✅ 20.816µs (SLO: <30.000µs 📉 -30.6%) vs baseline: -0.1%

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 40.192ms (SLO: <47.150ms 📉 -14.8%) vs baseline: -0.2%

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


✅ add-metrics

Time: ✅ 261.057ms (SLO: <344.800ms 📉 -24.3%) vs baseline: -0.9%

Memory: ✅ 43.826MB (SLO: <47.500MB -7.7%) vs baseline: +5.1%


✅ add-tags

Time: ✅ 316.118ms (SLO: <321.000ms 🟡 -1.5%) vs baseline: -1.1%

Memory: ✅ 43.759MB (SLO: <47.500MB -7.9%) vs baseline: +4.9%


✅ get-context

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

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


✅ is-recording

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

Memory: ✅ 39.474MB (SLO: <47.500MB 📉 -16.9%) vs baseline: +5.0%


✅ record-exception

Time: ✅ 58.642ms (SLO: <67.650ms 📉 -13.3%) vs baseline: -0.6%

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


✅ set-status

Time: ✅ 44.223ms (SLO: <50.400ms 📉 -12.3%) vs baseline: -0.4%

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


✅ start

Time: ✅ 38.125ms (SLO: <43.450ms 📉 -12.3%) vs baseline: +2.5%

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


✅ start-finish

Time: ✅ 82.600ms (SLO: <88.000ms -6.1%) vs baseline: +0.4%

Memory: ✅ 37.356MB (SLO: <46.500MB 📉 -19.7%) vs baseline: +4.6%


✅ start-finish-telemetry

Time: ✅ 84.261ms (SLO: <89.000ms -5.3%) vs baseline: +0.3%

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


✅ update-name

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

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


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

Memory: ✅ 35.055MB (SLO: <35.500MB 🟡 -1.3%) vs baseline: +4.7%


✅ low_rate_limit

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

Memory: ✅ 35.075MB (SLO: <35.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ no_rate_limit

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

Memory: ✅ 35.075MB (SLO: <35.500MB 🟡 -1.2%) vs baseline: +4.9%


✅ short_window

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

Memory: ✅ 35.134MB (SLO: <35.500MB 🟡 -1.0%) vs baseline: +5.0%


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 309.159ms (SLO: <320.950ms -3.7%) vs baseline: +0.1%

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


✅ deep-profiled

Time: ✅ 329.184ms (SLO: <359.150ms -8.3%) vs baseline: +0.1%

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


✅ medium

Time: ✅ 6.992ms (SLO: <7.400ms -5.5%) vs baseline: +0.1%

Memory: ✅ 34.760MB (SLO: <35.500MB -2.1%) vs baseline: +4.7%


✅ shallow

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

Memory: ✅ 34.839MB (SLO: <35.500MB 🟡 -1.9%) vs baseline: +4.5%


🟡 samplingrules - 8/8

✅ average_match

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

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


✅ high_match

Time: ✅ 172.872µs (SLO: <480.000µs 📉 -64.0%) vs baseline: -1.2%

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.7%


✅ low_match

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

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


✅ very_low_match

Time: ✅ 2.664ms (SLO: <8.500ms 📉 -68.7%) vs baseline: +0.4%

Memory: ✅ 71.040MB (SLO: <75.000MB -5.3%) vs baseline: +4.7%


🟡 sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

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

Memory: ✅ 35.448MB (SLO: <36.000MB 🟡 -1.5%) vs baseline: +4.5%


✅ collectipvariant_exists

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

Memory: ✅ 35.547MB (SLO: <36.000MB 🟡 -1.3%) vs baseline: +4.3%


✅ no-collectipvariant

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

Memory: ✅ 35.252MB (SLO: <36.000MB -2.1%) vs baseline: +3.4%


✅ no-useragentvariant

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

Memory: ✅ 35.291MB (SLO: <36.000MB 🟡 -2.0%) vs baseline: +4.0%


✅ obfuscation-no-query

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

Memory: ✅ 35.429MB (SLO: <36.000MB 🟡 -1.6%) vs baseline: +3.9%


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 35.704MB (SLO: <36.500MB -2.2%) vs baseline: +4.3%


✅ obfuscation-regular-case-implicit-query

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

Memory: ✅ 35.665MB (SLO: <36.500MB -2.3%) vs baseline: +4.6%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 35.684MB (SLO: <36.500MB -2.2%) vs baseline: +4.7%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 35.684MB (SLO: <36.500MB -2.2%) vs baseline: +4.9%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 154.831µs (SLO: <170.000µs -8.9%) vs baseline: -0.2%

Memory: ✅ 35.704MB (SLO: <36.500MB -2.2%) vs baseline: +4.7%


✅ useragentvariant_exists_1

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

Memory: ✅ 35.448MB (SLO: <36.000MB 🟡 -1.5%) vs baseline: +4.1%


✅ useragentvariant_exists_2

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

Memory: ✅ 35.448MB (SLO: <36.000MB 🟡 -1.5%) vs baseline: +4.3%


✅ useragentvariant_exists_3

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

Memory: ✅ 35.488MB (SLO: <36.000MB 🟡 -1.4%) vs baseline: +4.3%


✅ useragentvariant_not_exists_1

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

Memory: ✅ 35.291MB (SLO: <36.000MB 🟡 -2.0%) vs baseline: +3.5%


✅ useragentvariant_not_exists_2

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

Memory: ✅ 35.448MB (SLO: <36.000MB 🟡 -1.5%) vs baseline: +4.2%


🟡 span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 87.957ms (SLO: <93.500ms -5.9%) vs baseline: -0.9%

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


✅ add-tags

Time: ✅ 142.726ms (SLO: <155.000ms -7.9%) vs baseline: +0.4%

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


✅ get-context

Time: ✅ 17.017ms (SLO: <20.500ms 📉 -17.0%) vs baseline: -0.3%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.672ms (SLO: <40.000ms -8.3%) vs baseline: +0.1%

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


✅ set-status

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

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


✅ start

Time: ✅ 17.521ms (SLO: <20.500ms 📉 -14.5%) vs baseline: +3.8%

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


✅ start-finish

Time: ✅ 50.884ms (SLO: <52.500ms -3.1%) vs baseline: -0.5%

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


✅ start-finish-telemetry

Time: ✅ 52.659ms (SLO: <54.500ms -3.4%) vs baseline: +0.4%

Memory: ✅ 34.800MB (SLO: <35.500MB 🟡 -2.0%) vs baseline: +4.7%


✅ start-finish-traceid128

Time: ✅ 54.125ms (SLO: <57.000ms -5.0%) vs baseline: -0.2%

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


✅ start-traceid128

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

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


✅ update-name

Time: ✅ 17.374ms (SLO: <22.000ms 📉 -21.0%) vs baseline: -0.3%

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


🟡 tracer - 6/6

✅ large

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

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


✅ medium

Time: ✅ 2.875ms (SLO: <3.200ms 📉 -10.2%) vs baseline: -0.8%

Memory: ✅ 34.780MB (SLO: <35.500MB -2.0%) vs baseline: +4.7%


✅ small

Time: ✅ 332.272µs (SLO: <370.000µs 📉 -10.2%) vs baseline: +1.3%

Memory: ✅ 34.898MB (SLO: <35.500MB 🟡 -1.7%) vs baseline: +5.1%

⚠️ Unstable Tests (1 suite)
⚠️ packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 155.175µs (SLO: <170.000µs -8.7%) vs baseline: -0.9%

Memory: ✅ 39.856MB (SLO: <41.000MB -2.8%) vs baseline: +5.0%


✅ import_many_cached

Time: ✅ 120.669µs (SLO: <130.000µs -7.2%) vs baseline: -0.5%

Memory: ✅ 39.791MB (SLO: <41.000MB -2.9%) vs baseline: +4.8%


✅ import_many_stdlib

Time: ✅ 0.757ms (SLO: <1.750ms 📉 -56.7%) vs baseline: +0.9%

Memory: ✅ 39.805MB (SLO: <41.000MB -2.9%) vs baseline: +4.8%


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.173ms (SLO: <1.100ms 📉 -84.3%) vs baseline: +0.1%

Memory: ✅ 39.786MB (SLO: <41.000MB -3.0%) vs baseline: +4.9%


✅ import_many_unknown

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

Memory: ✅ 39.990MB (SLO: <41.000MB -2.5%) vs baseline: +4.3%


✅ import_many_unknown_cached

Time: ✅ 798.230µs (SLO: <870.000µs -8.2%) vs baseline: +0.4%

Memory: ✅ 39.919MB (SLO: <41.000MB -2.6%) vs baseline: +4.8%


✅ import_one

Time: ✅ 19.799µs (SLO: <30.000µs 📉 -34.0%) vs baseline: +0.8%

Memory: ✅ 39.884MB (SLO: <41.000MB -2.7%) vs baseline: +5.2%


✅ import_one_cache

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

Memory: ✅ 39.939MB (SLO: <41.000MB -2.6%) vs baseline: +5.5%


✅ import_one_stdlib

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

Memory: ✅ 39.920MB (SLO: <41.000MB -2.6%) vs baseline: +6.2%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.890MB (SLO: <41.000MB -2.7%) vs baseline: +4.6%


✅ import_one_unknown

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

Memory: ✅ 39.824MB (SLO: <41.000MB -2.9%) vs baseline: +4.8%


✅ import_one_unknown_cache

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

Memory: ✅ 39.908MB (SLO: <41.000MB -2.7%) vs baseline: +5.0%

✅ All Tests Passing (5 suites)
iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 33.567µs (SLO: <40.000µs 📉 -16.1%) vs baseline: +4.6%

Memory: ✅ 38.555MB (SLO: <41.000MB -6.0%) vs baseline: +4.9%


✅ re_expand_noaspect

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

Memory: ✅ 38.594MB (SLO: <41.000MB -5.9%) vs baseline: +5.2%


✅ re_findall_aspect

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

Memory: ✅ 38.633MB (SLO: <41.000MB -5.8%) vs baseline: +4.9%


✅ re_findall_noaspect

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

Memory: ✅ 38.496MB (SLO: <41.000MB -6.1%) vs baseline: +4.5%


✅ re_finditer_aspect

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

Memory: ✅ 38.378MB (SLO: <41.000MB -6.4%) vs baseline: +4.3%


✅ re_finditer_noaspect

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

Memory: ✅ 38.516MB (SLO: <41.000MB -6.1%) vs baseline: +4.4%


✅ re_fullmatch_aspect

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

Memory: ✅ 38.496MB (SLO: <41.000MB -6.1%) vs baseline: +4.6%


✅ re_fullmatch_noaspect

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

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +4.6%


✅ re_group_aspect

Time: ✅ 2.881µs (SLO: <10.000µs 📉 -71.2%) vs baseline: -2.9%

Memory: ✅ 38.614MB (SLO: <41.000MB -5.8%) vs baseline: +4.8%


✅ re_group_noaspect

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

Memory: ✅ 38.614MB (SLO: <41.000MB -5.8%) vs baseline: +4.9%


✅ re_groups_aspect

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

Memory: ✅ 38.633MB (SLO: <41.000MB -5.8%) vs baseline: +4.9%


✅ re_groups_noaspect

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

Memory: ✅ 38.692MB (SLO: <41.000MB -5.6%) vs baseline: +5.2%


✅ re_match_aspect

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

Memory: ✅ 38.673MB (SLO: <41.000MB -5.7%) vs baseline: +4.9%


✅ re_match_noaspect

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

Memory: ✅ 38.692MB (SLO: <41.000MB -5.6%) vs baseline: +5.4%


✅ re_search_aspect

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

Memory: ✅ 38.555MB (SLO: <41.000MB -6.0%) vs baseline: +4.6%


✅ re_search_noaspect

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

Memory: ✅ 38.574MB (SLO: <41.000MB -5.9%) vs baseline: +4.7%


✅ re_sub_aspect

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

Memory: ✅ 38.594MB (SLO: <41.000MB -5.9%) vs baseline: +4.9%


✅ re_sub_noaspect

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

Memory: ✅ 38.614MB (SLO: <41.000MB -5.8%) vs baseline: +4.9%


✅ re_subn_aspect

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

Memory: ✅ 38.653MB (SLO: <41.000MB -5.7%) vs baseline: +5.0%


✅ re_subn_noaspect

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

Memory: ✅ 38.633MB (SLO: <41.000MB -5.8%) vs baseline: +4.8%


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 38.555MB (SLO: <41.000MB -6.0%) vs baseline: +4.6%


✅ rsplit_noaspect

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

Memory: ✅ 38.633MB (SLO: <41.000MB -5.8%) vs baseline: +5.3%


✅ split_aspect

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

Memory: ✅ 38.614MB (SLO: <41.000MB -5.8%) vs baseline: +4.9%


✅ split_noaspect

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

Memory: ✅ 38.653MB (SLO: <41.000MB -5.7%) vs baseline: +5.1%


✅ splitlines_aspect

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

Memory: ✅ 38.496MB (SLO: <41.000MB -6.1%) vs baseline: +4.5%


✅ splitlines_noaspect

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

Memory: ✅ 38.496MB (SLO: <41.000MB -6.1%) vs baseline: +4.7%


iastpropagation - 7/7

✅ no-propagation

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

Memory: ✅ 38.221MB (SLO: <42.000MB -9.0%) vs baseline: +4.9%


✅ propagation_enabled

Time: ✅ 135.312µs (SLO: <190.000µs 📉 -28.8%) vs baseline: -0.3%

Memory: ✅ 38.240MB (SLO: <42.000MB -9.0%) vs baseline: +5.1%


✅ propagation_enabled_100

Time: ✅ 1.555ms (SLO: <2.300ms 📉 -32.4%) vs baseline: +0.2%


✅ propagation_enabled_1000

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

Memory: ✅ 38.614MB (SLO: <42.000MB -8.1%) vs baseline: +4.9%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.429ms (SLO: <42.000ms -3.7%) vs baseline: +0.7%

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


✅ add-link

Time: ✅ 36.171ms (SLO: <38.550ms -6.2%) vs baseline: -0.2%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.4%


✅ add-metrics

Time: ✅ 219.707ms (SLO: <232.000ms -5.3%) vs baseline: ~same

Memory: ✅ 37.690MB (SLO: <39.000MB -3.4%) vs baseline: +5.0%


✅ add-tags

Time: ✅ 211.482ms (SLO: <221.600ms -4.6%) vs baseline: ~same

Memory: ✅ 37.690MB (SLO: <39.000MB -3.4%) vs baseline: +5.1%


✅ get-context

Time: ✅ 29.173ms (SLO: <31.300ms -6.8%) vs baseline: +0.7%

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


✅ is-recording

Time: ✅ 29.138ms (SLO: <31.000ms -6.0%) vs baseline: +0.2%

Memory: ✅ 37.454MB (SLO: <39.000MB -4.0%) vs baseline: +4.5%


✅ record-exception

Time: ✅ 63.189ms (SLO: <65.850ms -4.0%) vs baseline: +0.1%

Memory: ✅ 37.670MB (SLO: <39.000MB -3.4%) vs baseline: +4.9%


✅ set-status

Time: ✅ 31.876ms (SLO: <34.150ms -6.7%) vs baseline: +0.4%

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


✅ start

Time: ✅ 29.258ms (SLO: <30.150ms -3.0%) vs baseline: +2.0%

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


✅ start-finish

Time: ✅ 34.063ms (SLO: <35.350ms -3.6%) vs baseline: +0.7%

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


✅ start-finish-telemetry

Time: ✅ 34.086ms (SLO: <35.450ms -3.8%) vs baseline: +0.2%

Memory: ✅ 37.709MB (SLO: <39.000MB -3.3%) vs baseline: +4.9%


✅ update-name

Time: ✅ 31.086ms (SLO: <33.400ms -6.9%) vs baseline: +0.7%

Memory: ✅ 37.434MB (SLO: <39.000MB -4.0%) vs baseline: +4.4%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 342.232ms (SLO: <354.300ms -3.4%) vs baseline: -0.8%

Memory: ✅ 40.554MB (SLO: <41.500MB -2.3%) vs baseline: +4.0%


✅ cache_on

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

Memory: ✅ 39.037MB (SLO: <41.000MB -4.8%) vs baseline: +4.8%

ℹ️ Scenarios Missing SLO Configuration (10 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
  • sethttpmeta-obfuscation-disabled

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

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

2 participants