WARNING: THIS SITE IS A MIRROR OF GITHUB.COM / IT CANNOT LOGIN OR REGISTER ACCOUNTS / THE CONTENTS ARE PROVIDED AS-IS / THIS SITE ASSUMES NO RESPONSIBILITY FOR ANY DISPLAYED CONTENT OR LINKS / IF YOU FOUND SOMETHING MAY NOT GOOD FOR EVERYONE, CONTACT ADMIN AT ilovescratch@foxmail.com
Skip to content

Conversation

@taegyunkim
Copy link
Contributor

Description

When cpu_loop() is calibrated to run for 0.01 seconds followed by time.sleep(0.1), the profiler seems to under-report the cpu time even when adaptive sampling is turned off. This test is to document this in our tests so that we have a baseline to improve upon.

https://app.datadoghq.com/notebook/13556452/profiles-for-stack-profiler-accuracy-check

Testing

Risks

Additional Notes

@taegyunkim taegyunkim requested a review from a team as a code owner December 4, 2025 17:34
@taegyunkim taegyunkim requested a review from r1viollet December 4, 2025 17:34
@taegyunkim taegyunkim added the Profiling Continous Profling label Dec 4, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Dec 4, 2025

CODEOWNERS have been resolved as:

tests/profiling/test_accuracy.py                                        @DataDog/profiling-python

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

github-actions bot commented Dec 4, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

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

The import time difference between this PR and base is: -2.6 ± 0.08 ms.

Import time breakdown

The following import paths have shrunk:

ddtrace.auto 2.679 ms (1.10%)
ddtrace 1.349 ms (0.56%)
ddtrace._logger 0.674 ms (0.28%)
ddtrace.internal.telemetry 0.674 ms (0.28%)
ddtrace.internal.telemetry.writer 0.674 ms (0.28%)
ddtrace.internal.utils.version 0.674 ms (0.28%)
ddtrace.version 0.674 ms (0.28%)
ddtrace.internal._unpatched 0.029 ms (0.01%)
json 0.029 ms (0.01%)
json.decoder 0.029 ms (0.01%)
re 0.029 ms (0.01%)
enum 0.029 ms (0.01%)
types 0.029 ms (0.01%)
ddtrace.bootstrap.sitecustomize 1.329 ms (0.55%)
ddtrace.bootstrap.preload 1.329 ms (0.55%)
ddtrace.internal.remoteconfig.client 0.681 ms (0.28%)

@pr-commenter
Copy link

pr-commenter bot commented Dec 4, 2025

Performance SLOs

Comparing candidate taegyunkim/cpu-loop-accuracy (a94f070) with baseline main (f643ad6)

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

✅ ospathbasename_aspect

Time: ✅ 5.163µs (SLO: <10.000µs 📉 -48.4%) vs baseline: 📈 +25.2%

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


✅ ospathbasename_noaspect

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

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


✅ ospathjoin_aspect

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

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


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

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


✅ ospathnormcase_noaspect

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

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


✅ ospathsplit_aspect

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

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


✅ ospathsplit_noaspect

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

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


✅ ospathsplitdrive_aspect

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

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


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

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


✅ ospathsplitext_noaspect

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

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


📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.387µs (SLO: <20.000µs 📉 -83.1%) vs baseline: 📈 +15.0%

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


✅ 1-count-metrics-100-times

Time: ✅ 201.125µs (SLO: <220.000µs -8.6%) vs baseline: ~same

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


✅ 1-distribution-metric-1-times

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

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


✅ 1-distribution-metrics-100-times

Time: ✅ 216.771µs (SLO: <230.000µs -5.8%) vs baseline: -0.3%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 136.772µs (SLO: <150.000µs -8.8%) vs baseline: +0.4%

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


✅ 1-rate-metric-1-times

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

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


✅ 1-rate-metrics-100-times

Time: ✅ 214.854µs (SLO: <250.000µs 📉 -14.1%) vs baseline: ~same

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


