Skip to content

Conversation

@chojomok
Copy link
Collaborator

@chojomok chojomok commented Dec 11, 2025

Description

Removes the usage of Hooks and replaces with core api dispatch.

Removed Hooks Class

  • Deleted ddtrace/_hooks.py entirely
  • Deleted tests/tracer/test_hooks.py (unit tests for Hooks)

Updated Integration Configuration

  • Removed Hooks import
  • Removed hooks attribute instantiation from IntegrationConfig.init

Updated Falcon Integration

  • Changed config.falcon.hooks.emit("request", ...) to core.dispatch("falcon.request", ...)
  • Updated documentation from decorator pattern to direct core.on() call

Updated Tests

  • test_global_config.py
    • Added core import (line 7)
  • Added tearDown() method with core.reset_listeners() (lines 23-25)
  • Migrated 7 hook tests to use core.on() and core.dispatch()
  • Changed event names from "request" to namespaced "web.request"
  • Updated test_suite.py to use core.on("falcon.request", ...)

Ensured Test Isolation

  • Added tearDown() with core.reset_listeners() to prevent global listener state from persisting across tests

Testing

use existing tests to see if anything breaks

@chojomok chojomok requested review from a team as code owners December 11, 2025 18:00
@github-actions
Copy link
Contributor

github-actions bot commented Dec 11, 2025

CODEOWNERS have been resolved as:

ddtrace/contrib/falcon.py                                               @DataDog/apm-core-python @DataDog/apm-idm-python
ddtrace/contrib/internal/falcon/middleware.py                           @DataDog/apm-core-python @DataDog/apm-idm-python
ddtrace/internal/settings/integration.py                                @DataDog/apm-core-python
tests/contrib/falcon/test_suite.py                                      @DataDog/apm-core-python @DataDog/apm-idm-python
tests/suitespec.yml                                                     @DataDog/python-guild @DataDog/apm-core-python
tests/tracer/test_global_config.py                                      @DataDog/apm-sdk-capabilities-python
ddtrace/_hooks.py                                                       @DataDog/apm-core-python
tests/tracer/test_hooks.py                                              @DataDog/apm-sdk-capabilities-python

@chojomok chojomok marked this pull request as draft December 11, 2025 18:01
@chojomok chojomok changed the title remove hooks usage and replace with coreapi [chore] remove hooks usage and replace with coreapi Dec 11, 2025
@chojomok chojomok changed the title [chore] remove hooks usage and replace with coreapi chore(tracer) remove hooks usage and replace with coreapi Dec 11, 2025
@chojomok chojomok added the changelog/no-changelog A changelog entry is not required for this PR. label Dec 11, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Dec 11, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

The average import time from base is: 249 ± 3 ms.

The import time difference between this PR and base is: -3.4 ± 0.1 ms.

Import time breakdown

The following import paths have disappeared:

ddtrace.auto 0.418 ms (0.17%)
ddtrace 0.418 ms (0.17%)
ddtrace.internal.settings._config 0.418 ms (0.17%)
ddtrace.internal.settings.integration 0.418 ms (0.17%)
ddtrace._hooks 0.418 ms (0.17%)

The following import paths have grown:

ddtrace.auto 0.100 ms (0.04%)
ddtrace 0.100 ms (0.04%)
ddtrace.internal.settings._config 0.100 ms (0.04%)

The following import paths have shrunk:

ddtrace.auto 2.663 ms (1.08%)
ddtrace 1.358 ms (0.55%)
ddtrace._logger 0.678 ms (0.28%)
ddtrace.internal.telemetry 0.678 ms (0.28%)
ddtrace.internal.telemetry.writer 0.678 ms (0.28%)
ddtrace.internal.utils.version 0.678 ms (0.28%)
ddtrace.version 0.678 ms (0.28%)
ddtrace.internal._unpatched 0.030 ms (0.01%)
json 0.030 ms (0.01%)
json.decoder 0.030 ms (0.01%)
re 0.030 ms (0.01%)
enum 0.030 ms (0.01%)
types 0.030 ms (0.01%)
ddtrace.bootstrap.sitecustomize 1.305 ms (0.53%)
ddtrace.bootstrap.preload 1.305 ms (0.53%)
ddtrace.internal.remoteconfig.client 0.621 ms (0.25%)

