Skip to content

Conversation

@vitor-de-araujo
Copy link
Contributor

@vitor-de-araujo vitor-de-araujo commented Nov 28, 2025

Description

This PR:

  • Changes HTTP methods to detect and report errors in a cleaner way. Previously we returned a tuple with the response object and response data, but depending on the error (e.g., connection refused), we might not even get a response object, and we would pass on the exception raised by the http.client module instead. Now the BackendConnector request methods return a BackendResult, containing information about the response and any errors that may have happened, even if there is no response.
  • Adds retry logic, based on the reported error types.
  • Adds telemetry for HTTP requests, using the reported error types, request duration and other data. Telemetry uses the telemetry_writer from ddtrace.internal.telemetry.

Telemetry for things besides HTTP requests will be added separately.

Testing

Unit tests.

Risks

None.

Additional Notes

None.

@github-actions
Copy link
Contributor

github-actions bot commented Nov 28, 2025

CODEOWNERS have been resolved as:

ddtrace/testing/internal/telemetry.py                                   @DataDog/ci-app-libraries
ddtrace/internal/ci_visibility/telemetry/test_management.py             @DataDog/ci-app-libraries
ddtrace/testing/internal/api_client.py                                  @DataDog/ci-app-libraries
ddtrace/testing/internal/http.py                                        @DataDog/ci-app-libraries
ddtrace/testing/internal/session_manager.py                             @DataDog/ci-app-libraries
ddtrace/testing/internal/writer.py                                      @DataDog/ci-app-libraries
tests/testing/internal/test_http.py                                     @DataDog/ci-app-libraries
tests/testing/mocks.py                                                  @DataDog/ci-app-libraries

@github-actions
Copy link
Contributor

github-actions bot commented Nov 28, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

The average import time from base is: 220 ± 5 ms.

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

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.021 ms (0.92%)
ddtrace.bootstrap.sitecustomize 1.021 ms (0.47%)
ddtrace.bootstrap.preload 1.021 ms (0.47%)
ddtrace.internal.remoteconfig.client 0.530 ms (0.24%)
ddtrace 1.000 ms (0.46%)
ddtrace._logger 0.492 ms (0.23%)
ddtrace.internal.telemetry 0.492 ms (0.23%)
ddtrace.internal.telemetry.writer 0.492 ms (0.23%)
ddtrace.internal.utils.version 0.492 ms (0.23%)
ddtrace.version 0.492 ms (0.23%)
ddtrace.internal._unpatched 0.040 ms (0.02%)
json 0.040 ms (0.02%)
json.decoder 0.040 ms (0.02%)
re 0.040 ms (0.02%)
enum 0.040 ms (0.02%)
types 0.040 ms (0.02%)

@pr-commenter
Copy link

pr-commenter bot commented Nov 28, 2025

Performance SLOs

Comparing candidate vitor-de-araujo/SDTEST-2663/telemetry (8b82b3f) with baseline main (20e2087)

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

✅ add_aspect

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

Memory: ✅ 40.181MB (SLO: <41.500MB -3.2%) vs baseline: +5.0%


✅ add_inplace_aspect

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

Memory: ✅ 40.356MB (SLO: <41.500MB -2.8%) vs baseline: +5.0%


✅ add_inplace_noaspect

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

Memory: ✅ 40.266MB (SLO: <41.500MB -3.0%) vs baseline: +5.0%


✅ add_noaspect

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

Memory: ✅ 40.186MB (SLO: <41.500MB -3.2%) vs baseline: +4.9%


✅ bytearray_aspect

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

Memory: ✅ 40.143MB (SLO: <41.500MB -3.3%) vs baseline: +4.6%


✅ bytearray_extend_aspect

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

Memory: ✅ 40.099MB (SLO: <41.500MB -3.4%) vs baseline: +4.5%


✅ bytearray_extend_noaspect

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

Memory: ✅ 40.069MB (SLO: <41.500MB -3.4%) vs baseline: +4.1%


✅ bytearray_noaspect

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

Memory: ✅ 40.064MB (SLO: <41.500MB -3.5%) vs baseline: +4.7%


✅ bytes_aspect

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

Memory: ✅ 40.141MB (SLO: <41.500MB -3.3%) vs baseline: +4.9%


✅ bytes_noaspect

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

Memory: ✅ 40.265MB (SLO: <41.500MB -3.0%) vs baseline: +4.9%


