Skip to content

Conversation

@avara1986
Copy link
Member

@avara1986 avara1986 commented Nov 25, 2025

Upgrade vendored psutil from 5.6.7 to 7.1.3 to address security vulnerabilities and modernize the dependency.

Key changes:

  • Remove insecure xml.etree.ElementTree functions used to parse input from *BSD kernel (kern.sched.topology_spec)
  • Drop Python 2.x support (psutil 7.x requires Python 3.6+)
  • Update all platform-specific implementations (Linux, Windows, macOS, *BSD, Solaris, AIX)
  • Restructure C extension modules with improved organization under arch/ directories
  • Modernize Python code (f-strings, type hints compatibility, removal of Python 2 compatibility layer)

Security improvements:

  • Addresses APPSEC-60046: Removes vulnerable XML parsing functions that could potentially be exploited on *BSD systems

@avara1986 avara1986 added the changelog/no-changelog A changelog entry is not required for this PR. label Nov 25, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Nov 25, 2025

CODEOWNERS have been resolved as:

ddtrace/vendor/psutil/arch/all/errors.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/all/init.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/all/init.h                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/all/pids.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/all/str.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/cpu.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/disk.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/init.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/init.h                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/net.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/proc.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/proc_utils.c                             @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/bsd/sys.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/cpu.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/disk.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/init.h                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/mem.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/pids.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/proc.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/sensors.c                            @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/linux/disk.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/linux/init.h                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/linux/mem.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/linux/net.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/linux/proc.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/cpu.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/disk.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/init.h                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/mem.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/pids.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/proc.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/cpu.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/disk.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/mem.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/pids.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/proc.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/socks.c                              @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/users.c                              @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/cpu.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/disk.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/init.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/init.h                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/mem.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/net.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/pids.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/proc.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/proc_utils.c                             @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/sensors.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/sys.c                                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/init.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/init.h                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/pids.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/proc.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/sysctl.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/users.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/cpu.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/disk.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/init.h                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/mem.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/net.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/proc.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/sys.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/cpu.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/disk.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/init.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/init.h                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/mem.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/net.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/pids.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/proc.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/proc_handles.c                       @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/proc_info.c                          @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/proc_utils.c                         @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/sensors.c                            @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/socks.c                              @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/sys.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/__init__.py                                       @DataDog/apm-core-python
ddtrace/vendor/psutil/_common.py                                        @DataDog/apm-core-python
ddtrace/vendor/psutil/_psaix.py                                         @DataDog/apm-core-python
ddtrace/vendor/psutil/_psbsd.py                                         @DataDog/apm-core-python
ddtrace/vendor/psutil/_pslinux.py                                       @DataDog/apm-core-python
ddtrace/vendor/psutil/_psosx.py                                         @DataDog/apm-core-python
ddtrace/vendor/psutil/_psposix.py                                       @DataDog/apm-core-python
ddtrace/vendor/psutil/_pssunos.py                                       @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_aix.c                                     @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_bsd.c                                     @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_linux.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_osx.c                                     @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_sunos.c                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_windows.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/_pswindows.py                                     @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/common.c                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/common.h                                 @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/ifaddrs.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/ifaddrs.h                                @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/net_connections.c                        @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/net_connections.h                        @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/aix/net_kernel_structs.h                     @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/proc_socks.c                         @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/sys_socks.c                          @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/socks.c                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/ntextapi.h                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/security.c                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/services.c                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/wmi.c                                @DataDog/apm-core-python
ddtrace/vendor/psutil/setup.py                                          @DataDog/python-guild
tests/profiling/suitespec.yml                                           @DataDog/profiling-python
tests/suitespec.yml                                                     @DataDog/python-guild @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/init.h                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/posix/net.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/sunos/environ.c                              @DataDog/apm-core-python
ddtrace/vendor/psutil/_compat.py                                        @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_common.c                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_common.h                                  @DataDog/apm-core-python
ddtrace/vendor/psutil/_psutil_posix.h                                   @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/proc_socks.h                         @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/specific.c                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/specific.h                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/freebsd/sys_socks.h                          @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/socks.h                               @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/specific.c                            @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/netbsd/specific.h                            @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/openbsd/specific.c                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/process_info.c                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/osx/process_info.h                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/solaris/environ.h                            @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/solaris/v10/ifaddrs.c                        @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/solaris/v10/ifaddrs.h                        @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/global.c                             @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/global.h                             @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/inet_ntop.c                          @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/inet_ntop.h                          @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/process_handles.c                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/process_handles.h                    @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/process_info.c                       @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/process_info.h                       @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/security.h                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/services.h                           @DataDog/apm-core-python
ddtrace/vendor/psutil/arch/windows/wmi.h                                @DataDog/apm-core-python

@github-actions
Copy link
Contributor

github-actions bot commented Nov 25, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

The average import time from this PR is: 251 ± 4 ms.

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

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

Import time breakdown

The following import paths have appeared:

ddtrace.auto 0.335 ms (0.13%)
ddtrace.bootstrap.sitecustomize 0.335 ms (0.13%)
ddtrace.bootstrap.preload 0.335 ms (0.13%)
ddtrace.internal.settings.profiling 0.335 ms (0.13%)
ddtrace.vendor.psutil 0.335 ms (0.13%)
ddtrace.vendor.psutil._pslinux 0.335 ms (0.13%)
resource 0.335 ms (0.13%)

The following import paths have disappeared:

ddtrace.auto 0.662 ms (0.26%)
ddtrace.bootstrap.sitecustomize 0.662 ms (0.26%)
ddtrace.bootstrap.preload 0.662 ms (0.26%)
ddtrace.internal.settings.profiling 0.662 ms (0.26%)
ddtrace.vendor.psutil 0.662 ms (0.26%)
ddtrace.vendor.psutil._compat 0.378 ms (0.15%)
ddtrace.vendor.psutil._pslinux 0.284 ms (0.11%)
ddtrace.vendor.psutil._psutil_posix 0.284 ms (0.11%)

The following import paths have grown:

ddtrace.auto 1.686 ms (0.67%)
ddtrace.bootstrap.sitecustomize 1.686 ms (0.67%)
ddtrace.bootstrap.preload 1.686 ms (0.67%)
multiprocessing 0.913 ms (0.36%)
multiprocessing.context 0.913 ms (0.36%)
multiprocessing.reduction 0.834 ms (0.33%)
pickle 0.834 ms (0.33%)
_pickle 0.834 ms (0.33%)
multiprocessing.process 0.079 ms (0.03%)
ddtrace.internal.settings.profiling 0.606 ms (0.24%)
ddtrace.vendor.psutil 0.606 ms (0.24%)
ddtrace.vendor.psutil._pslinux 0.449 ms (0.18%)
ddtrace.vendor.psutil._psposix 0.449 ms (0.18%)
ddtrace.vendor.psutil._common 0.157 ms (0.06%)
ddtrace.internal.remoteconfig._connectors 0.094 ms (0.04%)
multiprocessing.sharedctypes 0.073 ms (0.03%)
multiprocessing.heap 0.073 ms (0.03%)

The following import paths have shrunk:

ddtrace.auto 4.080 ms (1.62%)
ddtrace.bootstrap.sitecustomize 2.711 ms (1.08%)
ddtrace.bootstrap.preload 2.711 ms (1.08%)
multiprocessing 0.946 ms (0.38%)
multiprocessing.context 0.946 ms (0.38%)
multiprocessing.reduction 0.946 ms (0.38%)
pickle 0.872 ms (0.35%)
ddtrace.internal.remoteconfig.client 0.642 ms (0.26%)
ddtrace.internal.settings.profiling 0.229 ms (0.09%)
ddtrace.vendor.psutil 0.166 ms (0.07%)
ddtrace.vendor.psutil._pslinux 0.064 ms (0.03%)
glob 0.064 ms (0.03%)
ddtrace.internal.datadog.profiling 0.062 ms (0.02%)
ddtrace.internal.remoteconfig._publishers 0.095 ms (0.04%)
multiprocessing.sharedctypes 0.069 ms (0.03%)
multiprocessing.heap 0.069 ms (0.03%)
multiprocessing.util 0.069 ms (0.03%)
ddtrace 1.370 ms (0.54%)
ddtrace._logger 0.686 ms (0.27%)
ddtrace.internal.telemetry 0.686 ms (0.27%)
ddtrace.internal.telemetry.writer 0.686 ms (0.27%)
ddtrace.internal.utils.version 0.686 ms (0.27%)
ddtrace.version 0.686 ms (0.27%)
ddtrace.internal._unpatched 0.029 ms (0.01%)
json 0.029 ms (0.01%)
json.decoder 0.029 ms (0.01%)
re 0.029 ms (0.01%)
enum 0.029 ms (0.01%)
types 0.029 ms (0.01%)

@pr-commenter
Copy link

pr-commenter bot commented Nov 25, 2025

Performance SLOs

Comparing candidate avara1986/APPSEC-60046_upgrade_psutil (7e9bf59) with baseline main (6a92ecd)

📈 Performance Regressions (2 suites)
📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 5.221µs (SLO: <10.000µs 📉 -47.8%) vs baseline: 📈 +20.7%

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

Time: ✅ 4.805µs (SLO: <10.000µs 📉 -52.0%) vs baseline: -1.9%

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


✅ ospathsplit_noaspect

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

Memory: ✅ 40.442MB (SLO: <41.000MB 🟡 -1.4%) vs baseline: +5.3%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 40.187MB (SLO: <41.000MB 🟡 -2.0%) vs baseline: +4.8%


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.445µs (SLO: <20.000µs 📉 -82.8%) vs baseline: 📈 +18.5%

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