✅ 100-count-metrics-100-times

Time: ✅ 20.461ms (SLO: <22.000ms -7.0%) vs baseline: +0.3%

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


✅ 100-distribution-metrics-100-times

Time: ✅ 2.302ms (SLO: <2.550ms -9.7%) vs baseline: ~same

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.406ms (SLO: <1.550ms -9.3%) vs baseline: +0.4%

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.197ms (SLO: <2.550ms 📉 -13.9%) vs baseline: -1.5%

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


✅ flush-1-metric

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

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


✅ flush-100-metrics

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

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


✅ flush-1000-metrics

Time: ✅ 2.176ms (SLO: <2.500ms 📉 -13.0%) vs baseline: -0.4%

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

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

⚠️ context_with_data_listeners

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

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


✅ context_with_data_no_listeners

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

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


✅ get_item_exists

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

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


✅ get_item_missing

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

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


✅ set_item

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

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

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

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


✅ tracer-enabled

Time: ✅ 16.471ms (SLO: <19.450ms 📉 -15.3%) vs baseline: +0.6%

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


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.378ms (SLO: <4.750ms 📉 -28.9%) vs baseline: -0.2%

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


✅ appsec-post

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

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


✅ appsec-telemetry

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

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


✅ debugger

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

Memory: ✅ 47.903MB (SLO: <49.500MB -3.2%) vs baseline: +4.8%


✅ iast-get

Time: ✅ 1.854ms (SLO: <2.000ms -7.3%) vs baseline: ~same

Memory: ✅ 44.601MB (SLO: <49.000MB -9.0%) vs baseline: +4.8%


✅ profiler

Time: ✅ 1.906ms (SLO: <2.100ms -9.2%) vs baseline: ~same

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


✅ resource-renaming

Time: ✅ 3.366ms (SLO: <3.650ms -7.8%) vs baseline: +0.1%

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


✅ tracer

Time: ✅ 3.369ms (SLO: <3.650ms -7.7%) vs baseline: -0.1%

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


✅ tracer-native

Time: ✅ 3.372ms (SLO: <3.650ms -7.6%) vs baseline: ~same

Memory: ✅ 55.546MB (SLO: <60.000MB -7.4%) vs baseline: +4.7%


🟡 httppropagationextract - 60/60

✅ all_styles_all_headers

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

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

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

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


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

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

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

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

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.533µs (SLO: <30.000µs -8.2%) vs baseline: -0.5%

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


✅ large_valid_headers_all

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

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


🟡 httppropagationinject - 16/16

✅ ids_only

Time: ✅ 22.242µs (SLO: <30.000µs 📉 -25.9%) vs baseline: +4.6%

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


✅ with_all

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

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

Time: ✅ 26.056µs (SLO: <40.000µs 📉 -34.9%) vs baseline: -0.3%

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

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

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


🟡 iast_aspects - 40/40

✅ re_expand_aspect

Time: ✅ 33.683µs (SLO: <40.000µs 📉 -15.8%) vs baseline: +4.8%

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


✅ re_expand_noaspect

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

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


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

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

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

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

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


✅ re_groups_noaspect

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

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


✅ re_match_aspect

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

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

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

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

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

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


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


🟡 iastaspectssplit - 12/12

✅ rsplit_aspect

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

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

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


✅ split_noaspect

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

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


✅ splitlines_aspect

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

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


✅ splitlines_noaspect

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

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


🟡 otelspan - 22/22

✅ add-event

Time: ✅ 39.480ms (SLO: <47.150ms 📉 -16.3%) vs baseline: -0.3%

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


✅ add-metrics

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

Memory: ✅ 43.792MB (SLO: <47.500MB -7.8%) vs baseline: +5.1%


✅ add-tags

Time: ✅ 316.563ms (SLO: <321.000ms 🟡 -1.4%) vs baseline: +0.2%

Memory: ✅ 43.788MB (SLO: <47.500MB -7.8%) vs baseline: +5.0%