@chojomok chojomok changed the title chore(tracer) remove hooks usage and replace with coreapi chore(tracer): remove hooks usage and replace with coreapi Dec 11, 2025
@pr-commenter
Copy link

pr-commenter bot commented Dec 11, 2025

Performance SLOs

Comparing candidate remove_ddtrace._hooks.Hooks (a55cee2) with baseline main (f13aae0)

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

✅ add_aspect

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

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


✅ add_inplace_aspect

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

Memory: ✅ 38.242MB (SLO: <41.500MB -7.9%) vs baseline: +3.4%


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

Memory: ✅ 38.548MB (SLO: <41.500MB -7.1%) vs baseline: +4.4%


✅ bytearray_aspect

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

Memory: ✅ 38.334MB (SLO: <41.500MB -7.6%) vs baseline: +4.0%


✅ bytearray_extend_aspect

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

Memory: ✅ 38.404MB (SLO: <41.500MB -7.5%) vs baseline: +4.3%


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

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


✅ bytes_aspect

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

Memory: ✅ 38.569MB (SLO: <41.500MB -7.1%) vs baseline: +5.1%


✅ bytes_noaspect

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

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


✅ bytesio_aspect

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

Memory: ✅ 38.332MB (SLO: <41.500MB -7.6%) vs baseline: +4.3%


✅ bytesio_noaspect

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

Memory: ✅ 38.278MB (SLO: <41.500MB -7.8%) vs baseline: +3.5%


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

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


✅ casefold_aspect

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

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


✅ casefold_noaspect

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

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


✅ decode_aspect

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

Memory: ✅ 38.708MB (SLO: <41.500MB -6.7%) vs baseline: +5.1%


✅ decode_noaspect

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

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


✅ encode_aspect

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

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


✅ encode_noaspect

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

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


✅ format_aspect

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

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


✅ format_map_aspect

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

Memory: ✅ 38.368MB (SLO: <41.500MB -7.5%) vs baseline: +4.7%


✅ format_map_noaspect

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

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


✅ format_noaspect

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

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


✅ index_aspect

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

Memory: ✅ 38.511MB (SLO: <41.500MB -7.2%) vs baseline: +4.1%


✅ index_noaspect

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

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


✅ join_aspect

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

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


✅ join_noaspect

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

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


✅ ljust_aspect

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

Memory: ✅ 38.401MB (SLO: <41.500MB -7.5%) vs baseline: +4.3%


✅ ljust_noaspect

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

Memory: ✅ 38.285MB (SLO: <41.500MB -7.7%) vs baseline: +3.7%


✅ lower_aspect

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

Memory: ✅ 38.514MB (SLO: <41.500MB -7.2%) vs baseline: +5.0%


✅ lower_noaspect

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

Memory: ✅ 38.330MB (SLO: <41.500MB -7.6%) vs baseline: +3.9%


✅ lstrip_aspect

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

Memory: ✅ 38.502MB (SLO: <41.500MB -7.2%) vs baseline: +4.5%


✅ lstrip_noaspect

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

Memory: ✅ 38.590MB (SLO: <41.500MB -7.0%) vs baseline: +4.3%


✅ modulo_aspect

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

Memory: ✅ 38.511MB (SLO: <41.500MB -7.2%) vs baseline: +4.9%


✅ modulo_aspect_for_bytearray_bytearray

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

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


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

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


✅ modulo_noaspect

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

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


✅ replace_aspect

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

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


✅ replace_noaspect

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

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


✅ repr_aspect

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

Memory: ✅ 38.701MB (SLO: <41.500MB -6.7%) vs baseline: +5.4%


✅ repr_noaspect

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

Memory: ✅ 38.651MB (SLO: <41.500MB -6.9%) vs baseline: +4.9%


✅ rstrip_aspect

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

Memory: ✅ 38.643MB (SLO: <41.500MB -6.9%) vs baseline: +5.2%


✅ rstrip_noaspect

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

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


✅ slice_aspect

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

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


✅ slice_noaspect

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

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


✅ stringio_aspect

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

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


✅ stringio_noaspect

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

Memory: ✅ 38.279MB (SLO: <41.500MB -7.8%) vs baseline: +4.3%


✅ strip_aspect

Time: ✅ 2.416µs (SLO: <20.000µs 📉 -87.9%) vs baseline: 📈 +12.1%

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


✅ strip_noaspect

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

Memory: ✅ 38.406MB (SLO: <41.500MB -7.5%) vs baseline: +4.3%


✅ swapcase_aspect

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

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


✅ swapcase_noaspect

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

Memory: ✅ 38.538MB (SLO: <41.500MB -7.1%) vs baseline: +4.4%


✅ title_aspect

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

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


✅ title_noaspect

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

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


✅ translate_aspect

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

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


✅ translate_noaspect

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

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


✅ upper_aspect

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

Memory: ✅ 38.641MB (SLO: <41.500MB -6.9%) vs baseline: +5.3%


✅ upper_noaspect

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

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


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 5.087µs (SLO: <10.000µs 📉 -49.1%) vs baseline: 📈 +21.5%

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

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


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.521µs (SLO: <20.000µs 📉 -82.4%) vs baseline: 📈 +15.4%

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


✅ 1-count-metrics-100-times

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

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 216.584µs (SLO: <230.000µs -5.8%) vs baseline: -0.7%

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


✅ 1-gauge-metric-1-times

Time: ✅ 2.198µs (SLO: <20.000µs 📉 -89.0%) vs baseline: -2.3%

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


✅ 1-gauge-metrics-100-times

Time: ✅ 136.467µs (SLO: <150.000µs -9.0%) vs baseline: -0.4%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 219.550µs (SLO: <250.000µs 📉 -12.2%) vs baseline: -0.2%

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


✅ 100-count-metrics-100-times

Time: ✅ 21.034ms (SLO: <22.000ms -4.4%) vs baseline: +0.5%

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


✅ 100-distribution-metrics-100-times

Time: ✅ 2.306ms (SLO: <2.550ms -9.6%) vs baseline: ~same

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


✅ 100-gauge-metrics-100-times

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

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.292ms (SLO: <2.550ms 📉 -10.1%) vs baseline: +2.1%

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


✅ flush-1-metric

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

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


✅ flush-100-metrics

Time: ✅ 173.210µs (SLO: <250.000µs 📉 -30.7%) vs baseline: -0.9%

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


✅ flush-1000-metrics

Time: ✅ 2.174ms (SLO: <2.500ms 📉 -13.0%) vs baseline: -0.2%

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.303µs (SLO: <20.000µs 📉 -33.5%) vs baseline: +0.7%

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

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

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


🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 19.743ms (SLO: <22.300ms 📉 -11.5%) vs baseline: +1.2%

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


✅ exception-replay-enabled

Time: ✅ 1.363ms (SLO: <1.450ms -6.0%) vs baseline: ~same

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


✅ iast

Time: ✅ 19.586ms (SLO: <22.250ms 📉 -12.0%) vs baseline: +0.1%

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


✅ profiler

Time: ✅ 15.485ms (SLO: <16.550ms -6.4%) vs baseline: +0.5%

Memory: ✅ 56.308MB (SLO: <57.500MB -2.1%) vs baseline: +4.8%


✅ resource-renaming

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

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


✅ span-code-origin

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

Memory: ✅ 68.199MB (SLO: <71.000MB -3.9%) vs baseline: +4.8%


✅ tracer

Time: ✅ 19.587ms (SLO: <21.750ms -9.9%) vs baseline: +0.2%

Memory: ✅ 68.321MB (SLO: <70.000MB -2.4%) vs baseline: +5.0%


✅ tracer-and-profiler

Time: ✅ 21.730ms (SLO: <23.500ms -7.5%) vs baseline: -0.4%

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


✅ tracer-dont-create-db-spans

Time: ✅ 19.659ms (SLO: <21.500ms -8.6%) vs baseline: +0.3%

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


✅ tracer-minimal

Time: ✅ 16.881ms (SLO: <17.500ms -3.5%) vs baseline: +1.0%

Memory: ✅ 67.849MB (SLO: <70.000MB -3.1%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 19.536ms (SLO: <21.750ms 📉 -10.2%) vs baseline: +0.6%

Memory: ✅ 68.302MB (SLO: <72.500MB -5.8%) vs baseline: +4.8%


✅ tracer-no-caches

Time: ✅ 17.745ms (SLO: <19.650ms -9.7%) vs baseline: +0.9%

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


✅ tracer-no-databases

Time: ✅ 19.132ms (SLO: <20.100ms -4.8%) vs baseline: +0.2%

Memory: ✅ 67.849MB (SLO: <70.000MB -3.1%) vs baseline: +4.9%


✅ tracer-no-middleware

Time: ✅ 19.395ms (SLO: <21.500ms -9.8%) vs baseline: +0.5%

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


✅ tracer-no-templates

Time: ✅ 19.551ms (SLO: <22.000ms 📉 -11.1%) vs baseline: +1.3%

Memory: ✅ 68.116MB (SLO: <70.500MB -3.4%) vs baseline: +4.6%


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.349ms (SLO: <19.850ms 📉 -17.6%) vs baseline: ~same

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

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

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.069ms (SLO: <2.300ms 📉 -10.1%) vs baseline: -0.1%

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


✅ errortracking-enabled-user

Time: ✅ 2.076ms (SLO: <2.250ms -7.7%) vs baseline: +0.1%

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


✅ tracer-enabled

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

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


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.383ms (SLO: <4.750ms 📉 -28.8%) vs baseline: +0.4%

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


✅ appsec-post

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

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


✅ appsec-telemetry

Time: ✅ 3.418ms (SLO: <4.750ms 📉 -28.0%) vs baseline: +1.0%

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


✅ debugger

Time: ✅ 1.872ms (SLO: <2.000ms -6.4%) vs baseline: +0.1%

Memory: ✅ 47.783MB (SLO: <49.500MB -3.5%) vs baseline: +4.7%


✅ iast-get

Time: ✅ 1.863ms (SLO: <2.000ms -6.8%) vs baseline: +0.3%

Memory: ✅ 44.638MB (SLO: <49.000MB -8.9%) vs baseline: +5.2%


✅ profiler

Time: ✅ 1.919ms (SLO: <2.100ms -8.6%) vs baseline: +0.5%

Memory: ✅ 48.806MB (SLO: <50.000MB -2.4%) vs baseline: +4.9%


✅ resource-renaming

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

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


✅ tracer

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

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


✅ tracer-native

Time: ✅ 3.372ms (SLO: <3.650ms -7.6%) vs baseline: +0.2%

Memory: ✅ 55.427MB (SLO: <60.000MB -7.6%) vs baseline: +4.8%


🟡 flasksqli - 6/6

✅ appsec-enabled

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

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


✅ iast-enabled

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

Memory: ✅ 55.601MB (SLO: <62.500MB 📉 -11.0%) vs baseline: +4.6%


✅ tracer-enabled

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

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.068µs (SLO: <100.000µs 📉 -18.9%) vs baseline: -1.1%

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 64.498µs (SLO: <80.000µs 📉 -19.4%) vs baseline: +0.8%

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.334µs (SLO: <80.000µs 📉 -17.1%) vs baseline: -0.1%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.681µs (SLO: <30.000µs -7.7%) vs baseline: -0.3%

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

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

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


✅ with_all

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

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


✅ with_dd_origin

Time: ✅ 24.656µs (SLO: <30.000µs 📉 -17.8%) vs baseline: +1.4%

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

Time: ✅ 20.875µs (SLO: <30.000µs 📉 -30.4%) vs baseline: +0.9%

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


✅ with_tags

Time: ✅ 25.966µs (SLO: <40.000µs 📉 -35.1%) vs baseline: +0.9%

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


✅ with_tags_invalid

Time: ✅ 27.591µs (SLO: <40.000µs 📉 -31.0%) vs baseline: +1.3%

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


✅ with_tags_max_size

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

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


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 40.327ms (SLO: <47.150ms 📉 -14.5%) vs baseline: -0.2%

Memory: ✅ 39.436MB (SLO: <47.000MB 📉 -16.1%) vs baseline: +4.4%


✅ add-metrics

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

Memory: ✅ 43.705MB (SLO: <47.500MB -8.0%) vs baseline: +4.5%


✅ add-tags

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

Memory: ✅ 43.873MB (SLO: <47.500MB -7.6%) vs baseline: +5.1%


✅ get-context

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

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


✅ is-recording

Time: ✅ 37.915ms (SLO: <44.500ms 📉 -14.8%) vs baseline: ~same

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


✅ record-exception

Time: ✅ 59.034ms (SLO: <67.650ms 📉 -12.7%) vs baseline: +0.4%

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


✅ set-status

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

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


✅ start

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

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


✅ start-finish

Time: ✅ 82.686ms (SLO: <88.000ms -6.0%) vs baseline: +0.5%

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


✅ start-finish-telemetry

Time: ✅ 84.485ms (SLO: <89.000ms -5.1%) vs baseline: +0.8%

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


✅ update-name

Time: ✅ 38.598ms (SLO: <45.150ms 📉 -14.5%) vs baseline: -0.6%

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


🟡 packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 341.992ms (SLO: <354.300ms -3.5%) vs baseline: -1.3%

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


✅ cache_on

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

Memory: ✅ 39.431MB (SLO: <41.000MB -3.8%) vs baseline: +5.7%


🟡 packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 154.909µs (SLO: <170.000µs -8.9%) vs baseline: +0.4%

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


✅ import_many_cached

Time: ✅ 121.362µs (SLO: <130.000µs -6.6%) vs baseline: -0.2%

Memory: ✅ 40.039MB (SLO: <41.000MB -2.3%) vs baseline: +4.6%


✅ import_many_stdlib

Time: ✅ 0.755ms (SLO: <1.750ms 📉 -56.9%) vs baseline: -0.2%

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


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.172ms (SLO: <1.100ms 📉 -84.4%) vs baseline: -0.2%

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


✅ import_many_unknown

Time: ✅ 831.545µs (SLO: <890.000µs -6.6%) vs baseline: -1.3%

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


✅ import_many_unknown_cached

Time: ✅ 791.472µs (SLO: <870.000µs -9.0%) vs baseline: -1.6%

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


✅ import_one

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

Memory: ✅ 39.948MB (SLO: <41.000MB -2.6%) vs baseline: +4.7%


✅ import_one_cache

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

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


✅ import_one_stdlib

Time: ✅ 18.759µs (SLO: <20.000µs -6.2%) vs baseline: +0.5%

Memory: ✅ 40.082MB (SLO: <41.000MB -2.2%) vs baseline: +5.4%


✅ import_one_stdlib_cache

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

Memory: ✅ 40.087MB (SLO: <41.000MB -2.2%) vs baseline: +4.5%


✅ import_one_unknown

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

Memory: ✅ 40.108MB (SLO: <41.000MB -2.2%) vs baseline: +4.4%


✅ import_one_unknown_cache

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

Memory: ✅ 40.056MB (SLO: <41.000MB -2.3%) vs baseline: +4.4%


🟡 ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 34.701MB (SLO: <35.500MB -2.2%) vs baseline: +4.7%


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

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

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


✅ deep-profiled

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

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


✅ medium

Time: ✅ 6.980ms (SLO: <7.400ms -5.7%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.947ms (SLO: <1.050ms -9.9%) vs baseline: +1.2%

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


🟡 sethttpmeta - 32/32

✅ all-disabled

Time: ✅ 10.555µs (SLO: <20.000µs 📉 -47.2%) vs baseline: -0.1%

Memory: ✅ 35.212MB (SLO: <36.000MB -2.2%) vs baseline: +4.6%


✅ all-enabled

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

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

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


✅ no-useragentvariant

Time: ✅ 38.985µs (SLO: <50.000µs 📉 -22.0%) vs baseline: +0.8%

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


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

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


✅ obfuscation-regular-case-implicit-query

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

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


✅ obfuscation-send-querystring-disabled

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

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


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 35.743MB (SLO: <36.500MB -2.1%) vs baseline: +4.9%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 154.844µs (SLO: <170.000µs -8.9%) vs baseline: -0.3%

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


✅ useragentvariant_exists_1

Time: ✅ 40.003µs (SLO: <50.000µs 📉 -20.0%) vs baseline: +1.1%

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


✅ useragentvariant_exists_2

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

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


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 88.702ms (SLO: <93.500ms -5.1%) vs baseline: +0.7%

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


✅ add-tags

Time: ✅ 140.915ms (SLO: <155.000ms -9.1%) vs baseline: -1.4%

Memory: ✅ 40.861MB (SLO: <53.000MB 📉 -22.9%) vs baseline: +4.2%


✅ get-context

Time: ✅ 17.001ms (SLO: <20.500ms 📉 -17.1%) vs baseline: -0.3%

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


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.671ms (SLO: <40.000ms -8.3%) vs baseline: +0.5%

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


✅ set-status

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

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


✅ start

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

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


✅ start-finish

Time: ✅ 51.150ms (SLO: <52.500ms -2.6%) vs baseline: +0.2%

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


✅ start-finish-telemetry

Time: ✅ 52.352ms (SLO: <54.500ms -3.9%) vs baseline: -0.1%

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


✅ start-finish-traceid128

Time: ✅ 54.274ms (SLO: <57.000ms -4.8%) vs baseline: +0.1%

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


✅ start-traceid128

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

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


✅ update-name

Time: ✅ 17.335ms (SLO: <22.000ms 📉 -21.2%) vs baseline: -0.9%

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.078ms (SLO: <32.950ms 📉 -11.8%) vs baseline: -0.4%

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


✅ medium

Time: ✅ 2.873ms (SLO: <3.200ms 📉 -10.2%) vs baseline: -0.7%

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


✅ small

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

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

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

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

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

Memory: ✅ 38.712MB (SLO: <41.000MB -5.6%) vs baseline: +5.0%


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

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

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

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

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


✅ re_groups_noaspect

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

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


✅ re_match_aspect

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

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

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

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


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 1.498µs (SLO: <10.000µs 📉 -85.0%) vs baseline: +5.1%

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

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


✅ split_noaspect

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

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


✅ splitlines_aspect

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

Memory: ✅ 38.437MB (SLO: <41.000MB -6.3%) vs baseline: +4.3%


✅ splitlines_noaspect

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

Memory: ✅ 38.476MB (SLO: <41.000MB -6.2%) vs baseline: +4.3%


iastpropagation - 8/8

✅ no-propagation

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

Memory: ✅ 38.201MB (SLO: <42.000MB -9.0%) vs baseline: +4.7%


✅ propagation_enabled

Time: ✅ 135.742µs (SLO: <190.000µs 📉 -28.6%) vs baseline: -0.6%

Memory: ✅ 38.358MB (SLO: <42.000MB -8.7%) vs baseline: +5.2%


✅ propagation_enabled_100

Time: ✅ 1.557ms (SLO: <2.300ms 📉 -32.3%) vs baseline: -0.3%

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


✅ propagation_enabled_1000

Time: ✅ 28.984ms (SLO: <34.550ms 📉 -16.1%) vs baseline: -0.1%

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


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.684ms (SLO: <42.000ms -3.1%) vs baseline: +1.0%

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


✅ add-link

Time: ✅ 36.688ms (SLO: <38.550ms -4.8%) vs baseline: +0.9%

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


✅ add-metrics

Time: ✅ 219.943ms (SLO: <232.000ms -5.2%) vs baseline: +0.1%

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


✅ add-tags

Time: ✅ 212.355ms (SLO: <221.600ms -4.2%) vs baseline: +0.3%

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


✅ get-context

Time: ✅ 29.294ms (SLO: <31.300ms -6.4%) vs baseline: ~same

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


✅ is-recording

Time: ✅ 29.116ms (SLO: <31.000ms -6.1%) vs baseline: -0.8%

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


✅ record-exception

Time: ✅ 63.097ms (SLO: <65.850ms -4.2%) vs baseline: -0.2%

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


✅ set-status

Time: ✅ 32.051ms (SLO: <34.150ms -6.1%) vs baseline: +0.5%

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


✅ start

Time: ✅ 29.377ms (SLO: <30.150ms -2.6%) vs baseline: +2.4%

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


✅ start-finish

Time: ✅ 33.956ms (SLO: <35.350ms -3.9%) vs baseline: -0.4%

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


✅ start-finish-telemetry

Time: ✅ 33.922ms (SLO: <35.450ms -4.3%) vs baseline: -0.4%

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


✅ update-name

Time: ✅ 30.943ms (SLO: <33.400ms -7.4%) vs baseline: -0.8%

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


samplingrules - 8/8

✅ average_match

Time: ✅ 136.659µs (SLO: <290.000µs 📉 -52.9%) vs baseline: -0.5%

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


✅ high_match

Time: ✅ 171.819µs (SLO: <480.000µs 📉 -64.2%) vs baseline: -1.4%

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


✅ low_match

Time: ✅ 98.004µs (SLO: <120.000µs 📉 -18.3%) vs baseline: -1.2%

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


✅ very_low_match

Time: ✅ 2.651ms (SLO: <8.500ms 📉 -68.8%) vs baseline: -0.3%

Memory: ✅ 71.030MB (SLO: <75.000MB -5.3%) 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

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.

2 participants