✅ 1-count-metrics-100-times

Time: ✅ 204.147µs (SLO: <220.000µs -7.2%) vs baseline: +2.4%

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 215.868µs (SLO: <230.000µs -6.1%) vs baseline: +1.0%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 135.698µs (SLO: <150.000µs -9.5%) vs baseline: -1.2%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 215.624µs (SLO: <250.000µs 📉 -13.8%) vs baseline: +1.3%

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


✅ 100-count-metrics-100-times

Time: ✅ 20.278ms (SLO: <22.000ms -7.8%) vs baseline: +0.5%

Memory: ✅ 35.212MB (SLO: <35.500MB 🟡 -0.8%) vs baseline: +5.6%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.238ms (SLO: <2.300ms -2.7%) vs baseline: -1.5%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.405ms (SLO: <1.550ms -9.3%) vs baseline: +0.6%

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.211ms (SLO: <2.550ms 📉 -13.3%) vs baseline: +0.7%

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


✅ flush-1-metric

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

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


✅ flush-100-metrics

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

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


✅ flush-1000-metrics

Time: ✅ 2.182ms (SLO: <2.500ms 📉 -12.7%) vs baseline: -0.4%

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

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

⚠️ context_with_data_listeners

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

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

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

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


🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 19.615ms (SLO: <22.300ms 📉 -12.0%) vs baseline: +0.3%

Memory: ✅ 68.252MB (SLO: <70.500MB -3.2%) vs baseline: +4.8%


✅ exception-replay-enabled

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

Memory: ✅ 66.430MB (SLO: <67.500MB 🟡 -1.6%) vs baseline: +5.2%


✅ iast

Time: ✅ 19.650ms (SLO: <22.250ms 📉 -11.7%) vs baseline: +0.6%

Memory: ✅ 68.127MB (SLO: <70.000MB -2.7%) vs baseline: +4.6%


✅ profiler

Time: ✅ 15.688ms (SLO: <16.550ms -5.2%) vs baseline: ~same

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


✅ resource-renaming

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

Memory: ✅ 68.198MB (SLO: <70.500MB -3.3%) vs baseline: +4.8%


✅ span-code-origin

Time: ✅ 23.528ms (SLO: <28.200ms 📉 -16.6%) vs baseline: +0.9%

Memory: ✅ 69.452MB (SLO: <71.000MB -2.2%) vs baseline: +4.6%


✅ tracer

Time: ✅ 19.582ms (SLO: <21.750ms -10.0%) vs baseline: +0.1%

Memory: ✅ 68.158MB (SLO: <70.000MB -2.6%) vs baseline: +4.7%


✅ tracer-and-profiler

Time: ✅ 21.855ms (SLO: <23.500ms -7.0%) vs baseline: ~same

Memory: ✅ 69.403MB (SLO: <71.000MB -2.2%) vs baseline: +4.8%


✅ tracer-dont-create-db-spans

Time: ✅ 19.638ms (SLO: <21.500ms -8.7%) vs baseline: +0.2%

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


✅ tracer-minimal

Time: ✅ 16.818ms (SLO: <17.500ms -3.9%) vs baseline: +0.3%

Memory: ✅ 68.007MB (SLO: <70.000MB -2.8%) vs baseline: +5.1%


✅ tracer-native

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

Memory: ✅ 68.196MB (SLO: <72.500MB -5.9%) vs baseline: +4.8%


✅ tracer-no-caches

Time: ✅ 17.540ms (SLO: <19.650ms 📉 -10.7%) vs baseline: -0.6%

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


✅ tracer-no-databases

Time: ✅ 19.171ms (SLO: <20.100ms -4.6%) vs baseline: +0.5%

Memory: ✅ 67.981MB (SLO: <70.000MB -2.9%) vs baseline: +4.9%


✅ tracer-no-middleware

Time: ✅ 19.288ms (SLO: <21.500ms 📉 -10.3%) vs baseline: -0.2%

Memory: ✅ 67.988MB (SLO: <70.000MB -2.9%) vs baseline: +5.0%


✅ tracer-no-templates

Time: ✅ 19.582ms (SLO: <22.000ms 📉 -11.0%) vs baseline: +1.4%

Memory: ✅ 68.177MB (SLO: <70.500MB -3.3%) vs baseline: +4.9%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.242ms (SLO: <19.850ms 📉 -18.2%) vs baseline: -0.4%

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 16.357ms (SLO: <19.450ms 📉 -15.9%) vs baseline: +0.5%

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

Time: ✅ 2.074ms (SLO: <2.250ms -7.8%) vs baseline: ~same

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


✅ tracer-enabled

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

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


🟡 flasksimple - 18/18

✅ appsec-get

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

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


✅ appsec-post

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

Memory: ✅ 55.529MB (SLO: <66.500MB 📉 -16.5%) vs baseline: +4.1%


✅ appsec-telemetry

Time: ✅ 3.409ms (SLO: <4.750ms 📉 -28.2%) vs baseline: +1.3%

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


✅ debugger

Time: ✅ 1.867ms (SLO: <2.000ms -6.7%) vs baseline: ~same

Memory: ✅ 47.981MB (SLO: <49.500MB -3.1%) vs baseline: +5.0%


✅ iast-get

Time: ✅ 1.858ms (SLO: <2.000ms -7.1%) vs baseline: ~same

Memory: ✅ 44.717MB (SLO: <49.000MB -8.7%) vs baseline: +4.5%


✅ profiler

Time: ✅ 1.935ms (SLO: <2.100ms -7.8%) vs baseline: ~same

Memory: ✅ 48.825MB (SLO: <50.000MB -2.4%) vs baseline: +4.7%


✅ resource-renaming

Time: ✅ 3.349ms (SLO: <3.650ms -8.2%) vs baseline: -0.3%

Memory: ✅ 55.451MB (SLO: <56.000MB 🟡 -1.0%) vs baseline: +4.6%


✅ tracer

Time: ✅ 3.363ms (SLO: <3.650ms -7.9%) vs baseline: -0.2%

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


✅ tracer-native

Time: ✅ 3.363ms (SLO: <3.650ms -7.9%) vs baseline: -0.2%

Memory: ✅ 55.551MB (SLO: <60.000MB -7.4%) vs baseline: +4.9%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.061ms (SLO: <4.200ms 📉 -50.9%) vs baseline: -0.2%

Memory: ✅ 55.463MB (SLO: <66.000MB 📉 -16.0%) vs baseline: +4.5%


✅ iast-enabled

Time: ✅ 2.070ms (SLO: <2.800ms 📉 -26.1%) vs baseline: +0.1%

Memory: ✅ 55.404MB (SLO: <62.500MB 📉 -11.4%) vs baseline: +4.4%


✅ tracer-enabled

Time: ✅ 2.058ms (SLO: <2.250ms -8.5%) vs baseline: ~same

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

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

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 63.677µs (SLO: <80.000µs 📉 -20.4%) vs baseline: -0.6%

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 65.964µs (SLO: <80.000µs 📉 -17.5%) vs baseline: -0.4%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

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

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

Time: ✅ 34.643µs (SLO: <40.000µs 📉 -13.4%) vs baseline: -1.0%

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 21.965µs (SLO: <30.000µs 📉 -26.8%) vs baseline: +4.7%

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


✅ with_all

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

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 iast_aspects - 40/40

✅ re_expand_aspect

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

Memory: ✅ 40.423MB (SLO: <41.000MB 🟡 -1.4%) vs baseline: +5.4%


✅ re_expand_noaspect

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

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


✅ re_findall_aspect

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

Memory: ✅ 40.187MB (SLO: <41.000MB 🟡 -2.0%) vs baseline: +4.5%


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

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

Memory: ✅ 40.265MB (SLO: <41.000MB 🟡 -1.8%) vs baseline: +5.1%


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

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

Memory: ✅ 40.423MB (SLO: <41.000MB 🟡 -1.4%) vs baseline: +5.5%


✅ re_groups_noaspect

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

Memory: ✅ 40.423MB (SLO: <41.000MB 🟡 -1.4%) vs baseline: +5.4%


✅ re_match_aspect

Time: ✅ 2.727µs (SLO: <10.000µs 📉 -72.7%) vs baseline: +2.0%

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


✅ re_match_noaspect

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

Memory: ✅ 40.265MB (SLO: <41.000MB 🟡 -1.8%) vs baseline: +5.1%


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

Time: ✅ 3.471µs (SLO: <10.000µs 📉 -65.3%) vs baseline: +2.9%

Memory: ✅ 40.305MB (SLO: <41.000MB 🟡 -1.7%) vs baseline: +5.0%


✅ re_sub_noaspect

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

Memory: ✅ 40.305MB (SLO: <41.000MB 🟡 -1.7%) vs baseline: +5.0%


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


🟡 iastaspects - 118/118

✅ add_aspect

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

Memory: ✅ 40.678MB (SLO: <41.500MB 🟡 -2.0%) vs baseline: +5.3%


✅ add_inplace_aspect

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

Memory: ✅ 40.499MB (SLO: <41.500MB -2.4%) vs baseline: +5.7%


✅ add_inplace_noaspect

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

Memory: ✅ 40.461MB (SLO: <41.500MB -2.5%) vs baseline: +4.4%


✅ add_noaspect

Time: ✅ 0.278µs (SLO: <10.000µs 📉 -97.2%) vs baseline: -1.9%

Memory: ✅ 40.678MB (SLO: <41.500MB 🟡 -2.0%) vs baseline: +5.0%


✅ bytearray_aspect

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

Memory: ✅ 40.599MB (SLO: <41.500MB -2.2%) vs baseline: +4.9%


✅ bytearray_extend_aspect

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

Memory: ✅ 40.600MB (SLO: <41.500MB -2.2%) vs baseline: +4.8%


✅ bytearray_extend_noaspect

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

Memory: ✅ 40.619MB (SLO: <41.500MB -2.1%) vs baseline: +5.6%


✅ bytearray_noaspect

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

Memory: ✅ 40.559MB (SLO: <41.500MB -2.3%) vs baseline: +4.8%


✅ bytes_aspect

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

Memory: ✅ 40.659MB (SLO: <41.500MB -2.0%) vs baseline: +5.0%


✅ bytes_noaspect

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

Memory: ✅ 40.501MB (SLO: <41.500MB -2.4%) vs baseline: +4.9%


✅ bytesio_aspect

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

Memory: ✅ 40.619MB (SLO: <41.500MB -2.1%) vs baseline: +5.0%


✅ bytesio_noaspect

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

Memory: ✅ 40.383MB (SLO: <41.500MB -2.7%) vs baseline: +4.4%


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

Memory: ✅ 40.500MB (SLO: <41.500MB -2.4%) vs baseline: +4.6%


✅ casefold_aspect

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

Memory: ✅ 40.600MB (SLO: <41.500MB -2.2%) vs baseline: +4.9%


✅ casefold_noaspect

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

Memory: ✅ 40.422MB (SLO: <41.500MB -2.6%) vs baseline: +4.3%


✅ decode_aspect

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

Memory: ✅ 40.459MB (SLO: <41.500MB -2.5%) vs baseline: +4.4%


✅ decode_noaspect

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

Memory: ✅ 40.421MB (SLO: <41.500MB -2.6%) vs baseline: +4.2%


✅ encode_aspect

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

Memory: ✅ 40.519MB (SLO: <41.500MB -2.4%) vs baseline: +4.6%


✅ encode_noaspect

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

Memory: ✅ 40.461MB (SLO: <41.500MB -2.5%) vs baseline: +4.3%


✅ format_aspect

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

Memory: ✅ 40.659MB (SLO: <41.500MB -2.0%) vs baseline: +5.2%


✅ format_map_aspect

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

Memory: ✅ 40.420MB (SLO: <41.500MB -2.6%) vs baseline: +5.2%


✅ format_map_noaspect

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

Memory: ✅ 40.500MB (SLO: <41.500MB -2.4%) vs baseline: +4.7%


✅ format_noaspect

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

Memory: ✅ 40.343MB (SLO: <41.500MB -2.8%) vs baseline: +4.1%


✅ index_aspect

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

Memory: ✅ 40.658MB (SLO: <41.500MB -2.0%) vs baseline: +5.2%


✅ index_noaspect

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

Memory: ✅ 40.343MB (SLO: <41.500MB -2.8%) vs baseline: +4.2%


✅ join_aspect

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

Memory: ✅ 40.600MB (SLO: <41.500MB -2.2%) vs baseline: +4.8%


✅ join_noaspect

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

Memory: ✅ 40.619MB (SLO: <41.500MB -2.1%) vs baseline: +5.0%


✅ ljust_aspect

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

Memory: ✅ 40.659MB (SLO: <41.500MB -2.0%) vs baseline: +5.1%


✅ ljust_noaspect

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

Memory: ✅ 40.403MB (SLO: <41.500MB -2.6%) vs baseline: +4.3%


✅ lower_aspect

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

Memory: ✅ 40.520MB (SLO: <41.500MB -2.4%) vs baseline: +4.7%


✅ lower_noaspect

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

Memory: ✅ 40.462MB (SLO: <41.500MB -2.5%) vs baseline: +4.7%


✅ lstrip_aspect

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

Memory: ✅ 40.600MB (SLO: <41.500MB -2.2%) vs baseline: +4.9%


✅ lstrip_noaspect

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

Memory: ✅ 40.422MB (SLO: <41.500MB -2.6%) vs baseline: +4.6%


✅ modulo_aspect

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

Memory: ✅ 40.657MB (SLO: <41.500MB -2.0%) vs baseline: +5.1%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 40.262MB (SLO: <41.500MB -3.0%) vs baseline: +4.0%


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 40.185MB (SLO: <41.500MB -3.2%) vs baseline: +3.8%


✅ modulo_noaspect

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

Memory: ✅ 40.462MB (SLO: <41.500MB -2.5%) vs baseline: +4.5%


✅ replace_aspect

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

Memory: ✅ 40.319MB (SLO: <41.500MB -2.8%) vs baseline: +4.3%


✅ replace_noaspect

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

Memory: ✅ 40.422MB (SLO: <41.500MB -2.6%) vs baseline: +4.3%


✅ repr_aspect

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

Memory: ✅ 40.678MB (SLO: <41.500MB 🟡 -2.0%) vs baseline: +5.0%


✅ repr_noaspect

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

Memory: ✅ 40.659MB (SLO: <41.500MB -2.0%) vs baseline: +5.0%


✅ rstrip_aspect

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

Memory: ✅ 40.678MB (SLO: <41.500MB 🟡 -2.0%) vs baseline: +5.3%


✅ rstrip_noaspect

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

Memory: ✅ 40.363MB (SLO: <41.500MB -2.7%) vs baseline: +4.0%


✅ slice_aspect

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

Memory: ✅ 40.600MB (SLO: <41.500MB -2.2%) vs baseline: +4.9%


✅ slice_noaspect

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

Memory: ✅ 40.462MB (SLO: <41.500MB -2.5%) vs baseline: +4.4%


✅ stringio_aspect

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

Memory: ✅ 40.398MB (SLO: <41.500MB -2.7%) vs baseline: +4.5%


✅ stringio_noaspect

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

Memory: ✅ 40.462MB (SLO: <41.500MB -2.5%) vs baseline: +4.6%


✅ strip_aspect

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

Memory: ✅ 40.520MB (SLO: <41.500MB -2.4%) vs baseline: +4.7%


✅ strip_noaspect

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

Memory: ✅ 40.481MB (SLO: <41.500MB -2.5%) vs baseline: +4.4%


✅ swapcase_aspect

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

Memory: ✅ 40.298MB (SLO: <41.500MB -2.9%) vs baseline: +3.9%


✅ swapcase_noaspect

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

Memory: ✅ 40.521MB (SLO: <41.500MB -2.4%) vs baseline: +4.6%


✅ title_aspect

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

Memory: ✅ 40.580MB (SLO: <41.500MB -2.2%) vs baseline: +4.7%


✅ title_noaspect

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

Memory: ✅ 40.422MB (SLO: <41.500MB -2.6%) vs baseline: +4.3%


✅ translate_aspect

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

Memory: ✅ 40.260MB (SLO: <41.500MB -3.0%) vs baseline: +4.1%


✅ translate_noaspect

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

Memory: ✅ 40.618MB (SLO: <41.500MB -2.1%) vs baseline: +4.9%


✅ upper_aspect

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

Memory: ✅ 40.599MB (SLO: <41.500MB -2.2%) vs baseline: +5.0%


✅ upper_noaspect

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

Memory: ✅ 40.244MB (SLO: <41.500MB -3.0%) vs baseline: +4.0%


🟡 iastaspectssplit - 12/12

✅ rsplit_aspect

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

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


✅ rsplit_noaspect

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

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


✅ split_aspect

Time: ✅ 1.372µs (SLO: <10.000µs 📉 -86.3%) vs baseline: -3.4%

Memory: ✅ 40.167MB (SLO: <41.000MB -2.0%) vs baseline: +4.6%


✅ split_noaspect

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

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


✅ splitlines_aspect

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

Memory: ✅ 40.344MB (SLO: <41.000MB 🟡 -1.6%) vs baseline: +5.2%


✅ splitlines_noaspect

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

Memory: ✅ 40.226MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +4.3%


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 39.635ms (SLO: <47.150ms 📉 -15.9%) vs baseline: -0.3%

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


✅ add-metrics

Time: ✅ 261.196ms (SLO: <344.800ms 📉 -24.2%) vs baseline: +0.5%

Memory: ✅ 43.915MB (SLO: <47.500MB -7.5%) vs baseline: +5.1%


✅ add-tags

Time: ✅ 318.490ms (SLO: <321.000ms 🟡 -0.8%) vs baseline: +0.8%

Memory: ✅ 43.878MB (SLO: <47.500MB -7.6%) vs baseline: +5.0%


✅ get-context

Time: ✅ 79.949ms (SLO: <92.350ms 📉 -13.4%) vs baseline: +0.3%

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


✅ is-recording

Time: ✅ 37.011ms (SLO: <44.500ms 📉 -16.8%) vs baseline: -0.9%

Memory: ✅ 39.595MB (SLO: <47.500MB 📉 -16.6%) vs baseline: +4.7%


✅ record-exception

Time: ✅ 58.616ms (SLO: <67.650ms 📉 -13.4%) vs baseline: +0.6%

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


✅ set-status

Time: ✅ 43.711ms (SLO: <50.400ms 📉 -13.3%) vs baseline: +0.1%

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


✅ start

Time: ✅ 37.332ms (SLO: <43.450ms 📉 -14.1%) vs baseline: +2.3%

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


✅ start-finish

Time: ✅ 82.160ms (SLO: <88.000ms -6.6%) vs baseline: -0.3%

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


✅ start-finish-telemetry

Time: ✅ 83.567ms (SLO: <89.000ms -6.1%) vs baseline: -0.2%

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


✅ update-name

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

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


🟡 packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 342.119ms (SLO: <354.300ms -3.4%) vs baseline: -0.6%

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


✅ cache_on

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

Memory: ✅ 40.095MB (SLO: <41.000MB -2.2%) vs baseline: +3.7%


🟡 packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 155.419µs (SLO: <170.000µs -8.6%) vs baseline: -0.4%

Memory: ✅ 40.049MB (SLO: <41.000MB -2.3%) vs baseline: +5.1%


✅ import_many_cached

Time: ✅ 120.943µs (SLO: <130.000µs -7.0%) vs baseline: -0.6%

Memory: ✅ 39.922MB (SLO: <41.000MB -2.6%) vs baseline: +5.0%


✅ import_many_stdlib

Time: ✅ 0.756ms (SLO: <1.750ms 📉 -56.8%) vs baseline: -0.3%

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


⚠️ import_many_stdlib_cached

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

Memory: ✅ 39.762MB (SLO: <41.000MB -3.0%) vs baseline: +4.4%


✅ import_many_unknown

Time: ✅ 828.411µs (SLO: <890.000µs -6.9%) vs baseline: -0.9%

Memory: ✅ 40.168MB (SLO: <41.000MB -2.0%) vs baseline: +5.5%


✅ import_many_unknown_cached

Time: ✅ 792.344µs (SLO: <870.000µs -8.9%) vs baseline: -1.4%

Memory: ✅ 40.213MB (SLO: <41.000MB 🟡 -1.9%) vs baseline: +5.8%


✅ import_one

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

Memory: ✅ 39.928MB (SLO: <41.000MB -2.6%) vs baseline: +5.4%


✅ import_one_cache

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

Memory: ✅ 39.639MB (SLO: <41.000MB -3.3%) vs baseline: +4.2%


✅ import_one_stdlib

Time: ✅ 18.627µs (SLO: <20.000µs -6.9%) vs baseline: -1.0%

Memory: ✅ 39.664MB (SLO: <41.000MB -3.3%) vs baseline: +4.4%


✅ import_one_stdlib_cache

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

Memory: ✅ 40.013MB (SLO: <41.000MB -2.4%) vs baseline: +5.3%


✅ import_one_unknown

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

Memory: ✅ 39.956MB (SLO: <41.000MB -2.5%) vs baseline: +5.4%


✅ import_one_unknown_cache

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

Memory: ✅ 40.168MB (SLO: <41.000MB -2.0%) vs baseline: +5.5%


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 309.649ms (SLO: <320.950ms -3.5%) vs baseline: +0.4%

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


✅ deep-profiled

Time: ✅ 336.209ms (SLO: <359.150ms -6.4%) vs baseline: +0.2%

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


✅ medium

Time: ✅ 7.014ms (SLO: <7.400ms -5.2%) vs baseline: +0.3%

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


✅ shallow

Time: ✅ 0.945ms (SLO: <1.050ms -10.0%) vs baseline: +1.0%

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


🟡 samplingrules - 8/8

✅ average_match

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

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


✅ high_match

Time: ✅ 173.948µs (SLO: <480.000µs 📉 -63.8%) vs baseline: ~same

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


✅ low_match

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

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


✅ very_low_match

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

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


🟡 sethttpmeta - 32/32

✅ all-disabled

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

Memory: ✅ 35.822MB (SLO: <36.000MB 🟡 -0.5%) vs baseline: +4.9%


✅ all-enabled

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

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

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


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

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

Memory: ✅ 35.350MB (SLO: <36.000MB 🟡 -1.8%) vs baseline: +3.6%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 76.167µs (SLO: <90.000µs 📉 -15.4%) vs baseline: +0.4%

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


✅ obfuscation-regular-case-implicit-query

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

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


✅ obfuscation-send-querystring-disabled

Time: ✅ 154.083µs (SLO: <170.000µs -9.4%) vs baseline: -0.3%

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


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.645µs (SLO: <160.000µs -7.1%) vs baseline: -0.4%

Memory: ✅ 35.901MB (SLO: <36.500MB 🟡 -1.6%) vs baseline: +5.2%


✅ obfuscation-worst-case-implicit-query

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

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


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

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


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 span - 26/26

✅ add-event

Time: ✅ 18.246ms (SLO: <22.500ms 📉 -18.9%) vs baseline: +0.7%

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


✅ add-metrics

Time: ✅ 88.650ms (SLO: <93.500ms -5.2%) vs baseline: +0.1%

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


✅ add-tags

Time: ✅ 142.906ms (SLO: <155.000ms -7.8%) vs baseline: +0.8%

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


✅ get-context

Time: ✅ 16.919ms (SLO: <20.500ms 📉 -17.5%) vs baseline: -0.8%

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


✅ is-recording

Time: ✅ 17.302ms (SLO: <20.500ms 📉 -15.6%) vs baseline: -0.3%

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


✅ record-exception

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

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


✅ set-status

Time: ✅ 18.741ms (SLO: <22.000ms 📉 -14.8%) vs baseline: -0.3%

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


✅ start

Time: ✅ 17.455ms (SLO: <20.500ms 📉 -14.9%) vs baseline: +3.0%

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


✅ start-finish

Time: ✅ 51.100ms (SLO: <52.500ms -2.7%) vs baseline: +0.2%

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


✅ start-finish-telemetry

Time: ✅ 52.128ms (SLO: <54.500ms -4.4%) vs baseline: -0.3%

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


✅ start-finish-traceid128

Time: ✅ 54.268ms (SLO: <57.000ms -4.8%) vs baseline: +0.3%

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


✅ start-traceid128

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

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


✅ update-name

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

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.170ms (SLO: <32.950ms 📉 -11.5%) vs baseline: +0.5%

Memory: ✅ 36.156MB (SLO: <36.500MB 🟡 -0.9%) vs baseline: +5.2%


✅ medium

Time: ✅ 2.874ms (SLO: <3.200ms 📉 -10.2%) vs baseline: -0.2%

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


✅ small

Time: ✅ 332.687µs (SLO: <370.000µs 📉 -10.1%) vs baseline: +2.1%

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

✅ All Tests Passing (2 suites)
iastpropagation - 8/8

✅ no-propagation

Time: ✅ 48.816µs (SLO: <60.000µs 📉 -18.6%) vs baseline: ~same

Memory: ✅ 40.206MB (SLO: <42.000MB -4.3%) vs baseline: +5.0%


✅ propagation_enabled

Time: ✅ 165.603µs (SLO: <190.000µs 📉 -12.8%) vs baseline: -0.5%

Memory: ✅ 40.147MB (SLO: <42.000MB -4.4%) vs baseline: +4.9%


✅ propagation_enabled_100

Time: ✅ 1.842ms (SLO: <2.300ms 📉 -19.9%) vs baseline: -0.6%

Memory: ✅ 40.187MB (SLO: <42.000MB -4.3%) vs baseline: +4.9%


✅ propagation_enabled_1000

Time: ✅ 32.032ms (SLO: <34.550ms -7.3%) vs baseline: -0.2%

Memory: ✅ 40.206MB (SLO: <42.000MB -4.3%) vs baseline: +5.1%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.513ms (SLO: <42.000ms -3.5%) vs baseline: +0.7%

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


✅ add-link

Time: ✅ 36.296ms (SLO: <38.550ms -5.8%) vs baseline: -0.2%

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


✅ add-metrics

Time: ✅ 220.201ms (SLO: <232.000ms -5.1%) vs baseline: ~same

Memory: ✅ 37.749MB (SLO: <39.000MB -3.2%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 211.447ms (SLO: <221.600ms -4.6%) vs baseline: +0.1%

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


✅ get-context

Time: ✅ 29.032ms (SLO: <31.300ms -7.2%) vs baseline: +0.4%

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


✅ is-recording

Time: ✅ 29.186ms (SLO: <31.000ms -5.9%) vs baseline: ~same

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


✅ record-exception

Time: ✅ 63.154ms (SLO: <65.850ms -4.1%) vs baseline: ~same

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


✅ set-status

Time: ✅ 31.908ms (SLO: <34.150ms -6.6%) vs baseline: ~same

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


✅ start

Time: ✅ 29.432ms (SLO: <30.150ms -2.4%) vs baseline: +1.9%

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


✅ start-finish

Time: ✅ 34.018ms (SLO: <35.350ms -3.8%) vs baseline: ~same

Memory: ✅ 37.611MB (SLO: <39.000MB -3.6%) vs baseline: +4.5%


✅ start-finish-telemetry

Time: ✅ 33.796ms (SLO: <35.450ms -4.7%) vs baseline: -0.9%

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


✅ update-name

Time: ✅ 30.993ms (SLO: <33.400ms -7.2%) vs baseline: ~same

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

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

@avara1986 avara1986 marked this pull request as ready for review November 25, 2025 14:51
@avara1986 avara1986 requested review from a team as code owners November 25, 2025 14:51
Copy link
Member Author

@avara1986 avara1986 left a comment

Choose a reason for hiding this comment

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

Do not merge, waiting for @brettlangdon comments :)

@avara1986 avara1986 added the manual merge Do not automatically merge label Nov 27, 2025
@avara1986 avara1986 removed the manual merge Do not automatically merge label Dec 5, 2025
@avara1986 avara1986 enabled auto-merge (squash) December 5, 2025 08:29
@avara1986 avara1986 merged commit 9f1242e into main Dec 5, 2025
959 checks passed
@avara1986 avara1986 deleted the avara1986/APPSEC-60046_upgrade_psutil branch December 5, 2025 08:30
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

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.

4 participants