✅ get-context

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

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


✅ is-recording

Time: ✅ 36.892ms (SLO: <44.500ms 📉 -17.1%) vs baseline: -0.8%

Memory: ✅ 39.398MB (SLO: <47.500MB 📉 -17.1%) vs baseline: +5.0%


✅ record-exception

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

Memory: ✅ 40.009MB (SLO: <47.000MB 📉 -14.9%) vs baseline: +5.3%


✅ set-status

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

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


✅ start

Time: ✅ 37.188ms (SLO: <43.450ms 📉 -14.4%) vs baseline: +2.0%

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


✅ start-finish

Time: ✅ 82.037ms (SLO: <88.000ms -6.8%) vs baseline: +0.3%

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


✅ start-finish-telemetry

Time: ✅ 83.440ms (SLO: <89.000ms -6.2%) vs baseline: -0.2%

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


✅ update-name

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

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


🟡 ratelimiter - 12/12

✅ defaults

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

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


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

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


✅ no_rate_limit

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

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


✅ short_window

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

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


🟡 recursivecomputation - 8/8

✅ deep

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

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


✅ deep-profiled

Time: ✅ 327.350ms (SLO: <359.150ms -8.9%) vs baseline: ~same

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


✅ medium

Time: ✅ 6.984ms (SLO: <7.400ms -5.6%) vs baseline: ~same

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


✅ shallow

Time: ✅ 0.949ms (SLO: <1.050ms -9.6%) vs baseline: +1.3%

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


🟡 samplingrules - 8/8

✅ average_match

Time: ✅ 137.661µs (SLO: <290.000µs 📉 -52.5%) vs baseline: +0.3%

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


✅ high_match

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

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


✅ low_match

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

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


✅ very_low_match

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

Memory: ✅ 71.071MB (SLO: <75.000MB -5.2%) vs baseline: +4.9%


🟡 sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

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

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

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


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

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

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


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 35.586MB (SLO: <36.500MB -2.5%) vs baseline: +4.7%


✅ obfuscation-regular-case-implicit-query

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

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


✅ obfuscation-send-querystring-disabled

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

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


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.593µs (SLO: <160.000µs -7.1%) vs baseline: -0.3%

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


✅ obfuscation-worst-case-implicit-query

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

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


✅ useragentvariant_exists_1

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

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


✅ useragentvariant_exists_2

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

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


✅ useragentvariant_exists_3

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

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


✅ useragentvariant_not_exists_1

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

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


✅ useragentvariant_not_exists_2

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

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


🟡 span - 26/26

✅ add-event

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

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


✅ add-metrics

Time: ✅ 89.125ms (SLO: <93.500ms -4.7%) vs baseline: -0.1%

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


✅ add-tags

Time: ✅ 143.054ms (SLO: <155.000ms -7.7%) vs baseline: ~same

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


✅ get-context

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

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


✅ is-recording

Time: ✅ 17.279ms (SLO: <20.500ms 📉 -15.7%) vs baseline: -0.9%

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


✅ record-exception

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

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


✅ set-status

Time: ✅ 18.705ms (SLO: <22.000ms 📉 -15.0%) vs baseline: -0.7%

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


✅ start

Time: ✅ 17.374ms (SLO: <20.500ms 📉 -15.2%) vs baseline: +3.1%

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


✅ start-finish

Time: ✅ 50.835ms (SLO: <52.500ms -3.2%) vs baseline: -0.4%

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


✅ start-finish-telemetry

Time: ✅ 52.310ms (SLO: <54.500ms -4.0%) vs baseline: +0.1%

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


✅ start-finish-traceid128

Time: ✅ 54.070ms (SLO: <57.000ms -5.1%) vs baseline: -0.1%

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


✅ start-traceid128

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

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


✅ update-name

Time: ✅ 17.354ms (SLO: <22.000ms 📉 -21.1%) vs baseline: -0.3%

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


🟡 tracer - 6/6

✅ large

Time: ✅ 29.059ms (SLO: <32.950ms 📉 -11.8%) vs baseline: -0.6%

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


✅ medium

Time: ✅ 2.893ms (SLO: <3.200ms -9.6%) vs baseline: +0.3%

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


✅ small

Time: ✅ 331.517µs (SLO: <370.000µs 📉 -10.4%) vs baseline: +1.3%

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

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

✅ import_many

Time: ✅ 155.340µs (SLO: <170.000µs -8.6%) vs baseline: -0.3%

Memory: ✅ 39.373MB (SLO: <41.000MB -4.0%) vs baseline: +4.6%


✅ import_many_cached

Time: ✅ 121.158µs (SLO: <130.000µs -6.8%) vs baseline: -0.4%

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


✅ import_many_stdlib

Time: ✅ 0.754ms (SLO: <1.750ms 📉 -56.9%) vs baseline: ~same

Memory: ✅ 39.378MB (SLO: <41.000MB -4.0%) vs baseline: +5.0%


⚠️ import_many_stdlib_cached

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

Memory: ✅ 39.291MB (SLO: <41.000MB -4.2%) vs baseline: +4.7%


✅ import_many_unknown

Time: ✅ 833.337µs (SLO: <890.000µs -6.4%) vs baseline: +0.1%

Memory: ✅ 39.476MB (SLO: <41.000MB -3.7%) vs baseline: +5.1%


✅ import_many_unknown_cached

Time: ✅ 792.423µs (SLO: <870.000µs -8.9%) vs baseline: -0.9%

Memory: ✅ 39.366MB (SLO: <41.000MB -4.0%) vs baseline: +4.6%


✅ import_one

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

Memory: ✅ 39.311MB (SLO: <41.000MB -4.1%) vs baseline: +4.9%


✅ import_one_cache

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

Memory: ✅ 39.269MB (SLO: <41.000MB -4.2%) vs baseline: +4.5%


✅ import_one_stdlib

Time: ✅ 18.706µs (SLO: <20.000µs -6.5%) vs baseline: +1.0%

Memory: ✅ 39.294MB (SLO: <41.000MB -4.2%) vs baseline: +4.6%


✅ import_one_stdlib_cache

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

Memory: ✅ 39.309MB (SLO: <41.000MB -4.1%) vs baseline: +4.9%


✅ import_one_unknown

Time: ✅ 45.255µs (SLO: <50.000µs -9.5%) vs baseline: -0.2%

Memory: ✅ 39.280MB (SLO: <41.000MB -4.2%) vs baseline: +5.4%


✅ import_one_unknown_cache

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

Memory: ✅ 39.290MB (SLO: <41.000MB -4.2%) vs baseline: +4.7%

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

✅ appsec

Time: ✅ 19.608ms (SLO: <22.300ms 📉 -12.1%) vs baseline: +0.1%

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


✅ exception-replay-enabled

Time: ✅ 1.361ms (SLO: <1.450ms -6.1%) vs baseline: -0.2%

Memory: ✅ 66.117MB (SLO: <67.500MB -2.0%) vs baseline: +4.8%


✅ iast

Time: ✅ 19.553ms (SLO: <22.250ms 📉 -12.1%) vs baseline: -0.2%

Memory: ✅ 67.771MB (SLO: <70.000MB -3.2%) vs baseline: +4.3%


✅ profiler

Time: ✅ 15.469ms (SLO: <16.550ms -6.5%) vs baseline: +0.3%

Memory: ✅ 56.177MB (SLO: <57.500MB -2.3%) vs baseline: +4.6%


✅ resource-renaming

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

Memory: ✅ 68.007MB (SLO: <70.500MB -3.5%) vs baseline: +4.8%


✅ span-code-origin

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

Memory: ✅ 67.916MB (SLO: <71.000MB -4.3%) vs baseline: +4.6%


✅ tracer

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

Memory: ✅ 67.865MB (SLO: <70.000MB -3.0%) vs baseline: +4.5%


✅ tracer-and-profiler

Time: ✅ 21.770ms (SLO: <23.500ms -7.4%) vs baseline: +0.1%

Memory: ✅ 69.304MB (SLO: <71.000MB -2.4%) vs baseline: +5.0%


✅ tracer-dont-create-db-spans

Time: ✅ 19.614ms (SLO: <21.500ms -8.8%) vs baseline: -0.2%

Memory: ✅ 67.771MB (SLO: <70.000MB -3.2%) vs baseline: +4.4%


✅ tracer-minimal

Time: ✅ 16.783ms (SLO: <17.500ms -4.1%) vs baseline: -0.4%

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


✅ tracer-native

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

Memory: ✅ 67.908MB (SLO: <72.500MB -6.3%) vs baseline: +4.6%


✅ tracer-no-caches

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

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


✅ tracer-no-databases

Time: ✅ 19.129ms (SLO: <20.100ms -4.8%) vs baseline: -0.5%

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


✅ tracer-no-middleware

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

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


✅ tracer-no-templates

Time: ✅ 19.606ms (SLO: <22.000ms 📉 -10.9%) vs baseline: +0.9%

Memory: ✅ 67.846MB (SLO: <70.500MB -3.8%) vs baseline: +4.9%


errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

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

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


✅ errortracking-enabled-user

Time: ✅ 2.074ms (SLO: <2.250ms -7.8%) vs baseline: +0.2%

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


✅ tracer-enabled

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

Memory: ✅ 55.345MB (SLO: <56.500MB -2.0%) vs baseline: +4.8%


flasksqli - 6/6

✅ appsec-enabled

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

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


✅ iast-enabled

Time: ✅ 2.066ms (SLO: <2.800ms 📉 -26.2%) vs baseline: -0.1%

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


✅ tracer-enabled

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

Memory: ✅ 55.345MB (SLO: <56.500MB -2.0%) vs baseline: +4.8%


iastaspects - 118/118

✅ add_aspect

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

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


✅ add_inplace_aspect

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

Memory: ✅ 40.167MB (SLO: <41.500MB -3.2%) vs baseline: +4.1%


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +5.0%


✅ bytearray_aspect

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

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


✅ bytearray_extend_aspect

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

Memory: ✅ 40.029MB (SLO: <41.500MB -3.5%) vs baseline: +4.5%


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

Memory: ✅ 40.147MB (SLO: <41.500MB -3.3%) vs baseline: +3.6%


✅ bytes_aspect

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

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


✅ bytes_noaspect

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

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


✅ bytesio_aspect

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

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


✅ bytesio_noaspect

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

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


✅ capitalize_aspect

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

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


✅ capitalize_noaspect

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

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


✅ casefold_aspect

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

Memory: ✅ 40.305MB (SLO: <41.500MB -2.9%) vs baseline: +5.1%


✅ casefold_noaspect

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

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


✅ decode_aspect

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

Memory: ✅ 40.167MB (SLO: <41.500MB -3.2%) vs baseline: +4.0%


✅ decode_noaspect

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

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


✅ encode_aspect

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

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


✅ encode_noaspect

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

Memory: ✅ 40.167MB (SLO: <41.500MB -3.2%) vs baseline: +4.8%


✅ format_aspect

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

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


✅ format_map_aspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +4.3%


✅ format_map_noaspect

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

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


✅ format_noaspect

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

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


✅ index_aspect

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

Memory: ✅ 40.128MB (SLO: <41.500MB -3.3%) vs baseline: +4.2%


✅ index_noaspect

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

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


✅ join_aspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +4.6%


✅ join_noaspect

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

Memory: ✅ 40.167MB (SLO: <41.500MB -3.2%) vs baseline: +4.4%


✅ ljust_aspect

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

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


✅ ljust_noaspect

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

Memory: ✅ 40.324MB (SLO: <41.500MB -2.8%) vs baseline: +4.9%


✅ lower_aspect

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

Memory: ✅ 40.226MB (SLO: <41.500MB -3.1%) vs baseline: +5.0%


✅ lower_noaspect

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

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


✅ lstrip_aspect

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

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


✅ lstrip_noaspect

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

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


✅ modulo_aspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +4.9%


✅ modulo_aspect_for_bytearray_bytearray

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

Memory: ✅ 40.423MB (SLO: <41.500MB -2.6%) vs baseline: +5.5%


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

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


✅ modulo_noaspect

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

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


✅ replace_aspect

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

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


✅ replace_noaspect

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

Memory: ✅ 40.187MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ repr_aspect

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

Memory: ✅ 40.324MB (SLO: <41.500MB -2.8%) vs baseline: +4.7%


✅ repr_noaspect

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

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


✅ rstrip_aspect

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

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


✅ rstrip_noaspect

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

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


✅ slice_aspect

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

Memory: ✅ 40.147MB (SLO: <41.500MB -3.3%) vs baseline: +4.0%


✅ slice_noaspect

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

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


✅ stringio_aspect

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

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


✅ stringio_noaspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +4.9%


✅ strip_aspect

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

Memory: ✅ 40.167MB (SLO: <41.500MB -3.2%) vs baseline: +4.7%


✅ strip_noaspect

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

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


✅ swapcase_aspect

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

Memory: ✅ 40.088MB (SLO: <41.500MB -3.4%) vs baseline: +4.3%


✅ swapcase_noaspect

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

Memory: ✅ 40.324MB (SLO: <41.500MB -2.8%) vs baseline: +5.3%


✅ title_aspect

Time: ✅ 2.424µs (SLO: <10.000µs 📉 -75.8%) vs baseline: +2.7%

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


✅ title_noaspect

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

Memory: ✅ 40.285MB (SLO: <41.500MB -2.9%) vs baseline: +4.9%


✅ translate_aspect

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

Memory: ✅ 40.088MB (SLO: <41.500MB -3.4%) vs baseline: +4.2%


✅ translate_noaspect

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

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


✅ upper_aspect

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

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


✅ upper_noaspect

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

Memory: ✅ 40.187MB (SLO: <41.500MB -3.2%) vs baseline: +4.8%


iastpropagation - 8/8

✅ no-propagation

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

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


✅ propagation_enabled

Time: ✅ 174.089µs (SLO: <190.000µs -8.4%) vs baseline: -0.7%

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


✅ propagation_enabled_100

Time: ✅ 1.917ms (SLO: <2.300ms 📉 -16.7%) vs baseline: -0.4%

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


✅ propagation_enabled_1000

Time: ✅ 32.610ms (SLO: <34.550ms -5.6%) vs baseline: -0.4%

Memory: ✅ 40.010MB (SLO: <42.000MB -4.7%) vs baseline: +4.6%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.200ms (SLO: <42.000ms -4.3%) vs baseline: -0.6%

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


✅ add-link

Time: ✅ 36.174ms (SLO: <38.550ms -6.2%) vs baseline: ~same

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


✅ add-metrics

Time: ✅ 219.132ms (SLO: <232.000ms -5.5%) vs baseline: +0.5%

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


✅ add-tags

Time: ✅ 209.114ms (SLO: <221.600ms -5.6%) vs baseline: -0.8%

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


✅ get-context

Time: ✅ 29.163ms (SLO: <31.300ms -6.8%) vs baseline: +0.8%

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


✅ is-recording

Time: ✅ 29.151ms (SLO: <31.000ms -6.0%) vs baseline: -0.3%

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


✅ record-exception

Time: ✅ 63.032ms (SLO: <65.850ms -4.3%) vs baseline: +0.3%

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


✅ set-status

Time: ✅ 31.950ms (SLO: <34.150ms -6.4%) vs baseline: -1.1%

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


✅ start

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

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


✅ start-finish

Time: ✅ 34.162ms (SLO: <35.350ms -3.4%) vs baseline: +0.6%

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


✅ start-finish-telemetry

Time: ✅ 34.068ms (SLO: <35.450ms -3.9%) vs baseline: +0.3%

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


✅ update-name

Time: ✅ 31.202ms (SLO: <33.400ms -6.6%) vs baseline: +0.7%

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 343.655ms (SLO: <354.300ms -3.0%) vs baseline: -0.7%

Memory: ✅ 40.653MB (SLO: <41.500MB -2.0%) vs baseline: +4.1%


✅ cache_on

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

Memory: ✅ 39.325MB (SLO: <41.000MB -4.1%) vs baseline: +3.8%

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

Comment on lines +134 to +141
n = 1
while True:
start = time.thread_time_ns()
cpu_loop(n)
dt = time.thread_time_ns() - start
if dt > cpu_nano:
break
n *= 2
Copy link
Contributor

@vlad-scherbich vlad-scherbich Dec 5, 2025

Choose a reason for hiding this comment

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

This is a little cleaner / easier to reason about

Suggested change
n = 1
while True:
start = time.thread_time_ns()
cpu_loop(n)
dt = time.thread_time_ns() - start
if dt > cpu_nano:
break
n *= 2
n = 1
dt = 0
while dt <= cpu_nano:
start = time.thread_time_ns()
cpu_loop(n)
dt = time.thread_time_ns() - start
n *= 2

Comment on lines +166 to +171
# If actual time is more than 20% off, adjust proportionally
if actual_time_ns > 0:
ratio = cpu_nano / actual_time_ns
target_iterations = int(target_iterations * ratio)

return int(target_iterations)
Copy link
Contributor

Choose a reason for hiding this comment

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

Is this comment still accurate?

p_cal.stop(flush=True)

# Remove the pprof file created during calibration
pprof_file = os.environ["DD_PROFILING_OUTPUT_PPROF"] + "." + str(os.getpid())
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
pprof_file = os.environ["DD_PROFILING_OUTPUT_PPROF"] + "." + str(os.getpid())
pprof_file = f("{}.{}", os.environ["DD_PROFILING_OUTPUT_PPROF"], str(os.getpid())"

os.remove(pprof_file)

# Start profiler for the actual test
p = profiler.Profiler()
Copy link
Contributor

Choose a reason for hiding this comment

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

Can we reuse p_cal from above?

Comment on lines +220 to +222
start_cpu = time.thread_time_ns()
cpu_loop(iterations)
actual_cpu_time_ns += time.thread_time_ns() - start_cpu
Copy link
Contributor

Choose a reason for hiding this comment

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

This code is repeated 4-5 times, let's make it a helper that returns
time.thread_time_ns() - start_cpu

break

if sleep_function_name and wall_times[sleep_function_name] > 0:
expected_ratio = 0.01 / 0.1 # 0.1
Copy link
Contributor

Choose a reason for hiding this comment

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

Just this?

Suggested change
expected_ratio = 0.01 / 0.1 # 0.1
expected_ratio = 0.1

#
# The profiler uses sampling, so it may capture less than 100% of CPU time.
# We check that it captures at least 40% of the actual CPU time.
target_cpu_time_total_ns = actual_cpu_time_ns
Copy link
Contributor

Choose a reason for hiding this comment

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

This looks like a different test - should we break it out of here?

_DD_PROFILING_STACK_V2_ADAPTIVE_SAMPLING_ENABLED="0",
)
)
def test_cpu_loop_accuracy():
Copy link
Contributor

Choose a reason for hiding this comment

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

This one test is doing a lot of checks, and they don't all seem related. Should we refactor into several tests that do one specific thing?

  • test_cpu_loop_accuracy_THING_1
  • test_cpu_loop_accuracy_THING_2
  • ...

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. Profiling Continous Profling

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants