Skip to content

Conversation

@brettlangdon
Copy link
Member

@brettlangdon brettlangdon commented Oct 27, 2025

Description

Remove unused library dependencies and major version pin other library dependencies.

legacy-cgi and protobuf were only used in tests.

Testing

Risks

Additional Notes

@github-actions
Copy link
Contributor

github-actions bot commented Oct 27, 2025

CODEOWNERS have been resolved as:

lib-injection/sources/requirements.csv                                  @DataDog/apm-core-python
pyproject.toml                                                          @DataDog/python-guild
requirements.csv                                                        @DataDog/apm-core-python

@github-actions
Copy link
Contributor

github-actions bot commented Oct 27, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

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

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

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 1.968 ms (0.79%)
ddtrace.bootstrap.sitecustomize 1.284 ms (0.52%)
ddtrace.bootstrap.preload 1.284 ms (0.52%)
ddtrace.internal.remoteconfig.client 0.637 ms (0.26%)
ddtrace 0.684 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%)

@pr-commenter
Copy link

pr-commenter bot commented Oct 27, 2025

Performance SLOs

Comparing candidate APMLP-579/pin.deps (8d7ca9e) with baseline main (c529066)

🟡 Near SLO Breach (3 suites)
🟡 djangosimple - 30/30

✅ appsec

Time: ✅ 20.425ms (SLO: <22.300ms -8.4%) vs baseline: ~same

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


✅ exception-replay-enabled

Time: ✅ 1.344ms (SLO: <1.450ms -7.3%) vs baseline: -0.2%

Memory: ✅ 64.340MB (SLO: <67.000MB -4.0%) vs baseline: +4.9%


✅ iast

Time: ✅ 20.388ms (SLO: <22.250ms -8.4%) vs baseline: -0.3%

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


✅ profiler

Time: ✅ 15.498ms (SLO: <16.550ms -6.4%) vs baseline: ~same

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


✅ resource-renaming

Time: ✅ 20.531ms (SLO: <21.750ms -5.6%) vs baseline: +0.4%

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


✅ span-code-origin

Time: ✅ 25.411ms (SLO: <28.200ms -9.9%) vs baseline: ~same

Memory: ✅ 67.127MB (SLO: <69.500MB -3.4%) vs baseline: +4.7%


✅ tracer

Time: ✅ 20.483ms (SLO: <21.750ms -5.8%) vs baseline: ~same

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


✅ tracer-and-profiler

Time: ✅ 22.668ms (SLO: <23.500ms -3.5%) vs baseline: -0.2%

Memory: ✅ 67.790MB (SLO: <68.000MB 🟡 -0.3%) vs baseline: +4.8%


✅ tracer-dont-create-db-spans

Time: ✅ 19.259ms (SLO: <21.500ms 📉 -10.4%) vs baseline: -0.1%

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


✅ tracer-minimal

Time: ✅ 16.603ms (SLO: <17.500ms -5.1%) vs baseline: -0.5%

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


✅ tracer-native

Time: ✅ 20.501ms (SLO: <21.750ms -5.7%) vs baseline: +0.5%

Memory: ✅ 67.712MB (SLO: <72.500MB -6.6%) vs baseline: +4.8%


✅ tracer-no-caches

Time: ✅ 18.432ms (SLO: <19.650ms -6.2%) vs baseline: -0.4%

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


✅ tracer-no-databases

Time: ✅ 18.799ms (SLO: <20.100ms -6.5%) vs baseline: +0.9%

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


✅ tracer-no-middleware

Time: ✅ 20.182ms (SLO: <21.500ms -6.1%) vs baseline: +0.1%

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


✅ tracer-no-templates

Time: ✅ 20.273ms (SLO: <22.000ms -7.9%) vs baseline: -0.1%

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 18.025ms (SLO: <19.850ms -9.2%) vs baseline: -0.1%

Memory: ✅ 66.129MB (SLO: <66.500MB 🟡 -0.6%) vs baseline: +4.9%


✅ errortracking-enabled-user

Time: ✅ 18.036ms (SLO: <19.400ms -7.0%) vs baseline: ~same

Memory: ✅ 66.063MB (SLO: <66.500MB 🟡 -0.7%) vs baseline: +4.8%


✅ tracer-enabled

Time: ✅ 18.032ms (SLO: <19.450ms -7.3%) vs baseline: -0.3%

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


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 3.980ms (SLO: <4.200ms -5.2%) vs baseline: +0.5%

Memory: ✅ 62.285MB (SLO: <66.000MB -5.6%) vs baseline: +4.7%


✅ iast-enabled

Time: ✅ 2.435ms (SLO: <2.800ms 📉 -13.0%) vs baseline: -0.1%

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


✅ tracer-enabled

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

Memory: ✅ 52.671MB (SLO: <54.500MB -3.4%) vs baseline: +4.9%

⚠️ Unstable Tests (1 suite)
⚠️ coreapiscenario - 10/10 (1 unstable)

⚠️ context_with_data_listeners

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

Memory: ✅ 31.615MB (SLO: <33.500MB -5.6%) vs baseline: +5.2%


✅ context_with_data_no_listeners

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

Memory: ✅ 31.477MB (SLO: <33.500MB -6.0%) vs baseline: +4.4%


✅ get_item_exists

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

Memory: ✅ 31.595MB (SLO: <33.500MB -5.7%) vs baseline: +5.0%


✅ get_item_missing

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

Memory: ✅ 31.634MB (SLO: <33.500MB -5.6%) vs baseline: +5.5%


✅ set_item

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

Memory: ✅ 31.556MB (SLO: <33.500MB -5.8%) vs baseline: +4.9%

✅ All Tests Passing (15 suites)
errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

Memory: ✅ 52.376MB (SLO: <53.500MB -2.1%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 2.065ms (SLO: <2.250ms -8.2%) vs baseline: -0.7%

Memory: ✅ 52.376MB (SLO: <53.500MB -2.1%) vs baseline: +4.7%


✅ tracer-enabled

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

Memory: ✅ 52.376MB (SLO: <53.500MB -2.1%) vs baseline: +4.6%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 81.989µs (SLO: <100.000µs 📉 -18.0%) vs baseline: +0.4%

Memory: ✅ 32.067MB (SLO: <33.500MB -4.3%) vs baseline: +4.5%


✅ b3_headers

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +4.9%


✅ b3_single_headers

Time: ✅ 13.954µs (SLO: <20.000µs 📉 -30.2%) vs baseline: +4.3%

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.7%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 66.705µs (SLO: <80.000µs 📉 -16.6%) vs baseline: +4.3%

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +4.8%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.160µs (SLO: <80.000µs 📉 -17.3%) vs baseline: +0.3%

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.1%


✅ empty_headers

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +4.6%


✅ full_t_id_datadog_headers

Time: ✅ 24.192µs (SLO: <30.000µs 📉 -19.4%) vs baseline: +4.3%

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +5.1%


✅ invalid_priority_header

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.0%


✅ invalid_span_id_header

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

Memory: ✅ 31.968MB (SLO: <33.500MB -4.6%) vs baseline: +4.5%


✅ invalid_tags_header

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.7%


✅ invalid_trace_id_header

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

Memory: ✅ 32.027MB (SLO: <33.500MB -4.4%) vs baseline: +4.4%


✅ large_header_no_matches

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

Memory: ✅ 32.067MB (SLO: <33.500MB -4.3%) vs baseline: +5.0%


✅ large_valid_headers_all

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

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +5.1%


✅ medium_header_no_matches

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

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +5.2%


✅ medium_valid_headers_all

Time: ✅ 11.270µs (SLO: <20.000µs 📉 -43.7%) vs baseline: -0.3%

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.8%


✅ none_propagation_style

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

Memory: ✅ 32.106MB (SLO: <33.500MB -4.2%) vs baseline: +4.9%


✅ tracecontext_headers

Time: ✅ 34.312µs (SLO: <40.000µs 📉 -14.2%) vs baseline: -0.6%

Memory: ✅ 32.106MB (SLO: <33.500MB -4.2%) vs baseline: +4.9%


✅ valid_headers_all

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

Memory: ✅ 32.106MB (SLO: <33.500MB -4.2%) vs baseline: +5.2%


✅ valid_headers_basic

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +4.8%


✅ wsgi_empty_headers

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.9%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.6%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +5.2%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +4.7%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.5%


✅ wsgi_large_header_no_matches

Time: ✅ 28.574µs (SLO: <40.000µs 📉 -28.6%) vs baseline: -0.7%

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +4.8%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 32.086MB (SLO: <33.500MB -4.2%) vs baseline: +5.1%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +5.1%


✅ wsgi_medium_valid_headers_all

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

Memory: ✅ 32.067MB (SLO: <33.500MB -4.3%) vs baseline: +4.9%


✅ wsgi_valid_headers_all

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

Memory: ✅ 32.126MB (SLO: <33.500MB -4.1%) vs baseline: +5.2%


✅ wsgi_valid_headers_basic

Time: ✅ 6.258µs (SLO: <10.000µs 📉 -37.4%) vs baseline: +2.6%

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.8%


httppropagationinject - 16/16

✅ ids_only

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

Memory: ✅ 31.988MB (SLO: <33.500MB -4.5%) vs baseline: +4.5%


✅ with_all

Time: ✅ 29.674µs (SLO: <40.000µs 📉 -25.8%) vs baseline: +4.0%

Memory: ✅ 31.949MB (SLO: <33.500MB -4.6%) vs baseline: +4.6%


✅ with_dd_origin

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

Memory: ✅ 32.067MB (SLO: <33.500MB -4.3%) vs baseline: +5.1%


✅ with_priority_and_origin

Time: ✅ 24.785µs (SLO: <40.000µs 📉 -38.0%) vs baseline: +1.8%

Memory: ✅ 32.047MB (SLO: <33.500MB -4.3%) vs baseline: +4.7%


✅ with_sampling_priority

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

Memory: ✅ 32.106MB (SLO: <33.500MB -4.2%) vs baseline: +5.1%


✅ with_tags

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

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.7%


✅ with_tags_invalid

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

Memory: ✅ 32.106MB (SLO: <33.500MB -4.2%) vs baseline: +5.1%


✅ with_tags_max_size

Time: ✅ 28.348µs (SLO: <40.000µs 📉 -29.1%) vs baseline: +4.4%

Memory: ✅ 32.008MB (SLO: <33.500MB -4.5%) vs baseline: +4.8%


iast_aspects - 40/40

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

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

Memory: ✅ 37.532MB (SLO: <39.000MB -3.8%) vs baseline: +5.0%


✅ re_findall_aspect

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

Memory: ✅ 37.532MB (SLO: <39.000MB -3.8%) vs baseline: +5.0%


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

Memory: ✅ 37.532MB (SLO: <39.000MB -3.8%) vs baseline: +4.9%


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

Time: ✅ 2.810µs (SLO: <10.000µs 📉 -71.9%) vs baseline: +5.0%

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


✅ re_fullmatch_noaspect

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

Memory: ✅ 37.572MB (SLO: <39.000MB -3.7%) vs baseline: +4.7%


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

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

Memory: ✅ 37.532MB (SLO: <39.000MB -3.8%) vs baseline: +4.8%


✅ re_groups_noaspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +5.0%


✅ re_match_aspect

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

Memory: ✅ 37.572MB (SLO: <39.000MB -3.7%) vs baseline: +4.8%


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +4.9%


✅ re_sub_noaspect

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

Memory: ✅ 37.493MB (SLO: <39.000MB -3.9%) vs baseline: +4.7%


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


iastaspectsospath - 24/24

✅ ospathbasename_aspect

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

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +3.8%


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +3.9%


✅ ospathsplit_aspect

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

Memory: ✅ 37.945MB (SLO: <39.000MB -2.7%) vs baseline: +5.1%


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

Memory: ✅ 38.004MB (SLO: <39.000MB -2.6%) vs baseline: +4.9%


✅ ospathsplitdrive_noaspect

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

Memory: ✅ 37.631MB (SLO: <39.000MB -3.5%) vs baseline: +3.9%


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


iastaspectssplit - 12/12

✅ rsplit_aspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +4.7%


✅ rsplit_noaspect

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

Memory: ✅ 37.591MB (SLO: <39.000MB -3.6%) vs baseline: +4.7%


✅ split_aspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +4.8%


✅ split_noaspect

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +4.7%


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

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


iastpropagation - 2/2

✅ no-propagation

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

Memory: ✅ 37.552MB (SLO: <39.000MB -3.7%) vs baseline: +5.0%


otelspan - 22/22

✅ add-event

Time: ✅ 40.180ms (SLO: <47.150ms 📉 -14.8%) vs baseline: -0.5%

Memory: ✅ 43.643MB (SLO: <47.000MB -7.1%) vs baseline: +4.8%


✅ add-metrics

Time: ✅ 319.071ms (SLO: <344.800ms -7.5%) vs baseline: +0.2%

Memory: ✅ 651.158MB (SLO: <675.000MB -3.5%) vs baseline: +4.6%


✅ add-tags

Time: ✅ 286.886ms (SLO: <314.000ms -8.6%) vs baseline: -1.0%

Memory: ✅ 653.099MB (SLO: <675.000MB -3.2%) vs baseline: +4.8%


✅ get-context

Time: ✅ 82.812ms (SLO: <92.350ms 📉 -10.3%) vs baseline: +3.5%

Memory: ✅ 39.443MB (SLO: <46.500MB 📉 -15.2%) vs baseline: +4.8%


✅ is-recording

Time: ✅ 38.946ms (SLO: <44.500ms 📉 -12.5%) vs baseline: +2.5%

Memory: ✅ 42.990MB (SLO: <47.500MB -9.5%) vs baseline: +4.8%


✅ record-exception

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

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


✅ set-status

Time: ✅ 44.079ms (SLO: <50.400ms 📉 -12.5%) vs baseline: +0.4%

Memory: ✅ 42.961MB (SLO: <47.000MB -8.6%) vs baseline: +4.8%


✅ start

Time: ✅ 37.382ms (SLO: <43.450ms 📉 -14.0%) vs baseline: +0.4%

Memory: ✅ 43.058MB (SLO: <47.000MB -8.4%) vs baseline: +5.1%


✅ start-finish

Time: ✅ 82.070ms (SLO: <88.000ms -6.7%) vs baseline: +0.7%

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


✅ start-finish-telemetry

Time: ✅ 85.429ms (SLO: <89.000ms -4.0%) vs baseline: +2.9%

Memory: ✅ 34.446MB (SLO: <46.500MB 📉 -25.9%) vs baseline: +4.8%


✅ update-name

Time: ✅ 39.864ms (SLO: <45.150ms 📉 -11.7%) vs baseline: +3.1%

Memory: ✅ 43.387MB (SLO: <47.000MB -7.7%) vs baseline: +4.9%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 343.996ms (SLO: <354.300ms -2.9%) vs baseline: ~same

Memory: ✅ 38.177MB (SLO: <40.000MB -4.6%) vs baseline: +5.1%


✅ cache_on

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

Memory: ✅ 36.616MB (SLO: <39.000MB -6.1%) vs baseline: +4.8%


packagesupdateimporteddependencies - 24/24

✅ import_many

Time: ✅ 155.860µs (SLO: <170.000µs -8.3%) vs baseline: +0.3%

Memory: ✅ 36.497MB (SLO: <38.500MB -5.2%) vs baseline: +4.4%


✅ import_many_cached

Time: ✅ 122.662µs (SLO: <130.000µs -5.6%) vs baseline: +1.3%

Memory: ✅ 36.607MB (SLO: <38.500MB -4.9%) vs baseline: +4.7%


✅ import_many_stdlib

Time: ✅ 1.626ms (SLO: <1.750ms -7.1%) vs baseline: +0.6%

Memory: ✅ 36.573MB (SLO: <38.500MB -5.0%) vs baseline: +4.3%


✅ import_many_stdlib_cached

Time: ✅ 0.984ms (SLO: <1.100ms 📉 -10.6%) vs baseline: +0.5%

Memory: ✅ 36.694MB (SLO: <38.500MB -4.7%) vs baseline: +4.5%


✅ import_many_unknown

Time: ✅ 824.968µs (SLO: <890.000µs -7.3%) vs baseline: -0.7%

Memory: ✅ 36.719MB (SLO: <38.500MB -4.6%) vs baseline: +3.9%


✅ import_many_unknown_cached

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

Memory: ✅ 36.734MB (SLO: <38.500MB -4.6%) vs baseline: +4.6%


✅ import_one

Time: ✅ 19.976µs (SLO: <30.000µs 📉 -33.4%) vs baseline: +1.3%

Memory: ✅ 36.472MB (SLO: <39.000MB -6.5%) vs baseline: +4.8%


✅ import_one_cache

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

Memory: ✅ 36.398MB (SLO: <38.500MB -5.5%) vs baseline: +4.2%


✅ import_one_stdlib

Time: ✅ 18.769µs (SLO: <20.000µs -6.2%) vs baseline: -0.3%

Memory: ✅ 36.505MB (SLO: <38.500MB -5.2%) vs baseline: +4.4%


✅ import_one_stdlib_cache

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

Memory: ✅ 36.563MB (SLO: <38.500MB -5.0%) vs baseline: +4.7%


✅ import_one_unknown

Time: ✅ 46.135µs (SLO: <50.000µs -7.7%) vs baseline: +1.9%

Memory: ✅ 36.495MB (SLO: <38.500MB -5.2%) vs baseline: +4.2%


✅ import_one_unknown_cache

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

Memory: ✅ 36.610MB (SLO: <38.500MB -4.9%) vs baseline: +4.9%


recursivecomputation - 8/8

✅ deep

Time: ✅ 308.627ms (SLO: <320.950ms -3.8%) vs baseline: ~same

Memory: ✅ 32.794MB (SLO: <34.500MB -4.9%) vs baseline: +5.0%


✅ deep-profiled

Time: ✅ 327.045ms (SLO: <359.150ms -8.9%) vs baseline: -0.2%

Memory: ✅ 38.180MB (SLO: <39.000MB -2.1%) vs baseline: +3.0%


✅ medium

Time: ✅ 7.025ms (SLO: <7.400ms -5.1%) vs baseline: +0.2%

Memory: ✅ 32.027MB (SLO: <34.000MB -5.8%) vs baseline: +4.8%


✅ shallow

Time: ✅ 0.944ms (SLO: <1.050ms 📉 -10.1%) vs baseline: +0.2%

Memory: ✅ 32.027MB (SLO: <34.000MB -5.8%) vs baseline: +5.4%


samplingrules - 8/8

✅ average_match

Time: ✅ 136.798µs (SLO: <290.000µs 📉 -52.8%) vs baseline: ~same

Memory: ✅ 31.831MB (SLO: <34.000MB -6.4%) vs baseline: +4.8%


✅ high_match

Time: ✅ 175.030µs (SLO: <480.000µs 📉 -63.5%) vs baseline: +0.8%

Memory: ✅ 31.497MB (SLO: <34.000MB -7.4%) vs baseline: +3.7%


✅ low_match

Time: ✅ 99.315µs (SLO: <120.000µs 📉 -17.2%) vs baseline: -0.7%

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


✅ very_low_match

Time: ✅ 2.658ms (SLO: <8.500ms 📉 -68.7%) vs baseline: -1.2%

Memory: ✅ 68.020MB (SLO: <75.000MB -9.3%) vs baseline: +4.9%


sethttpmeta - 32/32

✅ all-disabled

Time: ✅ 10.507µs (SLO: <20.000µs 📉 -47.5%) vs baseline: -0.3%

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +4.8%


✅ all-enabled

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

Memory: ✅ 32.381MB (SLO: <34.000MB -4.8%) vs baseline: +5.0%


✅ collectipvariant_exists

Time: ✅ 40.540µs (SLO: <50.000µs 📉 -18.9%) vs baseline: -0.3%

Memory: ✅ 32.362MB (SLO: <34.000MB -4.8%) vs baseline: +4.7%


✅ no-collectipvariant

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

Memory: ✅ 32.342MB (SLO: <34.000MB -4.9%) vs baseline: +4.7%


✅ no-useragentvariant

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

Memory: ✅ 32.440MB (SLO: <34.000MB -4.6%) vs baseline: +4.9%


✅ obfuscation-no-query

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

Memory: ✅ 32.440MB (SLO: <34.000MB -4.6%) vs baseline: +5.2%


✅ obfuscation-regular-case-explicit-query

Time: ✅ 75.807µs (SLO: <90.000µs 📉 -15.8%) vs baseline: +0.2%

Memory: ✅ 32.755MB (SLO: <34.000MB -3.7%) vs baseline: +4.5%


✅ obfuscation-regular-case-implicit-query

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

Memory: ✅ 32.814MB (SLO: <34.000MB -3.5%) vs baseline: +4.8%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 32.794MB (SLO: <34.500MB -4.9%) vs baseline: +4.9%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 32.775MB (SLO: <34.500MB -5.0%) vs baseline: +5.0%


✅ obfuscation-worst-case-implicit-query

Time: ✅ 155.910µs (SLO: <170.000µs -8.3%) vs baseline: +0.6%

Memory: ✅ 32.853MB (SLO: <34.500MB -4.8%) vs baseline: +5.1%


✅ useragentvariant_exists_1

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

Memory: ✅ 32.440MB (SLO: <34.000MB -4.6%) vs baseline: +4.7%


✅ useragentvariant_exists_2

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

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +4.6%


✅ useragentvariant_exists_3

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

Memory: ✅ 32.362MB (SLO: <34.000MB -4.8%) vs baseline: +4.7%


✅ useragentvariant_not_exists_1

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

Memory: ✅ 32.421MB (SLO: <34.000MB -4.6%) vs baseline: +4.7%


✅ useragentvariant_not_exists_2

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

Memory: ✅ 32.401MB (SLO: <34.000MB -4.7%) vs baseline: +4.8%


span - 26/26

✅ add-event

Time: ✅ 19.965ms (SLO: <22.500ms 📉 -11.3%) vs baseline: -0.5%

Memory: ✅ 48.483MB (SLO: <53.000MB -8.5%) vs baseline: +4.7%


✅ add-metrics

Time: ✅ 90.113ms (SLO: <93.500ms -3.6%) vs baseline: +0.2%

Memory: ✅ 735.810MB (SLO: <961.000MB 📉 -23.4%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 146.720ms (SLO: <155.000ms -5.3%) vs baseline: -0.5%

Memory: ✅ 735.374MB (SLO: <962.500MB 📉 -23.6%) vs baseline: +4.8%


✅ get-context

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

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


✅ is-recording

Time: ✅ 18.574ms (SLO: <20.500ms -9.4%) vs baseline: +0.2%

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


✅ record-exception

Time: ✅ 37.971ms (SLO: <40.000ms -5.1%) vs baseline: +1.2%

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


✅ set-status

Time: ✅ 20.153ms (SLO: <22.000ms -8.4%) vs baseline: ~same

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


✅ start

Time: ✅ 18.063ms (SLO: <20.500ms 📉 -11.9%) vs baseline: -0.2%

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


✅ start-finish

Time: ✅ 50.533ms (SLO: <52.500ms -3.7%) vs baseline: ~same

Memory: ✅ 31.909MB (SLO: <34.000MB -6.1%) vs baseline: +4.7%


✅ start-finish-telemetry

Time: ✅ 52.076ms (SLO: <54.500ms -4.4%) vs baseline: +0.2%

Memory: ✅ 32.086MB (SLO: <34.000MB -5.6%) vs baseline: +5.1%


✅ start-finish-traceid128

Time: ✅ 53.813ms (SLO: <57.000ms -5.6%) vs baseline: +0.2%

Memory: ✅ 31.949MB (SLO: <34.000MB -6.0%) vs baseline: +4.9%


✅ start-traceid128

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

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


✅ update-name

Time: ✅ 18.692ms (SLO: <22.000ms 📉 -15.0%) vs baseline: -0.4%

Memory: ✅ 47.855MB (SLO: <53.000MB -9.7%) vs baseline: +4.8%


tracer - 6/6

✅ large

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

Memory: ✅ 32.735MB (SLO: <34.500MB -5.1%) vs baseline: +4.6%


✅ medium

Time: ✅ 2.887ms (SLO: <3.200ms -9.8%) vs baseline: +0.5%

Memory: ✅ 31.575MB (SLO: <34.000MB -7.1%) vs baseline: +4.8%


✅ small

Time: ✅ 324.694µs (SLO: <370.000µs 📉 -12.2%) vs baseline: ~same

Memory: ✅ 31.556MB (SLO: <34.000MB -7.2%) vs baseline: +4.7%

ℹ️ Scenarios Missing SLO Configuration (51 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-appsec-get
  • flasksimple-appsec-post
  • flasksimple-appsec-telemetry
  • flasksimple-baseline
  • flasksimple-debugger
  • flasksimple-iast-get
  • flasksimple-profiler
  • flasksimple-resource-renaming
  • flasksimple-tracer
  • flasksimple-tracer-native
  • flasksqli-baseline
  • otelsdkspan-add-event
  • otelsdkspan-add-link
  • otelsdkspan-add-metrics
  • otelsdkspan-add-tags
  • otelsdkspan-get-context
  • otelsdkspan-is-recording
  • otelsdkspan-record-exception
  • otelsdkspan-set-status
  • otelsdkspan-start
  • otelsdkspan-start-finish
  • otelsdkspan-start-finish-telemetry
  • otelsdkspan-update-name
  • ratelimiter-defaults
  • ratelimiter-high_rate_limit
  • ratelimiter-long_window
  • ratelimiter-low_rate_limit
  • ratelimiter-no_rate_limit
  • ratelimiter-short_window
  • telemetryaddmetric-1-count-metric-1-times
  • telemetryaddmetric-1-count-metrics-100-times
  • telemetryaddmetric-1-distribution-metric-1-times
  • telemetryaddmetric-1-distribution-metrics-100-times
  • telemetryaddmetric-1-gauge-metric-1-times
  • telemetryaddmetric-1-gauge-metrics-100-times
  • telemetryaddmetric-1-rate-metric-1-times
  • telemetryaddmetric-1-rate-metrics-100-times
  • telemetryaddmetric-100-count-metrics-100-times
  • telemetryaddmetric-100-distribution-metrics-100-times
  • telemetryaddmetric-100-gauge-metrics-100-times
  • telemetryaddmetric-100-rate-metrics-100-times
  • telemetryaddmetric-flush-1-metric
  • telemetryaddmetric-flush-100-metrics
  • telemetryaddmetric-flush-1000-metrics

@brettlangdon brettlangdon added the changelog/no-changelog A changelog entry is not required for this PR. label Nov 4, 2025
@brettlangdon brettlangdon marked this pull request as ready for review November 4, 2025 15:56
@brettlangdon brettlangdon requested review from a team as code owners November 4, 2025 15:56
@brettlangdon brettlangdon enabled auto-merge (squash) November 4, 2025 15:56
@brettlangdon
Copy link
Member Author

I can't figure out how to get the profiling tests to pass with removing protobuf, so keeping protobuf and legacy-cgi for now, I'll remove them in follow-up PRs.

@brettlangdon brettlangdon merged commit 59f52c2 into main Nov 6, 2025
945 checks passed
@brettlangdon brettlangdon deleted the APMLP-579/pin.deps branch November 6, 2025 17:55
emmettbutler pushed a commit that referenced this pull request Nov 7, 2025
## Description

<!-- Provide an overview of the change and motivation for the change -->

## Testing

<!-- Describe your testing strategy or note what tests are included -->

## Risks

<!-- Note any risks associated with this change, or "None" if no risks
-->

## Additional Notes

<!-- Any other information that would be helpful for reviewers -->
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.

5 participants