✅ bytesio_aspect

Time: ✅ 1.363µs (SLO: <10.000µs 📉 -86.4%) vs baseline: +3.6%

Memory: ✅ 40.143MB (SLO: <41.500MB -3.3%) vs baseline: +4.5%


✅ bytesio_noaspect

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

Memory: ✅ 40.263MB (SLO: <41.500MB -3.0%) vs baseline: +5.2%


✅ capitalize_aspect

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

Memory: ✅ 40.161MB (SLO: <41.500MB -3.2%) vs baseline: +4.5%


✅ capitalize_noaspect

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

Memory: ✅ 40.106MB (SLO: <41.500MB -3.4%) vs baseline: +4.6%


✅ casefold_aspect

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

Memory: ✅ 40.263MB (SLO: <41.500MB -3.0%) vs baseline: +5.1%


✅ casefold_noaspect

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

Memory: ✅ 40.140MB (SLO: <41.500MB -3.3%) vs baseline: +5.0%


✅ decode_aspect

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

Memory: ✅ 40.287MB (SLO: <41.500MB -2.9%) vs baseline: +5.2%


✅ decode_noaspect

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

Memory: ✅ 40.223MB (SLO: <41.500MB -3.1%) vs baseline: +4.9%


✅ encode_aspect

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

Memory: ✅ 40.139MB (SLO: <41.500MB -3.3%) vs baseline: +4.7%


✅ encode_noaspect

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

Memory: ✅ 40.240MB (SLO: <41.500MB -3.0%) vs baseline: +4.8%


✅ format_aspect

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

Memory: ✅ 40.224MB (SLO: <41.500MB -3.1%) vs baseline: +4.7%


✅ format_map_aspect

Time: ✅ 3.511µs (SLO: <10.000µs 📉 -64.9%) vs baseline: -2.3%

Memory: ✅ 40.246MB (SLO: <41.500MB -3.0%) vs baseline: +4.7%


✅ format_map_noaspect

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

Memory: ✅ 40.206MB (SLO: <41.500MB -3.1%) vs baseline: +5.1%


✅ format_noaspect

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

Memory: ✅ 40.181MB (SLO: <41.500MB -3.2%) vs baseline: +5.2%


✅ index_aspect

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

Memory: ✅ 40.142MB (SLO: <41.500MB -3.3%) vs baseline: +4.6%


✅ index_noaspect

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

Memory: ✅ 40.243MB (SLO: <41.500MB -3.0%) vs baseline: +4.8%


✅ join_aspect

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

Memory: ✅ 40.141MB (SLO: <41.500MB -3.3%) vs baseline: +4.8%


✅ join_noaspect

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

Memory: ✅ 40.084MB (SLO: <41.500MB -3.4%) vs baseline: +4.8%


✅ ljust_aspect

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

Memory: ✅ 40.166MB (SLO: <41.500MB -3.2%) vs baseline: +4.3%


✅ ljust_noaspect

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

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


✅ lower_aspect

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

Memory: ✅ 40.347MB (SLO: <41.500MB -2.8%) vs baseline: +4.8%


✅ lower_noaspect

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

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


✅ lstrip_aspect

Time: ✅ 2.267µs (SLO: <20.000µs 📉 -88.7%) vs baseline: +1.3%

Memory: ✅ 40.302MB (SLO: <41.500MB -2.9%) vs baseline: +4.8%


✅ lstrip_noaspect

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

Memory: ✅ 40.362MB (SLO: <41.500MB -2.7%) vs baseline: +5.3%


✅ modulo_aspect

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

Memory: ✅ 40.078MB (SLO: <41.500MB -3.4%) vs baseline: +4.7%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 40.246MB (SLO: <41.500MB -3.0%) vs baseline: +4.5%


✅ modulo_aspect_for_bytes

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

Memory: ✅ 40.300MB (SLO: <41.500MB -2.9%) vs baseline: +4.8%


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 40.372MB (SLO: <41.500MB -2.7%) vs baseline: +5.2%


✅ modulo_noaspect

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

Memory: ✅ 40.061MB (SLO: <41.500MB -3.5%) vs baseline: +4.6%


✅ replace_aspect

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

Memory: ✅ 40.347MB (SLO: <41.500MB -2.8%) vs baseline: +5.0%


✅ replace_noaspect

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

Memory: ✅ 40.243MB (SLO: <41.500MB -3.0%) vs baseline: +5.0%


✅ repr_aspect

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

Memory: ✅ 40.122MB (SLO: <41.500MB -3.3%) vs baseline: +4.7%


✅ repr_noaspect

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

Memory: ✅ 40.227MB (SLO: <41.500MB -3.1%) vs baseline: +4.8%


✅ rstrip_aspect

Time: ✅ 1.969µs (SLO: <20.000µs 📉 -90.2%) vs baseline: +1.5%

Memory: ✅ 40.062MB (SLO: <41.500MB -3.5%) vs baseline: +4.3%


✅ rstrip_noaspect

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

Memory: ✅ 40.225MB (SLO: <41.500MB -3.1%) vs baseline: +4.9%


✅ slice_aspect

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

Memory: ✅ 40.322MB (SLO: <41.500MB -2.8%) vs baseline: +5.5%


✅ slice_noaspect

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

Memory: ✅ 40.121MB (SLO: <41.500MB -3.3%) vs baseline: +4.8%


✅ stringio_aspect

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

Memory: ✅ 40.142MB (SLO: <41.500MB -3.3%) vs baseline: +4.5%


✅ stringio_noaspect

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

Memory: ✅ 40.225MB (SLO: <41.500MB -3.1%) vs baseline: +5.4%


✅ strip_aspect

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

Memory: ✅ 40.165MB (SLO: <41.500MB -3.2%) vs baseline: +4.6%


✅ strip_noaspect

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

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


✅ swapcase_aspect

Time: ✅ 2.766µs (SLO: <10.000µs 📉 -72.3%) vs baseline: 📈 +12.9%

Memory: ✅ 40.126MB (SLO: <41.500MB -3.3%) vs baseline: +4.4%


✅ swapcase_noaspect

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

Memory: ✅ 40.103MB (SLO: <41.500MB -3.4%) vs baseline: +4.6%


✅ title_aspect

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

Memory: ✅ 40.166MB (SLO: <41.500MB -3.2%) vs baseline: +4.5%


✅ title_noaspect

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

Memory: ✅ 40.042MB (SLO: <41.500MB -3.5%) vs baseline: +4.4%


✅ translate_aspect

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

Memory: ✅ 40.099MB (SLO: <41.500MB -3.4%) vs baseline: +4.4%


✅ translate_noaspect

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

Memory: ✅ 40.266MB (SLO: <41.500MB -3.0%) vs baseline: +5.2%


✅ upper_aspect

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

Memory: ✅ 40.108MB (SLO: <41.500MB -3.4%) vs baseline: +4.5%


✅ upper_noaspect

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

Memory: ✅ 40.019MB (SLO: <41.500MB -3.6%) vs baseline: +4.5%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 5.151µs (SLO: <10.000µs 📉 -48.5%) vs baseline: 📈 +25.6%

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


✅ ospathbasename_noaspect

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

Memory: ✅ 40.088MB (SLO: <41.000MB -2.2%) vs baseline: +4.2%


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.3%


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

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


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.404µs (SLO: <20.000µs 📉 -83.0%) vs baseline: 📈 +16.5%

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


✅ 1-count-metrics-100-times

Time: ✅ 202.831µs (SLO: <220.000µs -7.8%) vs baseline: +0.7%

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 218.230µs (SLO: <230.000µs -5.1%) vs baseline: +0.9%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 137.140µs (SLO: <150.000µs -8.6%) vs baseline: +1.0%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 216.314µs (SLO: <250.000µs 📉 -13.5%) vs baseline: +1.8%

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


✅ 100-count-metrics-100-times

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

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


✅ 100-distribution-metrics-100-times

Time: ✅ 2.291ms (SLO: <2.300ms 🟡 -0.4%) vs baseline: -1.0%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.413ms (SLO: <1.550ms -8.8%) vs baseline: +1.1%

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.224ms (SLO: <2.550ms 📉 -12.8%) vs baseline: +0.5%

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


✅ flush-1-metric

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

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


✅ flush-100-metrics

Time: ✅ 173.558µs (SLO: <250.000µs 📉 -30.6%) vs baseline: -0.5%

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


✅ flush-1000-metrics

Time: ✅ 2.188ms (SLO: <2.500ms 📉 -12.5%) vs baseline: +0.1%

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

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

⚠️ context_with_data_listeners

