Skip to content

chore(internal): container tags support for DSM/DBM#15293

Merged
dubloom merged 49 commits intomainfrom
dubloom/container-back-propagation
Dec 19, 2025
Merged

chore(internal): container tags support for DSM/DBM#15293
dubloom merged 49 commits intomainfrom
dubloom/container-back-propagation

Conversation

@dubloom
Copy link
Contributor

@dubloom dubloom commented Nov 17, 2025

This PR implements the container tags support for DSM/DBM as described in this RFC.

Currently tracers communicate their containerID through a request http header, the trace-agent can propagate back the resulting identifying container hash in http header responses.

We retrieve this container hash and add it as a field in the DBM comment used for context propagation and use it as the base hash for DSM.

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

github-actions bot commented Nov 17, 2025

CODEOWNERS have been resolved as:

releasenotes/notes/add-container-tags-support-ae80f97d168e5ff1.yaml     @DataDog/apm-python
ddtrace/internal/agent.py                                               @DataDog/apm-core-python
ddtrace/internal/constants.py                                           @DataDog/apm-core-python
ddtrace/internal/datastreams/encoding.py                                @DataDog/data-streams-monitoring
ddtrace/internal/datastreams/processor.py                               @DataDog/data-streams-monitoring
ddtrace/internal/datastreams/schemas/schema_builder.py                  @DataDog/data-streams-monitoring
ddtrace/internal/process_tags/__init__.py                               @DataDog/apm-core-python
ddtrace/internal/settings/_database_monitoring.py                       @DataDog/apm-core-python
ddtrace/propagation/_database_monitoring.py                             @DataDog/apm-sdk-capabilities-python
tests/datastreams/test_processor.py                                     @DataDog/data-streams-monitoring
tests/internal/test_database_monitoring.py                              @DataDog/apm-core-python
tests/tracer/test_agent.py                                              @DataDog/apm-sdk-capabilities-python
ddtrace/internal/utils/fnv.py                                           @DataDog/apm-core-python

@github-actions
Copy link
Contributor

github-actions bot commented Nov 17, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

The average import time from this PR is: 245 ± 2 ms.

The average import time from base is: 248 ± 2 ms.

The import time difference between this PR and base is: -3.08 ± 0.09 ms.

Import time breakdown

The following import paths have appeared:

ddtrace.auto 0.252 ms (0.10%)
ddtrace 0.252 ms (0.10%)
ddtrace._logger 0.252 ms (0.10%)
ddtrace.internal.telemetry 0.252 ms (0.10%)
ddtrace.internal.telemetry.writer 0.252 ms (0.10%)
ddtrace.internal.telemetry.data 0.252 ms (0.10%)
ddtrace.internal.process_tags 0.252 ms (0.10%)
ddtrace.internal.utils.fnv 0.252 ms (0.10%)

The following import paths have grown:

ddtrace.auto 0.324 ms (0.13%)
ddtrace 0.230 ms (0.09%)
ddtrace.internal.settings._config 0.117 ms (0.05%)
ddtrace.internal.gitmetadata 0.117 ms (0.05%)
ddtrace.ext.ci 0.117 ms (0.05%)
ddtrace.trace 0.113 ms (0.05%)
ddtrace._trace.provider 0.113 ms (0.05%)
ddtrace.bootstrap.sitecustomize 0.094 ms (0.04%)
ddtrace.bootstrap 0.094 ms (0.04%)

The following import paths have shrunk:

ddtrace.auto 3.064 ms (1.25%)
ddtrace 1.597 ms (0.65%)
ddtrace._logger 0.675 ms (0.28%)
ddtrace.internal.telemetry 0.675 ms (0.28%)
ddtrace.internal.telemetry.writer 0.675 ms (0.28%)
ddtrace.internal.utils.version 0.675 ms (0.28%)
ddtrace.version 0.675 ms (0.28%)
ddtrace.internal.settings._config 0.113 ms (0.05%)
ddtrace.internal.gitmetadata 0.113 ms (0.05%)
ddtrace.ext.ci 0.113 ms (0.05%)
ddtrace.ext 0.113 ms (0.05%)
ddtrace.trace 0.103 ms (0.04%)
ddtrace._trace.tracer 0.103 ms (0.04%)
ddtrace.internal._unpatched 0.062 ms (0.03%)
subprocess 0.031 ms (0.01%)
contextlib 0.031 ms (0.01%)
json 0.031 ms (0.01%)
json.decoder 0.031 ms (0.01%)
re 0.031 ms (0.01%)
enum 0.031 ms (0.01%)
types 0.031 ms (0.01%)
ddtrace.bootstrap.sitecustomize 1.467 ms (0.60%)
ddtrace.bootstrap.preload 1.361 ms (0.56%)
ddtrace.internal.remoteconfig.client 0.626 ms (0.26%)
ddtrace.bootstrap.cloning 0.105 ms (0.04%)

@pr-commenter
Copy link

pr-commenter bot commented Nov 17, 2025

Performance SLOs

Comparing candidate dubloom/container-back-propagation (9c139a9) with baseline main (c6edb37)

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

✅ add_aspect

Time: ✅ 17.624µs (SLO: <20.000µs 📉 -11.9%) vs baseline: 📈 +21.9%

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


✅ add_inplace_aspect

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

Memory: ✅ 42.821MB (SLO: <43.250MB 🟡 -1.0%) vs baseline: +5.1%


✅ add_inplace_noaspect

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

Memory: ✅ 42.566MB (SLO: <43.500MB -2.1%) vs baseline: +4.6%


✅ add_noaspect

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

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


✅ bytearray_aspect

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

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


✅ bytearray_extend_aspect

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

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


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

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


✅ bytes_aspect

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

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


✅ bytes_noaspect

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

Memory: ✅ 42.625MB (SLO: <43.500MB -2.0%) vs baseline: +4.8%


✅ bytesio_aspect

Time: ✅ 52.709µs (SLO: <70.000µs 📉 -24.7%) vs baseline: -1.0%

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


✅ bytesio_noaspect

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

Memory: ✅ 42.487MB (SLO: <43.500MB -2.3%) vs baseline: +3.7%


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

Memory: ✅ 42.762MB (SLO: <43.500MB 🟡 -1.7%) vs baseline: +4.3%


✅ casefold_aspect

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

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


✅ casefold_noaspect

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

Memory: ✅ 42.802MB (SLO: <43.500MB 🟡 -1.6%) vs baseline: +4.5%


✅ decode_aspect

Time: ✅ 15.042µs (SLO: <30.000µs 📉 -49.9%) vs baseline: +0.2%

Memory: ✅ 42.546MB (SLO: <43.500MB -2.2%) vs baseline: +3.9%


✅ decode_noaspect

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

Memory: ✅ 42.684MB (SLO: <43.500MB 🟡 -1.9%) vs baseline: +4.0%


✅ encode_aspect

Time: ✅ 17.706µs (SLO: <30.000µs 📉 -41.0%) vs baseline: 📈 +23.1%

Memory: ✅ 42.762MB (SLO: <43.500MB 🟡 -1.7%) vs baseline: +4.3%


✅ encode_noaspect

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

Memory: ✅ 42.625MB (SLO: <43.500MB -2.0%) vs baseline: +4.8%


✅ format_aspect

Time: ✅ 168.905µs (SLO: <200.000µs 📉 -15.5%) vs baseline: ~same

Memory: ✅ 42.998MB (SLO: <43.250MB 🟡 -0.6%) vs baseline: +4.5%


✅ format_map_aspect

Time: ✅ 188.489µs (SLO: <200.000µs -5.8%) vs baseline: -0.1%

Memory: ✅ 43.195MB (SLO: <43.500MB 🟡 -0.7%) vs baseline: +5.2%


✅ format_map_noaspect

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

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


✅ format_noaspect

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

Memory: ✅ 42.664MB (SLO: <43.250MB 🟡 -1.4%) vs baseline: +3.9%


✅ index_aspect

Time: ✅ 14.679µs (SLO: <20.000µs 📉 -26.6%) vs baseline: -1.3%

Memory: ✅ 42.566MB (SLO: <43.250MB 🟡 -1.6%) vs baseline: +4.5%


✅ index_noaspect

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

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


✅ join_aspect

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

Memory: ✅ 42.605MB (SLO: <43.500MB -2.1%) vs baseline: +4.0%


✅ join_noaspect

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

Memory: ✅ 42.743MB (SLO: <43.250MB 🟡 -1.2%) vs baseline: +4.7%


✅ ljust_aspect

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

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


✅ ljust_noaspect

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

Memory: ✅ 42.723MB (SLO: <43.250MB 🟡 -1.2%) vs baseline: +4.3%


✅ lower_aspect

Time: ✅ 17.109µs (SLO: <30.000µs 📉 -43.0%) vs baseline: -1.7%

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


✅ lower_noaspect

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

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


✅ lstrip_aspect

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

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


✅ lstrip_noaspect

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

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


✅ modulo_aspect

Time: ✅ 164.187µs (SLO: <200.000µs 📉 -17.9%) vs baseline: +0.3%

Memory: ✅ 42.861MB (SLO: <43.500MB 🟡 -1.5%) vs baseline: +4.0%


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 171.932µs (SLO: <200.000µs 📉 -14.0%) vs baseline: -0.5%

Memory: ✅ 43.096MB (SLO: <43.500MB 🟡 -0.9%) vs baseline: +5.6%


✅ modulo_aspect_for_bytes

Time: ✅ 166.193µs (SLO: <200.000µs 📉 -16.9%) vs baseline: ~same

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


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 169.534µs (SLO: <200.000µs 📉 -15.2%) vs baseline: ~same

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


✅ modulo_noaspect

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

Memory: ✅ 42.684MB (SLO: <43.500MB 🟡 -1.9%) vs baseline: +4.0%


✅ replace_aspect

Time: ✅ 218.414µs (SLO: <300.000µs 📉 -27.2%) vs baseline: +4.0%

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


✅ replace_noaspect

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

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


✅ repr_aspect

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

Memory: ✅ 42.900MB (SLO: <43.500MB 🟡 -1.4%) vs baseline: +5.6%


✅ repr_noaspect

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

Memory: ✅ 42.684MB (SLO: <43.500MB 🟡 -1.9%) vs baseline: +5.1%


✅ rstrip_aspect

Time: ✅ 22.312µs (SLO: <30.000µs 📉 -25.6%) vs baseline: 📈 +21.8%

Memory: ✅ 42.723MB (SLO: <43.500MB 🟡 -1.8%) vs baseline: +3.9%


✅ rstrip_noaspect

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

Memory: ✅ 42.703MB (SLO: <43.500MB 🟡 -1.8%) vs baseline: +3.9%


✅ slice_aspect

Time: ✅ 15.307µs (SLO: <20.000µs 📉 -23.5%) vs baseline: -1.2%

Memory: ✅ 42.723MB (SLO: <43.500MB 🟡 -1.8%) vs baseline: +5.3%


✅ slice_noaspect

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

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


✅ stringio_aspect

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

Memory: ✅ 43.077MB (SLO: <43.500MB 🟡 -1.0%) vs baseline: +5.1%


✅ stringio_noaspect

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

Memory: ✅ 42.644MB (SLO: <43.500MB 🟡 -2.0%) vs baseline: +3.9%


✅ strip_aspect

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

Memory: ✅ 42.703MB (SLO: <43.500MB 🟡 -1.8%) vs baseline: +4.4%


✅ strip_noaspect

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

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


✅ swapcase_aspect

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

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


✅ swapcase_noaspect

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

Memory: ✅ 42.743MB (SLO: <43.500MB 🟡 -1.7%) vs baseline: +4.3%


✅ title_aspect

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

Memory: ✅ 42.644MB (SLO: <43.000MB 🟡 -0.8%) vs baseline: +4.2%


✅ title_noaspect

Time: ✅ 2.858µs (SLO: <10.000µs 📉 -71.4%) vs baseline: +7.7%

Memory: ✅ 42.625MB (SLO: <43.500MB -2.0%) vs baseline: +4.1%


✅ translate_aspect

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

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


✅ translate_noaspect

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

Memory: ✅ 42.605MB (SLO: <43.500MB -2.1%) vs baseline: +3.9%


✅ upper_aspect

Time: ✅ 17.358µs (SLO: <30.000µs 📉 -42.1%) vs baseline: +0.2%

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


✅ upper_noaspect

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

Memory: ✅ 42.723MB (SLO: <43.500MB 🟡 -1.8%) vs baseline: +4.2%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 4.971µs (SLO: <10.000µs 📉 -50.3%) vs baseline: 📈 +22.8%

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ ospathbasename_noaspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.8%


✅ ospathjoin_aspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ ospathjoin_noaspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +4.8%


✅ ospathnormcase_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ ospathnormcase_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.7%


✅ ospathsplit_aspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +5.1%


✅ ospathsplit_noaspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.7%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +4.9%


✅ ospathsplitext_aspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +4.8%


✅ ospathsplitext_noaspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +5.1%


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.338µs (SLO: <20.000µs 📉 -83.3%) vs baseline: 📈 +11.4%

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


✅ 1-count-metrics-100-times

Time: ✅ 197.639µs (SLO: <220.000µs 📉 -10.2%) vs baseline: -2.2%

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


✅ 1-distribution-metric-1-times

Time: ✅ 3.294µs (SLO: <20.000µs 📉 -83.5%) vs baseline: -1.0%

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


✅ 1-distribution-metrics-100-times

Time: ✅ 214.049µs (SLO: <230.000µs -6.9%) vs baseline: -0.8%

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


✅ 1-gauge-metric-1-times

Time: ✅ 2.169µs (SLO: <20.000µs 📉 -89.2%) vs baseline: -2.6%

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


✅ 1-gauge-metrics-100-times

Time: ✅ 137.478µs (SLO: <150.000µs -8.3%) vs baseline: +0.2%

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


✅ 1-rate-metric-1-times

Time: ✅ 3.099µs (SLO: <20.000µs 📉 -84.5%) vs baseline: -1.9%

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


✅ 1-rate-metrics-100-times

Time: ✅ 211.750µs (SLO: <250.000µs 📉 -15.3%) vs baseline: -1.8%

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


✅ 100-count-metrics-100-times

Time: ✅ 20.275ms (SLO: <22.000ms -7.8%) vs baseline: +2.0%

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


✅ 100-distribution-metrics-100-times

Time: ✅ 2.238ms (SLO: <2.550ms 📉 -12.2%) vs baseline: +0.2%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.408ms (SLO: <1.550ms -9.2%) vs baseline: ~same

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


✅ 100-rate-metrics-100-times

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

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


✅ flush-1-metric

Time: ✅ 4.652µs (SLO: <20.000µs 📉 -76.7%) vs baseline: +3.0%

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


✅ flush-100-metrics

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

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


✅ flush-1000-metrics

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

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.310µs (SLO: <20.000µs 📉 -33.4%) vs baseline: -0.1%

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

Time: ✅ 24.316µs (SLO: <30.000µs 📉 -18.9%) vs baseline: +1.1%

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


🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 19.528ms (SLO: <22.300ms 📉 -12.4%) vs baseline: -0.3%

Memory: ✅ 68.306MB (SLO: <70.500MB -3.1%) vs baseline: +4.9%


✅ exception-replay-enabled

Time: ✅ 1.361ms (SLO: <1.450ms -6.2%) vs baseline: -0.5%

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


✅ iast

Time: ✅ 19.492ms (SLO: <22.250ms 📉 -12.4%) vs baseline: -0.5%

Memory: ✅ 68.365MB (SLO: <70.000MB -2.3%) vs baseline: +5.0%


✅ profiler

Time: ✅ 14.715ms (SLO: <16.550ms 📉 -11.1%) vs baseline: +0.1%

Memory: ✅ 56.059MB (SLO: <57.500MB -2.5%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 19.410ms (SLO: <21.750ms 📉 -10.8%) vs baseline: -0.3%

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


✅ span-code-origin

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

Memory: ✅ 68.300MB (SLO: <71.000MB -3.8%) vs baseline: +5.0%


✅ tracer

Time: ✅ 19.583ms (SLO: <21.750ms -10.0%) vs baseline: +0.2%

Memory: ✅ 68.312MB (SLO: <70.000MB -2.4%) vs baseline: +4.8%


✅ tracer-and-profiler

Time: ✅ 20.931ms (SLO: <23.500ms 📉 -10.9%) vs baseline: +0.3%

Memory: ✅ 69.412MB (SLO: <71.000MB -2.2%) vs baseline: +4.9%


✅ tracer-dont-create-db-spans

Time: ✅ 19.571ms (SLO: <21.500ms -9.0%) vs baseline: -0.6%

Memory: ✅ 68.252MB (SLO: <70.000MB -2.5%) vs baseline: +4.7%


✅ tracer-minimal

Time: ✅ 16.769ms (SLO: <17.500ms -4.2%) vs baseline: -0.4%

Memory: ✅ 68.093MB (SLO: <70.000MB -2.7%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 19.509ms (SLO: <21.750ms 📉 -10.3%) vs baseline: -0.3%

Memory: ✅ 68.370MB (SLO: <72.500MB -5.7%) vs baseline: +4.9%


✅ tracer-no-caches

Time: ✅ 17.670ms (SLO: <19.650ms 📉 -10.1%) vs baseline: +0.4%

Memory: ✅ 68.322MB (SLO: <70.000MB -2.4%) vs baseline: +5.1%


✅ tracer-no-databases

Time: ✅ 19.051ms (SLO: <20.100ms -5.2%) vs baseline: ~same

Memory: ✅ 67.957MB (SLO: <70.000MB -2.9%) vs baseline: +4.6%


✅ tracer-no-middleware

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

Memory: ✅ 68.400MB (SLO: <70.000MB -2.3%) vs baseline: +5.1%


✅ tracer-no-templates

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

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.277ms (SLO: <19.850ms 📉 -18.0%) vs baseline: -0.3%

Memory: ✅ 69.794MB (SLO: <70.000MB 🟡 -0.3%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 16.288ms (SLO: <19.400ms 📉 -16.0%) vs baseline: ~same

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


✅ tracer-enabled

Time: ✅ 16.311ms (SLO: <19.450ms 📉 -16.1%) vs baseline: -0.3%

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

Memory: ✅ 55.994MB (SLO: <56.500MB 🟡 -0.9%) vs baseline: +5.1%


✅ errortracking-enabled-user

Time: ✅ 2.078ms (SLO: <2.250ms -7.6%) vs baseline: +0.2%

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


✅ tracer-enabled

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

Memory: ✅ 55.915MB (SLO: <56.500MB 🟡 -1.0%) vs baseline: +5.1%


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.366ms (SLO: <4.750ms 📉 -29.1%) vs baseline: -0.4%

Memory: ✅ 55.935MB (SLO: <66.500MB 📉 -15.9%) vs baseline: +5.0%


✅ appsec-post

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

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


✅ appsec-telemetry

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

Memory: ✅ 55.982MB (SLO: <66.500MB 📉 -15.8%) vs baseline: +5.2%


✅ debugger

Time: ✅ 1.875ms (SLO: <2.000ms -6.3%) vs baseline: +0.2%

Memory: ✅ 47.859MB (SLO: <49.500MB -3.3%) vs baseline: +5.1%


✅ iast-get

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

Memory: ✅ 44.831MB (SLO: <49.000MB -8.5%) vs baseline: +4.9%


✅ profiler

Time: ✅ 1.867ms (SLO: <2.100ms 📉 -11.1%) vs baseline: +0.1%

Memory: ✅ 48.645MB (SLO: <50.000MB -2.7%) vs baseline: +4.8%


✅ resource-renaming

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

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


✅ tracer

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

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


✅ tracer-native

Time: ✅ 3.374ms (SLO: <3.650ms -7.6%) vs baseline: +0.3%

Memory: ✅ 55.917MB (SLO: <60.000MB -6.8%) vs baseline: +5.1%


🟡 flasksqli - 6/6

✅ appsec-enabled

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

Memory: ✅ 55.856MB (SLO: <66.000MB 📉 -15.4%) vs baseline: +4.8%


✅ iast-enabled

Time: ✅ 2.075ms (SLO: <2.800ms 📉 -25.9%) vs baseline: +0.3%

Memory: ✅ 55.935MB (SLO: <62.500MB 📉 -10.5%) vs baseline: +5.3%


✅ tracer-enabled

Time: ✅ 2.064ms (SLO: <2.250ms -8.3%) vs baseline: +0.2%

Memory: ✅ 55.876MB (SLO: <56.500MB 🟡 -1.1%) vs baseline: +5.1%


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 83.456µs (SLO: <100.000µs 📉 -16.5%) vs baseline: +5.6%

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 61.695µs (SLO: <80.000µs 📉 -22.9%) vs baseline: -0.3%

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 63.836µs (SLO: <80.000µs 📉 -20.2%) vs baseline: -0.3%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

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

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


✅ large_valid_headers_all

Time: ✅ 28.528µs (SLO: <40.000µs 📉 -28.7%) vs baseline: -1.1%

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 21.376µs (SLO: <30.000µs 📉 -28.7%) vs baseline: +5.8%

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


✅ with_all

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

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

Time: ✅ 24.880µs (SLO: <40.000µs 📉 -37.8%) vs baseline: +0.1%

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 40.361ms (SLO: <47.150ms 📉 -14.4%) vs baseline: +0.3%

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


✅ add-metrics

Time: ✅ 261.761ms (SLO: <344.800ms 📉 -24.1%) vs baseline: +0.4%

Memory: ✅ 44.000MB (SLO: <47.500MB -7.4%) vs baseline: +5.5%


✅ add-tags

Time: ✅ 317.418ms (SLO: <321.000ms 🟡 -1.1%) vs baseline: +0.1%

Memory: ✅ 43.781MB (SLO: <47.500MB -7.8%) vs baseline: +4.8%


✅ get-context

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

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


✅ is-recording

Time: ✅ 37.786ms (SLO: <44.500ms 📉 -15.1%) vs baseline: +0.3%

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


✅ record-exception

Time: ✅ 58.610ms (SLO: <67.650ms 📉 -13.4%) vs baseline: -0.5%

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


✅ set-status

Time: ✅ 44.260ms (SLO: <50.400ms 📉 -12.2%) vs baseline: -0.4%

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


✅ start

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

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


✅ start-finish

Time: ✅ 82.541ms (SLO: <88.000ms -6.2%) vs baseline: ~same

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


✅ start-finish-telemetry

Time: ✅ 84.250ms (SLO: <89.000ms -5.3%) vs baseline: +0.1%

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


✅ update-name

Time: ✅ 38.742ms (SLO: <45.150ms 📉 -14.2%) vs baseline: -0.3%

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


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

Time: ✅ 308.996ms (SLO: <320.950ms -3.7%) vs baseline: ~same

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


✅ deep-profiled

Time: ✅ 314.754ms (SLO: <359.150ms 📉 -12.4%) vs baseline: -0.5%

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


✅ medium

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

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


✅ shallow

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

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


🟡 samplingrules - 8/8

✅ average_match

Time: ✅ 137.168µs (SLO: <290.000µs 📉 -52.7%) vs baseline: +0.5%

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


✅ high_match

Time: ✅ 174.764µs (SLO: <480.000µs 📉 -63.6%) vs baseline: +1.6%

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


✅ low_match

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

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


✅ very_low_match

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

Memory: ✅ 71.195MB (SLO: <75.000MB -5.1%) vs baseline: +4.9%


🟡 sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

Time: ✅ 41.150µs (SLO: <50.000µs 📉 -17.7%) vs baseline: +2.8%

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

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


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

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

Memory: ✅ 35.743MB (SLO: <36.000MB 🟡 -0.7%) vs baseline: +5.3%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 76.393µs (SLO: <90.000µs 📉 -15.1%) vs baseline: +0.8%

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


✅ obfuscation-regular-case-implicit-query

Time: ✅ 76.966µs (SLO: <90.000µs 📉 -14.5%) vs baseline: +0.9%

Memory: ✅ 35.724MB (SLO: <36.500MB -2.1%) vs baseline: +5.0%


✅ obfuscation-send-querystring-disabled

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

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


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 35.724MB (SLO: <36.500MB -2.1%) vs baseline: +4.8%


✅ obfuscation-worst-case-implicit-query

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

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


✅ useragentvariant_exists_1

Time: ✅ 39.839µs (SLO: <50.000µs 📉 -20.3%) vs baseline: +0.9%

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


✅ useragentvariant_exists_2

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

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


✅ useragentvariant_exists_3

Time: ✅ 40.353µs (SLO: <50.000µs 📉 -19.3%) vs baseline: +0.7%

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 tracer - 6/6

✅ large

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

Memory: ✅ 35.861MB (SLO: <36.500MB 🟡 -1.7%) vs baseline: +4.4%


✅ medium

Time: ✅ 2.872ms (SLO: <3.200ms 📉 -10.2%) vs baseline: +0.5%

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


✅ small

Time: ✅ 330.478µs (SLO: <370.000µs 📉 -10.7%) vs baseline: +1.9%

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

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

✅ import_many

Time: ✅ 154.363µs (SLO: <170.000µs -9.2%) vs baseline: -0.6%

Memory: ✅ 39.654MB (SLO: <43.000MB -7.8%) vs baseline: +4.6%


✅ import_many_cached

Time: ✅ 121.814µs (SLO: <130.000µs -6.3%) vs baseline: +0.9%

Memory: ✅ 39.372MB (SLO: <43.000MB -8.4%) vs baseline: +4.4%


✅ import_many_stdlib

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

Memory: ✅ 39.489MB (SLO: <43.000MB -8.2%) vs baseline: +4.2%


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.173ms (SLO: <1.100ms 📉 -84.2%) vs baseline: ~same

Memory: ✅ 39.530MB (SLO: <43.000MB -8.1%) vs baseline: +5.0%


✅ import_many_unknown

Time: ✅ 832.428µs (SLO: <890.000µs -6.5%) vs baseline: +0.4%

Memory: ✅ 39.673MB (SLO: <43.000MB -7.7%) vs baseline: +3.9%


✅ import_many_unknown_cached

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

Memory: ✅ 39.506MB (SLO: <43.000MB -8.1%) vs baseline: +3.0%


✅ import_one

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

Memory: ✅ 39.342MB (SLO: <43.000MB -8.5%) vs baseline: +4.2%


✅ import_one_cache

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

Memory: ✅ 39.435MB (SLO: <43.000MB -8.3%) vs baseline: +4.6%


✅ import_one_stdlib

Time: ✅ 18.794µs (SLO: <20.000µs -6.0%) vs baseline: +0.9%

Memory: ✅ 39.459MB (SLO: <43.000MB -8.2%) vs baseline: +5.5%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.858MB (SLO: <43.000MB -7.3%) vs baseline: +4.6%


✅ import_one_unknown

Time: ✅ 45.502µs (SLO: <50.000µs -9.0%) vs baseline: -0.2%

Memory: ✅ 39.422MB (SLO: <43.000MB -8.3%) vs baseline: +4.0%


✅ import_one_unknown_cache

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

Memory: ✅ 39.939MB (SLO: <43.000MB -7.1%) vs baseline: +5.0%

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

✅ re_expand_aspect

Time: ✅ 36.106µs (SLO: <40.000µs -9.7%) vs baseline: +6.2%

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ re_expand_noaspect

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

Memory: ✅ 41.543MB (SLO: <43.500MB -4.5%) vs baseline: +5.2%


✅ re_findall_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ re_findall_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.7%


✅ re_finditer_aspect

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

Memory: ✅ 41.347MB (SLO: <43.500MB -5.0%) vs baseline: +4.8%


✅ re_finditer_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.6%


✅ re_fullmatch_aspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +5.0%


✅ re_fullmatch_noaspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +4.9%


✅ re_group_aspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ re_group_noaspect

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

Memory: ✅ 41.425MB (SLO: <43.500MB -4.8%) vs baseline: +4.7%


✅ re_groups_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ re_groups_noaspect

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

Memory: ✅ 41.524MB (SLO: <43.500MB -4.5%) vs baseline: +4.9%


✅ re_match_aspect

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

Memory: ✅ 41.327MB (SLO: <43.500MB -5.0%) vs baseline: +4.5%


✅ re_match_noaspect

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

Memory: ✅ 41.504MB (SLO: <43.500MB -4.6%) vs baseline: +5.1%


✅ re_search_aspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +4.9%


✅ re_search_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


✅ re_sub_aspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +5.0%


✅ re_sub_noaspect

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

Memory: ✅ 41.445MB (SLO: <43.500MB -4.7%) vs baseline: +4.9%


✅ re_subn_aspect

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

Memory: ✅ 41.465MB (SLO: <43.500MB -4.7%) vs baseline: +4.8%


✅ re_subn_noaspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +4.8%


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 41.406MB (SLO: <43.500MB -4.8%) vs baseline: +5.0%


✅ rsplit_noaspect

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

Memory: ✅ 41.484MB (SLO: <43.500MB -4.6%) vs baseline: +5.0%


✅ split_aspect

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

Memory: ✅ 41.386MB (SLO: <43.500MB -4.9%) vs baseline: +4.8%


✅ split_noaspect

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

Memory: ✅ 41.602MB (SLO: <43.500MB -4.4%) vs baseline: +5.5%


✅ splitlines_aspect

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

Memory: ✅ 41.366MB (SLO: <43.500MB -4.9%) vs baseline: +4.8%


✅ splitlines_noaspect

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

Memory: ✅ 41.366MB (SLO: <43.500MB -4.9%) vs baseline: +4.8%


iastpropagation - 8/8

✅ no-propagation

Time: ✅ 48.470µs (SLO: <60.000µs 📉 -19.2%) vs baseline: -0.7%

Memory: ✅ 38.417MB (SLO: <42.000MB -8.5%) vs baseline: +5.5%


✅ propagation_enabled

Time: ✅ 136.452µs (SLO: <190.000µs 📉 -28.2%) vs baseline: +0.2%

Memory: ✅ 38.535MB (SLO: <42.000MB -8.2%) vs baseline: +4.9%


✅ propagation_enabled_100

Time: ✅ 1.568ms (SLO: <2.300ms 📉 -31.8%) vs baseline: -1.0%

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


✅ propagation_enabled_1000

Time: ✅ 29.287ms (SLO: <34.550ms 📉 -15.2%) vs baseline: -0.6%

Memory: ✅ 38.319MB (SLO: <42.000MB -8.8%) vs baseline: +4.6%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.614ms (SLO: <42.000ms -3.3%) vs baseline: ~same

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


✅ add-link

Time: ✅ 36.230ms (SLO: <38.550ms -6.0%) vs baseline: -0.3%

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


✅ add-metrics

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

Memory: ✅ 37.808MB (SLO: <39.000MB -3.1%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 212.048ms (SLO: <221.600ms -4.3%) vs baseline: ~same

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


✅ get-context

Time: ✅ 29.197ms (SLO: <31.300ms -6.7%) vs baseline: -0.1%

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


✅ is-recording

Time: ✅ 29.263ms (SLO: <31.000ms -5.6%) vs baseline: +0.2%

Memory: ✅ 37.729MB (SLO: <39.000MB -3.3%) vs baseline: +4.8%


✅ record-exception

Time: ✅ 62.841ms (SLO: <65.850ms -4.6%) vs baseline: -0.5%

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


✅ set-status

Time: ✅ 31.832ms (SLO: <34.150ms -6.8%) vs baseline: +0.3%

Memory: ✅ 37.768MB (SLO: <39.000MB -3.2%) vs baseline: +5.0%


✅ start

Time: ✅ 29.309ms (SLO: <30.150ms -2.8%) vs baseline: +2.4%

Memory: ✅ 37.650MB (SLO: <39.000MB -3.5%) vs baseline: +4.9%


✅ start-finish

Time: ✅ 33.972ms (SLO: <35.350ms -3.9%) vs baseline: +0.2%

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


✅ start-finish-telemetry

Time: ✅ 33.750ms (SLO: <35.450ms -4.8%) vs baseline: -0.6%

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


✅ update-name

Time: ✅ 31.093ms (SLO: <33.400ms -6.9%) vs baseline: ~same

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 341.283ms (SLO: <354.300ms -3.7%) vs baseline: -1.1%

Memory: ✅ 40.802MB (SLO: <43.500MB -6.2%) vs baseline: +4.4%


✅ cache_on

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

Memory: ✅ 39.993MB (SLO: <43.000MB -7.0%) vs baseline: +5.2%


span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 88.150ms (SLO: <93.500ms -5.7%) vs baseline: -0.3%

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


✅ add-tags

Time: ✅ 141.703ms (SLO: <155.000ms -8.6%) vs baseline: +0.2%

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


✅ get-context

Time: ✅ 16.994ms (SLO: <20.500ms 📉 -17.1%) vs baseline: +0.1%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.587ms (SLO: <40.000ms -8.5%) vs baseline: +0.4%

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


✅ set-status

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

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


✅ start

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

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


✅ start-finish

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

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


✅ start-finish-telemetry

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

Memory: ✅ 34.721MB (SLO: <35.500MB -2.2%) vs baseline: +4.6%


✅ start-finish-traceid128

Time: ✅ 53.983ms (SLO: <57.000ms -5.3%) vs baseline: +0.4%

Memory: ✅ 34.721MB (SLO: <35.500MB -2.2%) vs baseline: +4.8%


✅ start-traceid128

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

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


✅ update-name

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

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

ℹ️ Scenarios Missing SLO Configuration (26 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
  • startup-baseline
  • startup-baseline_django
  • startup-baseline_flask
  • startup-ddtrace_run
  • startup-ddtrace_run_appsec
  • startup-ddtrace_run_profiling
  • startup-ddtrace_run_runtime_metrics
  • startup-ddtrace_run_send_span
  • startup-ddtrace_run_telemetry_disabled
  • startup-ddtrace_run_telemetry_enabled
  • startup-import_ddtrace
  • startup-import_ddtrace_auto
  • startup-import_ddtrace_auto_django
  • startup-import_ddtrace_auto_flask
  • startup-import_ddtrace_django
  • startup-import_ddtrace_flask

@dubloom dubloom requested a review from a team as a code owner December 9, 2025 16:25
Copy link
Member

@brettlangdon brettlangdon left a comment

Choose a reason for hiding this comment

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

no release note needed for this?

@dubloom dubloom requested a review from a team as a code owner December 15, 2025 09:09
@dubloom dubloom requested a review from wantsui December 15, 2025 09:09
Copy link
Collaborator

@emmettbutler emmettbutler left a comment

Choose a reason for hiding this comment

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

lgtm

Copy link
Contributor

@mabdinur mabdinur left a comment

Choose a reason for hiding this comment

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

Left some nits that do not block this change. Overall LGTM

@dubloom dubloom enabled auto-merge (squash) December 19, 2025 10:27
@dubloom dubloom merged commit 5e1071c into main Dec 19, 2025
1040 of 1043 checks passed
@dubloom dubloom deleted the dubloom/container-back-propagation branch December 19, 2025 19:29
brettlangdon added a commit that referenced this pull request Jan 6, 2026
This PR implements the container tags support for DSM/DBM as described
in this
[RFC](https://docs.google.com/document/d/15GtNOKGBCt6Dc-HsDNnMmCdZwhewFQx8yUlI9in5n3M/edit?pli=1&tab=t.0).

Currently tracers communicate their containerID through a request http
header, the trace-agent can propagate back the resulting identifying
container hash in http header responses.

We retrieve this container hash and add it as a field in the DBM comment
used for context propagation and use it as the base hash for DSM.

---------

Co-authored-by: Brett Langdon <brett.langdon@datadoghq.com>
kianjones9 pushed a commit to kianjones9/dd-trace-py that referenced this pull request Jan 9, 2026
This PR implements the container tags support for DSM/DBM as described
in this
[RFC](https://docs.google.com/document/d/15GtNOKGBCt6Dc-HsDNnMmCdZwhewFQx8yUlI9in5n3M/edit?pli=1&tab=t.0).

Currently tracers communicate their containerID through a request http
header, the trace-agent can propagate back the resulting identifying
container hash in http header responses.

We retrieve this container hash and add it as a field in the DBM comment
used for context propagation and use it as the base hash for DSM.

---------

Co-authored-by: Brett Langdon <brett.langdon@datadoghq.com>
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.

7 participants