Time: ⚠️ 13.279µs (SLO: <20.000µs 📉 -33.6%) vs baseline: -1.1%

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

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

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 16.340ms (SLO: <19.450ms 📉 -16.0%) vs baseline: +0.1%

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


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

Time: ✅ 2.073ms (SLO: <2.250ms -7.9%) vs baseline: -0.1%

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


✅ tracer-enabled

Time: ✅ 2.062ms (SLO: <2.300ms 📉 -10.3%) vs baseline: -0.2%

Memory: ✅ 55.325MB (SLO: <56.500MB -2.1%) vs baseline: +4.9%


🟡 flasksimple - 18/18

✅ appsec-get

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

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


✅ appsec-post

Time: ✅ 2.861ms (SLO: <6.750ms 📉 -57.6%) vs baseline: +0.3%

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


✅ appsec-telemetry

Time: ✅ 3.407ms (SLO: <4.750ms 📉 -28.3%) vs baseline: +0.9%

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


✅ debugger

Time: ✅ 1.870ms (SLO: <2.000ms -6.5%) vs baseline: +0.2%

Memory: ✅ 47.891MB (SLO: <49.500MB -3.3%) vs baseline: +4.8%


✅ iast-get

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

Memory: ✅ 44.648MB (SLO: <49.000MB -8.9%) vs baseline: +4.9%


✅ profiler

Time: ✅ 1.910ms (SLO: <2.100ms -9.0%) vs baseline: ~same

Memory: ✅ 48.817MB (SLO: <50.000MB -2.4%) vs baseline: +5.0%


✅ resource-renaming

Time: ✅ 3.353ms (SLO: <3.650ms -8.1%) vs baseline: -0.3%

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


✅ tracer

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

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


✅ tracer-native

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

Memory: ✅ 55.456MB (SLO: <60.000MB -7.6%) vs baseline: +4.9%


🟡 flasksqli - 6/6

✅ appsec-enabled

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

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


✅ iast-enabled

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

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


✅ tracer-enabled

Time: ✅ 2.062ms (SLO: <2.250ms -8.4%) vs baseline: +0.2%

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


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.487µs (SLO: <100.000µs 📉 -18.5%) vs baseline: +1.2%

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

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

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.372µs (SLO: <80.000µs 📉 -17.0%) vs baseline: +0.4%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

Time: ✅ 22.705µs (SLO: <30.000µs 📉 -24.3%) vs baseline: +1.7%

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.769µs (SLO: <30.000µs -7.4%) vs baseline: +0.4%

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

Time: ✅ 6.760µs (SLO: <10.000µs 📉 -32.4%) vs baseline: +2.8%

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


✅ wsgi_large_header_no_matches

Time: ✅ 29.166µs (SLO: <40.000µs 📉 -27.1%) vs baseline: +1.4%

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

Memory: ✅ 34.682MB (SLO: <35.500MB -2.3%) vs baseline: +4.1%


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 22.041µs (SLO: <30.000µs 📉 -26.5%) vs baseline: +3.9%

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


✅ with_all

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

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


✅ with_dd_origin

Time: ✅ 24.817µs (SLO: <30.000µs 📉 -17.3%) vs baseline: -0.5%

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

Time: ✅ 21.175µs (SLO: <30.000µs 📉 -29.4%) vs baseline: -0.9%

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 iast_aspects - 40/40

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

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

Memory: ✅ 40.128MB (SLO: <41.000MB -2.1%) vs baseline: +4.7%


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

Memory: ✅ 40.147MB (SLO: <41.000MB -2.1%) vs baseline: +5.0%


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

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

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

Memory: ✅ 40.088MB (SLO: <41.000MB -2.2%) vs baseline: +4.7%


✅ re_groups_aspect

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

Memory: ✅ 40.147MB (SLO: <41.000MB -2.1%) vs baseline: +4.6%


✅ re_groups_noaspect

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

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


✅ re_match_aspect

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

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

Memory: ✅ 40.069MB (SLO: <41.000MB -2.3%) vs baseline: +4.7%


✅ re_sub_aspect

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

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


✅ re_sub_noaspect

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

Memory: ✅ 40.147MB (SLO: <41.000MB -2.1%) vs baseline: +4.4%


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


🟡 iastaspectssplit - 12/12

✅ rsplit_aspect

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

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

Memory: ✅ 40.147MB (SLO: <41.000MB -2.1%) vs baseline: +4.9%


✅ split_noaspect

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

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


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

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


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 39.555ms (SLO: <47.150ms 📉 -16.1%) vs baseline: -0.3%

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


✅ add-metrics

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

Memory: ✅ 43.687MB (SLO: <47.500MB -8.0%) vs baseline: +4.8%


✅ add-tags

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

Memory: ✅ 43.723MB (SLO: <47.500MB -8.0%) vs baseline: +4.7%


✅ get-context

Time: ✅ 80.153ms (SLO: <92.350ms 📉 -13.2%) vs baseline: +0.2%

Memory: ✅ 39.695MB (SLO: <46.500MB 📉 -14.6%) vs baseline: +5.2%


✅ is-recording

Time: ✅ 37.217ms (SLO: <44.500ms 📉 -16.4%) vs baseline: +0.1%

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


✅ record-exception

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

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


✅ set-status

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

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


✅ start

Time: ✅ 37.246ms (SLO: <43.450ms 📉 -14.3%) vs baseline: +2.6%

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


✅ start-finish

Time: ✅ 81.993ms (SLO: <88.000ms -6.8%) vs baseline: -0.1%

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


✅ start-finish-telemetry

Time: ✅ 83.721ms (SLO: <89.000ms -5.9%) vs baseline: ~same

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


✅ update-name

Time: ✅ 38.516ms (SLO: <45.150ms 📉 -14.7%) vs baseline: +1.4%

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


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

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

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


✅ deep-profiled

Time: ✅ 328.243ms (SLO: <359.150ms -8.6%) vs baseline: ~same

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


✅ medium

Time: ✅ 6.996ms (SLO: <7.400ms -5.5%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.946ms (SLO: <1.050ms -9.9%) vs baseline: +1.0%

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


🟡 sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

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

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

Memory: ✅ 35.232MB (SLO: <36.000MB -2.1%) vs baseline: +4.4%


✅ no-useragentvariant

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

Memory: ✅ 35.173MB (SLO: <36.000MB -2.3%) vs baseline: +4.4%


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

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


✅ obfuscation-regular-case-implicit-query

Time: ✅ 76.246µs (SLO: <90.000µs 📉 -15.3%) vs baseline: +0.1%

Memory: ✅ 35.606MB (SLO: <36.500MB -2.5%) vs baseline: +4.6%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 35.645MB (SLO: <36.500MB -2.3%) vs baseline: +4.7%


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.118µs (SLO: <160.000µs -7.4%) vs baseline: -0.3%

Memory: ✅ 35.645MB (SLO: <36.500MB -2.3%) vs baseline: +4.8%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 155.003µs (SLO: <170.000µs -8.8%) vs baseline: +0.1%

Memory: ✅ 35.625MB (SLO: <36.500MB -2.4%) vs baseline: +4.7%


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

Memory: ✅ 35.232MB (SLO: <36.000MB -2.1%) vs baseline: +4.5%


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 88.691ms (SLO: <93.500ms -5.1%) vs baseline: ~same

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


✅ add-tags

Time: ✅ 142.315ms (SLO: <155.000ms -8.2%) vs baseline: +0.2%

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


✅ get-context

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

Memory: ✅ 36.538MB (SLO: <53.000MB 📉 -31.1%) vs baseline: +4.3%


✅ is-recording

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

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


✅ record-exception

Time: ✅ 36.439ms (SLO: <40.000ms -8.9%) vs baseline: -0.1%

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


✅ set-status

Time: ✅ 18.725ms (SLO: <22.000ms 📉 -14.9%) vs baseline: +0.4%

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


✅ start

Time: ✅ 17.459ms (SLO: <20.500ms 📉 -14.8%) vs baseline: +3.5%

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


✅ start-finish

Time: ✅ 51.120ms (SLO: <52.500ms -2.6%) vs baseline: +0.6%

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


✅ start-finish-telemetry

Time: ✅ 52.131ms (SLO: <54.500ms -4.3%) vs baseline: ~same

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


✅ start-finish-traceid128

Time: ✅ 54.108ms (SLO: <57.000ms -5.1%) vs baseline: ~same

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


✅ start-traceid128

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

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


✅ update-name

Time: ✅ 17.356ms (SLO: <22.000ms 📉 -21.1%) vs baseline: +0.1%

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.176ms (SLO: <32.950ms 📉 -11.5%) vs baseline: -0.2%

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


✅ medium

Time: ✅ 2.899ms (SLO: <3.200ms -9.4%) vs baseline: +0.5%

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


✅ small

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

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

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

✅ import_many

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

Memory: ✅ 39.403MB (SLO: <41.000MB -3.9%) vs baseline: +3.9%


✅ import_many_cached

Time: ✅ 120.660µs (SLO: <130.000µs -7.2%) vs baseline: -0.3%

Memory: ✅ 39.470MB (SLO: <41.000MB -3.7%) vs baseline: +4.5%


✅ import_many_stdlib

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

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


⚠️ import_many_stdlib_cached

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

Memory: ✅ 39.564MB (SLO: <41.000MB -3.5%) vs baseline: +4.7%


✅ import_many_unknown

Time: ✅ 832.312µs (SLO: <890.000µs -6.5%) vs baseline: -0.2%

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


✅ import_many_unknown_cached

Time: ✅ 789.454µs (SLO: <870.000µs -9.3%) vs baseline: -1.3%

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


✅ import_one

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

Memory: ✅ 39.459MB (SLO: <41.000MB -3.8%) vs baseline: +4.9%


✅ import_one_cache

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

Memory: ✅ 39.561MB (SLO: <41.000MB -3.5%) vs baseline: +5.0%


✅ import_one_stdlib

Time: ✅ 18.713µs (SLO: <20.000µs -6.4%) vs baseline: -0.3%

Memory: ✅ 39.524MB (SLO: <41.000MB -3.6%) vs baseline: +4.3%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.339MB (SLO: <41.000MB -4.1%) vs baseline: +4.6%


✅ import_one_unknown

Time: ✅ 45.401µs (SLO: <50.000µs -9.2%) vs baseline: -0.2%

Memory: ✅ 39.225MB (SLO: <41.000MB -4.3%) vs baseline: +3.2%


✅ import_one_unknown_cache

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

Memory: ✅ 39.319MB (SLO: <41.000MB -4.1%) vs baseline: +4.2%

✅ All Tests Passing (5 suites)
djangosimple - 30/30

✅ appsec

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

Memory: ✅ 68.002MB (SLO: <70.500MB -3.5%) vs baseline: +4.6%


✅ exception-replay-enabled

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

Memory: ✅ 66.021MB (SLO: <67.500MB -2.2%) vs baseline: +4.7%


✅ iast

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

Memory: ✅ 68.026MB (SLO: <70.000MB -2.8%) vs baseline: +4.9%


✅ profiler

Time: ✅ 15.414ms (SLO: <16.550ms -6.9%) vs baseline: ~same

Memory: ✅ 56.256MB (SLO: <57.500MB -2.2%) vs baseline: +5.2%


✅ resource-renaming

Time: ✅ 19.560ms (SLO: <21.750ms 📉 -10.1%) vs baseline: +0.5%

Memory: ✅ 67.908MB (SLO: <70.500MB -3.7%) vs baseline: +4.6%


✅ span-code-origin

Time: ✅ 23.604ms (SLO: <28.200ms 📉 -16.3%) vs baseline: +1.0%

Memory: ✅ 69.278MB (SLO: <71.000MB -2.4%) vs baseline: +4.8%


✅ tracer

Time: ✅ 19.632ms (SLO: <21.750ms -9.7%) vs baseline: +0.5%

Memory: ✅ 67.948MB (SLO: <70.000MB -2.9%) vs baseline: +4.5%


✅ tracer-and-profiler

Time: ✅ 21.269ms (SLO: <23.500ms -9.5%) vs baseline: ~same

Memory: ✅ 69.186MB (SLO: <71.000MB -2.6%) vs baseline: +4.8%


✅ tracer-dont-create-db-spans

Time: ✅ 19.617ms (SLO: <21.500ms -8.8%) vs baseline: -0.4%

Memory: ✅ 68.066MB (SLO: <70.000MB -2.8%) vs baseline: +4.8%


✅ tracer-minimal

Time: ✅ 16.844ms (SLO: <17.500ms -3.7%) vs baseline: +0.3%

Memory: ✅ 67.790MB (SLO: <70.000MB -3.2%) vs baseline: +4.9%


✅ tracer-native

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

Memory: ✅ 67.869MB (SLO: <72.500MB -6.4%) vs baseline: +4.5%


✅ tracer-no-caches

Time: ✅ 17.580ms (SLO: <19.650ms 📉 -10.5%) vs baseline: -0.2%

Memory: ✅ 67.810MB (SLO: <70.000MB -3.1%) vs baseline: +4.8%


✅ tracer-no-databases

Time: ✅ 19.044ms (SLO: <20.100ms -5.3%) vs baseline: -0.5%

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


✅ tracer-no-middleware

Time: ✅ 19.240ms (SLO: <21.500ms 📉 -10.5%) vs baseline: -0.4%

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


✅ tracer-no-templates

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

Memory: ✅ 67.869MB (SLO: <70.500MB -3.7%) vs baseline: +4.9%


iastpropagation - 8/8

✅ no-propagation

Time: ✅ 48.886µs (SLO: <60.000µs 📉 -18.5%) vs baseline: +0.2%

Memory: ✅ 40.108MB (SLO: <42.000MB -4.5%) vs baseline: +4.9%


✅ propagation_enabled

Time: ✅ 174.289µs (SLO: <190.000µs -8.3%) vs baseline: -0.3%

Memory: ✅ 40.088MB (SLO: <42.000MB -4.6%) vs baseline: +4.8%


✅ propagation_enabled_100

Time: ✅ 1.940ms (SLO: <2.300ms 📉 -15.6%) vs baseline: +1.1%

Memory: ✅ 40.128MB (SLO: <42.000MB -4.5%) vs baseline: +4.9%


✅ propagation_enabled_1000

Time: ✅ 32.444ms (SLO: <34.550ms -6.1%) vs baseline: -0.8%

Memory: ✅ 40.167MB (SLO: <42.000MB -4.4%) vs baseline: +5.0%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.560ms (SLO: <42.000ms -3.4%) vs baseline: +0.4%

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


✅ add-link

Time: ✅ 36.077ms (SLO: <38.550ms -6.4%) vs baseline: -0.8%

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


✅ add-metrics

Time: ✅ 219.028ms (SLO: <232.000ms -5.6%) vs baseline: ~same

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


✅ add-tags

Time: ✅ 212.254ms (SLO: <221.600ms -4.2%) vs baseline: +0.6%

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


✅ get-context

Time: ✅ 29.057ms (SLO: <31.300ms -7.2%) vs baseline: +0.3%

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


✅ is-recording

Time: ✅ 29.231ms (SLO: <31.000ms -5.7%) vs baseline: +0.4%

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


✅ record-exception

Time: ✅ 62.876ms (SLO: <65.850ms -4.5%) vs baseline: -0.6%

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


✅ set-status

Time: ✅ 31.969ms (SLO: <34.150ms -6.4%) vs baseline: +0.4%

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


✅ start

Time: ✅ 29.457ms (SLO: <30.150ms -2.3%) vs baseline: +2.2%

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


✅ start-finish

Time: ✅ 34.064ms (SLO: <35.350ms -3.6%) vs baseline: +0.9%

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


✅ start-finish-telemetry

Time: ✅ 33.850ms (SLO: <35.450ms -4.5%) vs baseline: ~same

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


✅ update-name

Time: ✅ 31.121ms (SLO: <33.400ms -6.8%) vs baseline: +0.2%

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 342.874ms (SLO: <354.300ms -3.2%) vs baseline: -0.7%

Memory: ✅ 40.463MB (SLO: <41.500MB -2.5%) vs baseline: +4.8%


✅ cache_on

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

Memory: ✅ 39.784MB (SLO: <41.000MB -3.0%) vs baseline: +4.1%


samplingrules - 8/8

✅ average_match

Time: ✅ 137.602µs (SLO: <290.000µs 📉 -52.6%) vs baseline: +0.1%

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


✅ high_match

Time: ✅ 173.528µs (SLO: <480.000µs 📉 -63.8%) vs baseline: +0.5%

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


✅ low_match

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

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


✅ very_low_match

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

Memory: ✅ 70.989MB (SLO: <75.000MB -5.3%) vs baseline: +4.9%

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

Base automatically changed from vitor-de-araujo/SDTEST-2803/reabsorb-ddtestpy to main December 2, 2025 08:22
@vitor-de-araujo vitor-de-araujo added CI App changelog/no-changelog A changelog entry is not required for this PR. labels Dec 2, 2025
@vitor-de-araujo vitor-de-araujo changed the title chore(ci_visibility): add telemetry to the new plugin (WIP) chore(ci_visibility): add telemetry to the new plugin, part 1 Dec 2, 2025
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. CI App

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants