Skip to content

Comments

perf(internal, profiling): native PeriodicThread avoids awake() after fork()#16545

Merged
gh-worker-dd-mergequeue-cf854d[bot] merged 13 commits intomainfrom
taegyunkim/periodic-thread-fork
Feb 18, 2026
Merged

perf(internal, profiling): native PeriodicThread avoids awake() after fork()#16545
gh-worker-dd-mergequeue-cf854d[bot] merged 13 commits intomainfrom
taegyunkim/periodic-thread-fork

Conversation

@taegyunkim
Copy link
Contributor

Description

After #14163, we started to see a profiler behavior change in dd-trace-doe CI:

  • TestLanguage/python/flush/false expected 0 profiles, got 3. https://github.com/DataDog/dd-trace-doe/actions/runs/22102391228/job/63875669025

  • During pre-fork, PeriodicThread.stop() sets the internal request event to wake the periodic threads promptly.

  • After fork restart, that same request could be interpreted as a real wakeup, causing an immediate periodic() run.

  • For profiling, that means an immediate upload() right after fork, which results in unexpected profile exports.

What this PR changfes:

  • Distinguishes a fork-stop wakeup from a real awake() request in PeriodicThread
  • Clears the request after fork only when it came from the pre-fork stop path.
  • Preserves real awake() behavior across restart windows.

Testing

Risks

Additional Notes

@taegyunkim taegyunkim requested review from a team as code owners February 17, 2026 21:38
@taegyunkim taegyunkim changed the title fix(internal): PeriodicThread avoids awake() after fork() fix(internal): PeriodicThread avoids awake() after fork() Feb 17, 2026
@taegyunkim taegyunkim changed the title fix(internal): PeriodicThread avoids awake() after fork() fix(internal): native PeriodicThread avoids awake() after fork() Feb 17, 2026
Copy link

@chatgpt-codex-connector chatgpt-codex-connector bot left a comment

Choose a reason for hiding this comment

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

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: e7c6d3f49a

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

@taegyunkim taegyunkim marked this pull request as draft February 17, 2026 21:44
@datadog-datadog-prod-us1

This comment has been minimized.

@pr-commenter
Copy link

pr-commenter bot commented Feb 17, 2026

Performance SLOs

Comparing candidate taegyunkim/periodic-thread-fork (cb70445) with baseline main (af51ae1)

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

✅ add_aspect

Time: ✅ 103.072µs (SLO: <130.000µs 📉 -20.7%) vs baseline: +0.6%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ add_inplace_aspect

Time: ✅ 101.738µs (SLO: <130.000µs 📉 -21.7%) vs baseline: -2.3%

Memory: ✅ 42.998MB (SLO: <46.000MB -6.5%) vs baseline: +4.5%


✅ add_inplace_noaspect

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

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.2%


✅ add_noaspect

Time: ✅ 48.894µs (SLO: <70.000µs 📉 -30.2%) vs baseline: -0.7%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.2%


✅ bytearray_aspect

Time: ✅ 250.618µs (SLO: <400.000µs 📉 -37.3%) vs baseline: +1.3%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.7%


✅ bytearray_extend_aspect

Time: ✅ 637.775µs (SLO: <800.000µs 📉 -20.3%) vs baseline: -3.2%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ bytearray_extend_noaspect

Time: ✅ 264.587µs (SLO: <400.000µs 📉 -33.9%) vs baseline: -2.3%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.5%


✅ bytearray_noaspect

Time: ✅ 137.202µs (SLO: <300.000µs 📉 -54.3%) vs baseline: -1.4%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.6%


✅ bytes_aspect

Time: ✅ 216.590µs (SLO: <300.000µs 📉 -27.8%) vs baseline: -2.2%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.3%


✅ bytes_noaspect

Time: ✅ 133.123µs (SLO: <200.000µs 📉 -33.4%) vs baseline: -2.1%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ bytesio_aspect

Time: ✅ 3.760ms (SLO: <5.000ms 📉 -24.8%) vs baseline: -1.3%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.0%


✅ bytesio_noaspect

Time: ✅ 314.465µs (SLO: <420.000µs 📉 -25.1%) vs baseline: -1.9%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.5%


✅ capitalize_aspect

Time: ✅ 89.499µs (SLO: <300.000µs 📉 -70.2%) vs baseline: +0.8%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.6%


✅ capitalize_noaspect

Time: ✅ 251.656µs (SLO: <300.000µs 📉 -16.1%) vs baseline: -1.1%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.2%


✅ casefold_aspect

Time: ✅ 92.512µs (SLO: <500.000µs 📉 -81.5%) vs baseline: +3.9%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.3%


✅ casefold_noaspect

Time: ✅ 308.630µs (SLO: <500.000µs 📉 -38.3%) vs baseline: -1.1%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.1%


✅ decode_aspect

Time: ✅ 86.384µs (SLO: <100.000µs 📉 -13.6%) vs baseline: ~same

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.7%


✅ decode_noaspect

Time: ✅ 154.188µs (SLO: <210.000µs 📉 -26.6%) vs baseline: -0.2%

Memory: ✅ 42.998MB (SLO: <46.000MB -6.5%) vs baseline: +4.7%


✅ encode_aspect

Time: ✅ 84.385µs (SLO: <200.000µs 📉 -57.8%) vs baseline: -0.7%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.6%


✅ encode_noaspect

Time: ✅ 140.908µs (SLO: <200.000µs 📉 -29.5%) vs baseline: -0.8%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.3%


✅ format_aspect

Time: ✅ 14.605ms (SLO: <19.200ms 📉 -23.9%) vs baseline: -0.2%

Memory: ✅ 43.077MB (SLO: <46.000MB -6.4%) vs baseline: +4.2%


✅ format_map_aspect

Time: ✅ 16.385ms (SLO: <21.500ms 📉 -23.8%) vs baseline: -0.3%

Memory: ✅ 43.096MB (SLO: <46.000MB -6.3%) vs baseline: +4.5%


✅ format_map_noaspect

Time: ✅ 375.296µs (SLO: <500.000µs 📉 -24.9%) vs baseline: +0.3%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.3%


✅ format_noaspect

Time: ✅ 300.089µs (SLO: <500.000µs 📉 -40.0%) vs baseline: -2.3%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.4%


✅ index_aspect

Time: ✅ 121.493µs (SLO: <300.000µs 📉 -59.5%) vs baseline: ~same

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.2%


✅ index_noaspect

Time: ✅ 40.549µs (SLO: <300.000µs 📉 -86.5%) vs baseline: +1.0%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.6%


✅ join_aspect

Time: ✅ 210.950µs (SLO: <300.000µs 📉 -29.7%) vs baseline: -2.2%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.1%


✅ join_noaspect

Time: ✅ 141.486µs (SLO: <300.000µs 📉 -52.8%) vs baseline: -1.9%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.4%


✅ ljust_aspect

Time: ✅ 493.231µs (SLO: <700.000µs 📉 -29.5%) vs baseline: -3.6%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.6%


✅ ljust_noaspect

Time: ✅ 259.715µs (SLO: <300.000µs 📉 -13.4%) vs baseline: -0.5%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.5%


✅ lower_aspect

Time: ✅ 294.822µs (SLO: <500.000µs 📉 -41.0%) vs baseline: -2.4%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.2%


✅ lower_noaspect

Time: ✅ 237.233µs (SLO: <300.000µs 📉 -20.9%) vs baseline: +0.8%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.6%


✅ lstrip_aspect

Time: ✅ 0.269ms (SLO: <3.000ms 📉 -91.0%) vs baseline: -3.1%

Memory: ✅ 42.998MB (SLO: <46.000MB -6.5%) vs baseline: +4.4%


✅ lstrip_noaspect

Time: ✅ 0.211ms (SLO: <3.000ms 📉 -93.0%) vs baseline: 📈 +18.1%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.4%


✅ modulo_aspect

Time: ✅ 14.525ms (SLO: <18.750ms 📉 -22.5%) vs baseline: +2.0%

Memory: ✅ 42.998MB (SLO: <46.000MB -6.5%) vs baseline: +4.4%


✅ modulo_aspect_for_bytearray_bytearray

Time: ✅ 14.745ms (SLO: <19.350ms 📉 -23.8%) vs baseline: -1.1%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.4%


✅ modulo_aspect_for_bytes

Time: ✅ 14.365ms (SLO: <18.900ms 📉 -24.0%) vs baseline: -0.5%

Memory: ✅ 43.037MB (SLO: <46.000MB -6.4%) vs baseline: +4.6%


✅ modulo_aspect_for_bytes_bytearray

Time: ✅ 14.624ms (SLO: <19.150ms 📉 -23.6%) vs baseline: ~same

Memory: ✅ 43.037MB (SLO: <46.000MB -6.4%) vs baseline: +4.3%


✅ modulo_noaspect

Time: ✅ 0.360ms (SLO: <3.000ms 📉 -88.0%) vs baseline: -1.0%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ replace_aspect

Time: ✅ 18.341ms (SLO: <24.000ms 📉 -23.6%) vs baseline: -0.4%

Memory: ✅ 43.096MB (SLO: <46.000MB -6.3%) vs baseline: +4.4%


✅ replace_noaspect

Time: ✅ 278.144µs (SLO: <300.000µs -7.3%) vs baseline: -0.9%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +4.5%


✅ repr_aspect

Time: ✅ 310.992µs (SLO: <420.000µs 📉 -26.0%) vs baseline: -2.9%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.5%


✅ repr_noaspect

Time: ✅ 47.133µs (SLO: <90.000µs 📉 -47.6%) vs baseline: +1.4%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ rstrip_aspect

Time: ✅ 384.359µs (SLO: <500.000µs 📉 -23.1%) vs baseline: -1.5%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.4%


✅ rstrip_noaspect

Time: ✅ 183.872µs (SLO: <300.000µs 📉 -38.7%) vs baseline: +0.2%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.3%


✅ slice_aspect

Time: ✅ 183.380µs (SLO: <300.000µs 📉 -38.9%) vs baseline: -0.4%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ slice_noaspect

Time: ✅ 53.844µs (SLO: <90.000µs 📉 -40.2%) vs baseline: -0.3%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.0%


✅ stringio_aspect

Time: ✅ 3.835ms (SLO: <5.000ms 📉 -23.3%) vs baseline: -0.9%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.3%


✅ stringio_noaspect

Time: ✅ 381.087µs (SLO: <500.000µs 📉 -23.8%) vs baseline: +7.2%

Memory: ✅ 43.018MB (SLO: <46.000MB -6.5%) vs baseline: +4.7%


✅ strip_aspect

Time: ✅ 269.644µs (SLO: <350.000µs 📉 -23.0%) vs baseline: -2.0%

Memory: ✅ 42.821MB (SLO: <46.000MB -6.9%) vs baseline: +4.0%


✅ strip_noaspect

Time: ✅ 176.075µs (SLO: <240.000µs 📉 -26.6%) vs baseline: -1.0%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.1%


✅ swapcase_aspect

Time: ✅ 335.028µs (SLO: <500.000µs 📉 -33.0%) vs baseline: -1.6%

Memory: ✅ 42.900MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ swapcase_noaspect

Time: ✅ 274.248µs (SLO: <400.000µs 📉 -31.4%) vs baseline: -1.0%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ title_aspect

Time: ✅ 320.469µs (SLO: <500.000µs 📉 -35.9%) vs baseline: -2.7%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.2%


✅ title_noaspect

Time: ✅ 259.644µs (SLO: <400.000µs 📉 -35.1%) vs baseline: ~same

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.3%


✅ translate_aspect

Time: ✅ 489.717µs (SLO: <700.000µs 📉 -30.0%) vs baseline: -2.2%

Memory: ✅ 42.920MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


✅ translate_noaspect

Time: ✅ 422.540µs (SLO: <500.000µs 📉 -15.5%) vs baseline: -2.7%

Memory: ✅ 42.959MB (SLO: <46.000MB -6.6%) vs baseline: +4.2%


✅ upper_aspect

Time: ✅ 294.587µs (SLO: <500.000µs 📉 -41.1%) vs baseline: -2.1%

Memory: ✅ 42.880MB (SLO: <46.000MB -6.8%) vs baseline: +4.1%


✅ upper_noaspect

Time: ✅ 236.482µs (SLO: <400.000µs 📉 -40.9%) vs baseline: +0.5%

Memory: ✅ 42.939MB (SLO: <46.000MB -6.7%) vs baseline: +4.4%


📈 iastaspectsospath - 24/24

✅ ospathbasename_aspect

Time: ✅ 510.926µs (SLO: <700.000µs 📉 -27.0%) vs baseline: 📈 +20.0%

Memory: ✅ 42.605MB (SLO: <46.000MB -7.4%) vs baseline: +4.4%


✅ ospathbasename_noaspect

Time: ✅ 434.442µs (SLO: <700.000µs 📉 -37.9%) vs baseline: ~same

Memory: ✅ 42.664MB (SLO: <46.000MB -7.3%) vs baseline: +4.5%


✅ ospathjoin_aspect

Time: ✅ 631.297µs (SLO: <700.000µs -9.8%) vs baseline: +1.0%

Memory: ✅ 42.507MB (SLO: <46.000MB -7.6%) vs baseline: +3.8%


✅ ospathjoin_noaspect

Time: ✅ 633.263µs (SLO: <700.000µs -9.5%) vs baseline: ~same

Memory: ✅ 42.507MB (SLO: <46.000MB -7.6%) vs baseline: +3.9%


✅ ospathnormcase_aspect

Time: ✅ 348.920µs (SLO: <700.000µs 📉 -50.2%) vs baseline: -0.6%

Memory: ✅ 42.526MB (SLO: <46.000MB -7.6%) vs baseline: +4.4%


✅ ospathnormcase_noaspect

Time: ✅ 358.302µs (SLO: <700.000µs 📉 -48.8%) vs baseline: +0.7%

Memory: ✅ 42.566MB (SLO: <46.000MB -7.5%) vs baseline: +3.7%


✅ ospathsplit_aspect

Time: ✅ 488.951µs (SLO: <700.000µs 📉 -30.1%) vs baseline: -0.7%

Memory: ✅ 42.684MB (SLO: <46.000MB -7.2%) vs baseline: +4.0%


✅ ospathsplit_noaspect

Time: ✅ 500.121µs (SLO: <700.000µs 📉 -28.6%) vs baseline: -0.3%

Memory: ✅ 42.625MB (SLO: <46.000MB -7.3%) vs baseline: +4.2%


✅ ospathsplitdrive_aspect

Time: ✅ 377.418µs (SLO: <700.000µs 📉 -46.1%) vs baseline: +2.3%

Memory: ✅ 42.723MB (SLO: <46.000MB -7.1%) vs baseline: +4.8%


✅ ospathsplitdrive_noaspect

Time: ✅ 72.939µs (SLO: <700.000µs 📉 -89.6%) vs baseline: -0.9%

Memory: ✅ 42.979MB (SLO: <46.000MB -6.6%) vs baseline: +5.3%


✅ ospathsplitext_aspect

Time: ✅ 458.583µs (SLO: <700.000µs 📉 -34.5%) vs baseline: -0.3%

Memory: ✅ 42.644MB (SLO: <46.000MB -7.3%) vs baseline: +4.7%


✅ ospathsplitext_noaspect

Time: ✅ 469.920µs (SLO: <700.000µs 📉 -32.9%) vs baseline: +1.1%

Memory: ✅ 42.644MB (SLO: <46.000MB -7.3%) vs baseline: +4.6%

🟡 Near SLO Breach (1 suite)
🟡 tracer - 6/6

✅ large

Time: ✅ 31.539ms (SLO: <32.950ms -4.3%) vs baseline: +0.2%

Memory: ✅ 36.707MB (SLO: <39.250MB -6.5%) vs baseline: +4.6%


✅ medium

Time: ✅ 3.117ms (SLO: <3.200ms -2.6%) vs baseline: +0.9%

Memory: ✅ 35.527MB (SLO: <38.750MB -8.3%) vs baseline: +5.1%


✅ small

Time: ✅ 362.820µs (SLO: <370.000µs 🟡 -1.9%) vs baseline: +4.5%

Memory: ✅ 35.586MB (SLO: <38.750MB -8.2%) vs baseline: +5.7%

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

⚠️ context_with_data_listeners

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.7%


✅ context_with_data_no_listeners

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

Memory: ✅ 35.547MB (SLO: <38.000MB -6.5%) vs baseline: +4.0%


✅ get_item_exists

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

Memory: ✅ 35.507MB (SLO: <38.000MB -6.6%) vs baseline: +4.2%


✅ get_item_missing

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.4%


✅ set_item

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

Memory: ✅ 35.547MB (SLO: <38.000MB -6.5%) vs baseline: +3.8%


⚠️ packagesupdateimporteddependencies - 24/24 (1 unstable)

✅ import_many

Time: ✅ 155.151µs (SLO: <170.000µs -8.7%) vs baseline: -0.7%

Memory: ✅ 40.609MB (SLO: <46.000MB 📉 -11.7%) vs baseline: +4.8%


✅ import_many_cached

Time: ✅ 120.996µs (SLO: <130.000µs -6.9%) vs baseline: +0.3%

Memory: ✅ 40.361MB (SLO: <46.000MB 📉 -12.3%) vs baseline: +5.1%


✅ import_many_stdlib

Time: ✅ 0.770ms (SLO: <1.750ms 📉 -56.0%) vs baseline: +0.9%

Memory: ✅ 40.236MB (SLO: <46.000MB 📉 -12.5%) vs baseline: +3.3%


⚠️ import_many_stdlib_cached

Time: ⚠️ 0.176ms (SLO: <1.100ms 📉 -84.0%) vs baseline: +0.9%

Memory: ✅ 40.242MB (SLO: <46.000MB 📉 -12.5%) vs baseline: +4.0%


✅ import_many_unknown

Time: ✅ 829.774µs (SLO: <890.000µs -6.8%) vs baseline: +0.5%

Memory: ✅ 40.649MB (SLO: <46.000MB 📉 -11.6%) vs baseline: +4.6%


✅ import_many_unknown_cached

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

Memory: ✅ 40.656MB (SLO: <46.000MB 📉 -11.6%) vs baseline: +4.7%


✅ import_one

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

Memory: ✅ 40.355MB (SLO: <46.000MB 📉 -12.3%) vs baseline: +4.0%


✅ import_one_cache

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

Memory: ✅ 40.445MB (SLO: <46.000MB 📉 -12.1%) vs baseline: +5.3%


✅ import_one_stdlib

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

Memory: ✅ 40.259MB (SLO: <46.000MB 📉 -12.5%) vs baseline: +4.6%


✅ import_one_stdlib_cache

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

Memory: ✅ 40.286MB (SLO: <46.000MB 📉 -12.4%) vs baseline: +4.2%


✅ import_one_unknown

Time: ✅ 45.532µs (SLO: <50.000µs -8.9%) vs baseline: +0.6%

Memory: ✅ 40.340MB (SLO: <46.000MB 📉 -12.3%) vs baseline: +4.9%


✅ import_one_unknown_cache

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

Memory: ✅ 40.330MB (SLO: <43.000MB -6.2%) vs baseline: +4.2%

✅ All Tests Passing (19 suites)
djangosimple - 23/23

✅ appsec

Time: ✅ 19.541ms (SLO: <22.300ms 📉 -12.4%) vs baseline: -0.8%

Memory: ✅ 67.613MB (SLO: <73.500MB -8.0%) vs baseline: +4.6%


✅ exception-replay-enabled

Time: ✅ 1.384ms (SLO: <1.450ms -4.5%) vs baseline: -0.1%

Memory: ✅ 65.824MB (SLO: <71.500MB -7.9%) vs baseline: +4.8%


✅ iast

Time: ✅ 19.579ms (SLO: <22.250ms 📉 -12.0%) vs baseline: -0.6%


✅ profiler

Time: ✅ 15.319ms (SLO: <16.550ms -7.4%) vs baseline: +0.4%

Memory: ✅ 58.820MB (SLO: <61.000MB -3.6%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 19.522ms (SLO: <21.750ms 📉 -10.2%) vs baseline: -0.2%


✅ span-code-origin

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

Memory: ✅ 67.665MB (SLO: <75.000MB -9.8%) vs baseline: +4.8%


✅ tracer

Time: ✅ 19.548ms (SLO: <21.750ms 📉 -10.1%) vs baseline: -0.3%

Memory: ✅ 67.613MB (SLO: <75.000MB -9.8%) vs baseline: +4.8%


✅ tracer-and-profiler

Time: ✅ 21.080ms (SLO: <23.500ms 📉 -10.3%) vs baseline: -0.3%


✅ tracer-dont-create-db-spans

Time: ✅ 19.715ms (SLO: <21.500ms -8.3%) vs baseline: ~same


✅ tracer-minimal

Time: ✅ 16.791ms (SLO: <17.500ms -4.0%) vs baseline: -0.3%


✅ tracer-native

Time: ✅ 19.454ms (SLO: <21.750ms 📉 -10.6%) vs baseline: -0.2%


✅ tracer-no-caches

Time: ✅ 17.608ms (SLO: <19.650ms 📉 -10.4%) vs baseline: +0.5%

Memory: ✅ 67.613MB (SLO: <75.000MB -9.8%) vs baseline: +4.7%


✅ tracer-no-databases

Time: ✅ 19.216ms (SLO: <20.100ms -4.4%) vs baseline: +0.3%


✅ tracer-no-middleware

Time: ✅ 19.389ms (SLO: <21.500ms -9.8%) vs baseline: +0.4%

Memory: ✅ 67.613MB (SLO: <75.000MB -9.8%) vs baseline: +4.7%


✅ tracer-no-templates

Time: ✅ 19.645ms (SLO: <22.000ms 📉 -10.7%) vs baseline: +2.0%

Memory: ✅ 67.604MB (SLO: <73.500MB -8.0%) vs baseline: +4.6%


errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 16.291ms (SLO: <19.850ms 📉 -17.9%) vs baseline: -0.4%

Memory: ✅ 67.132MB (SLO: <75.000MB 📉 -10.5%) vs baseline: +4.8%


✅ errortracking-enabled-user

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

Memory: ✅ 67.156MB (SLO: <75.000MB 📉 -10.5%) vs baseline: +4.9%


✅ tracer-enabled

Time: ✅ 16.364ms (SLO: <19.450ms 📉 -15.9%) vs baseline: +0.2%

Memory: ✅ 67.225MB (SLO: <75.000MB 📉 -10.4%) vs baseline: +5.0%


errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.104ms (SLO: <2.300ms -8.5%) vs baseline: -0.5%

Memory: ✅ 55.011MB (SLO: <60.000MB -8.3%) vs baseline: +4.7%


✅ errortracking-enabled-user

Time: ✅ 2.115ms (SLO: <2.250ms -6.0%) vs baseline: ~same

Memory: ✅ 54.952MB (SLO: <60.000MB -8.4%) vs baseline: +4.7%


✅ tracer-enabled

Time: ✅ 2.102ms (SLO: <2.300ms -8.6%) vs baseline: ~same

Memory: ✅ 54.972MB (SLO: <60.000MB -8.4%) vs baseline: +4.7%


flasksimple - 18/18

✅ appsec-get

Time: ✅ 3.438ms (SLO: <4.750ms 📉 -27.6%) vs baseline: +0.8%

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


✅ appsec-post

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

Memory: ✅ 55.054MB (SLO: <66.500MB 📉 -17.2%) vs baseline: +4.5%


✅ appsec-telemetry

Time: ✅ 3.446ms (SLO: <4.750ms 📉 -27.5%) vs baseline: +1.6%

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


✅ debugger

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

Memory: ✅ 48.349MB (SLO: <51.500MB -6.1%) vs baseline: +4.4%


✅ iast-get

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

Memory: ✅ 45.204MB (SLO: <49.000MB -7.7%) vs baseline: +4.3%


✅ profiler

Time: ✅ 1.903ms (SLO: <2.100ms -9.4%) vs baseline: ~same

Memory: ✅ 51.201MB (SLO: <52.500MB -2.5%) vs baseline: +4.8%


✅ resource-renaming

Time: ✅ 3.393ms (SLO: <3.650ms -7.0%) vs baseline: +0.3%

Memory: ✅ 54.885MB (SLO: <60.000MB -8.5%) vs baseline: +4.8%


✅ tracer

Time: ✅ 3.408ms (SLO: <3.650ms -6.6%) vs baseline: -0.1%

Memory: ✅ 54.779MB (SLO: <60.000MB -8.7%) vs baseline: +4.9%


✅ tracer-native

Time: ✅ 3.408ms (SLO: <3.650ms -6.6%) vs baseline: +0.3%

Memory: ✅ 54.838MB (SLO: <60.000MB -8.6%) vs baseline: +4.7%


flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 2.102ms (SLO: <4.200ms 📉 -50.0%) vs baseline: -0.1%

Memory: ✅ 54.952MB (SLO: <66.000MB 📉 -16.7%) vs baseline: +4.5%


✅ iast-enabled

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

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


✅ tracer-enabled

Time: ✅ 2.100ms (SLO: <2.250ms -6.7%) vs baseline: +0.1%

Memory: ✅ 55.070MB (SLO: <60.000MB -8.2%) vs baseline: +4.7%


forktime - 4/4

✅ baseline

Time: ✅ 1.960ms (SLO: <3.000ms 📉 -34.7%) vs baseline: +4.3%

Memory: ✅ 29.275MB (SLO: <33.000MB 📉 -11.3%) vs baseline: +5.0%


✅ configured

Time: ✅ 8.588ms (SLO: <13.000ms 📉 -33.9%) vs baseline: -1.9%

Memory: ✅ 54.940MB (SLO: <60.000MB -8.4%) vs baseline: +4.6%


httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 75.182µs (SLO: <100.000µs 📉 -24.8%) vs baseline: -1.3%

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.7%


✅ b3_headers

Time: ✅ 12.769µs (SLO: <20.000µs 📉 -36.2%) vs baseline: -1.4%

Memory: ✅ 35.704MB (SLO: <38.000MB -6.0%) vs baseline: +4.6%


✅ b3_single_headers

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

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.3%


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 60.682µs (SLO: <80.000µs 📉 -24.1%) vs baseline: -0.8%

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.5%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 62.223µs (SLO: <80.000µs 📉 -22.2%) vs baseline: -0.7%

Memory: ✅ 35.704MB (SLO: <38.000MB -6.0%) vs baseline: +4.8%


✅ empty_headers

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

Memory: ✅ 35.645MB (SLO: <38.000MB -6.2%) vs baseline: +4.4%


✅ full_t_id_datadog_headers

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

Memory: ✅ 35.802MB (SLO: <38.000MB -5.8%) vs baseline: +4.7%


✅ invalid_priority_header

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

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.6%


✅ invalid_span_id_header

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ invalid_tags_header

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

Memory: ✅ 35.527MB (SLO: <38.000MB -6.5%) vs baseline: +4.1%


✅ invalid_trace_id_header

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.3%


✅ large_header_no_matches

Time: ✅ 27.126µs (SLO: <30.000µs -9.6%) vs baseline: +0.3%

Memory: ✅ 35.645MB (SLO: <38.000MB -6.2%) vs baseline: +4.2%


✅ large_valid_headers_all

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.5%


✅ medium_header_no_matches

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.3%


✅ medium_valid_headers_all

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

Memory: ✅ 35.645MB (SLO: <38.000MB -6.2%) vs baseline: +4.1%


✅ none_propagation_style

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

Memory: ✅ 35.645MB (SLO: <38.000MB -6.2%) vs baseline: +4.4%


✅ tracecontext_headers

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

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.3%


✅ valid_headers_all

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

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.3%


✅ valid_headers_basic

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ wsgi_empty_headers

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

Memory: ✅ 35.704MB (SLO: <38.000MB -6.0%) vs baseline: +4.6%


✅ wsgi_invalid_priority_header

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

Memory: ✅ 35.704MB (SLO: <38.000MB -6.0%) vs baseline: +4.7%


✅ wsgi_invalid_span_id_header

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

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.2%


✅ wsgi_invalid_tags_header

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.1%


✅ wsgi_invalid_trace_id_header

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

Memory: ✅ 35.724MB (SLO: <38.000MB -6.0%) vs baseline: +4.7%


✅ wsgi_large_header_no_matches

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

Memory: ✅ 35.645MB (SLO: <38.000MB -6.2%) vs baseline: +4.5%


✅ wsgi_large_valid_headers_all

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

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.3%


✅ wsgi_medium_header_no_matches

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ wsgi_medium_valid_headers_all

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.6%


✅ wsgi_valid_headers_all

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

Memory: ✅ 35.724MB (SLO: <38.000MB -6.0%) vs baseline: +4.7%


✅ wsgi_valid_headers_basic

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

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.2%


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 20.465µs (SLO: <30.000µs 📉 -31.8%) vs baseline: +4.0%

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.2%


✅ with_all

Time: ✅ 26.222µs (SLO: <40.000µs 📉 -34.4%) vs baseline: -1.8%

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.6%


✅ with_dd_origin

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

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.8%


✅ with_priority_and_origin

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

Memory: ✅ 35.704MB (SLO: <38.000MB -6.0%) vs baseline: +4.7%


✅ with_sampling_priority

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

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.4%


✅ with_tags

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

Memory: ✅ 35.684MB (SLO: <38.000MB -6.1%) vs baseline: +4.7%


✅ with_tags_invalid

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

Memory: ✅ 35.743MB (SLO: <38.000MB -5.9%) vs baseline: +4.7%


✅ with_tags_max_size

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

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.5%


iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 154.153µs (SLO: <250.000µs 📉 -38.3%) vs baseline: -1.4%

Memory: ✅ 42.723MB (SLO: <46.000MB -7.1%) vs baseline: +4.6%


✅ rsplit_noaspect

Time: ✅ 156.312µs (SLO: <250.000µs 📉 -37.5%) vs baseline: -5.3%

Memory: ✅ 42.566MB (SLO: <46.000MB -7.5%) vs baseline: +4.6%


✅ split_aspect

Time: ✅ 149.022µs (SLO: <250.000µs 📉 -40.4%) vs baseline: -2.9%

Memory: ✅ 42.723MB (SLO: <46.000MB -7.1%) vs baseline: +4.7%


✅ split_noaspect

Time: ✅ 155.871µs (SLO: <250.000µs 📉 -37.7%) vs baseline: -4.6%

Memory: ✅ 42.585MB (SLO: <46.000MB -7.4%) vs baseline: +4.5%


✅ splitlines_aspect

Time: ✅ 145.277µs (SLO: <250.000µs 📉 -41.9%) vs baseline: -4.9%

Memory: ✅ 42.644MB (SLO: <46.000MB -7.3%) vs baseline: +4.3%


✅ splitlines_noaspect

Time: ✅ 150.008µs (SLO: <250.000µs 📉 -40.0%) vs baseline: -5.9%

Memory: ✅ 42.585MB (SLO: <46.000MB -7.4%) vs baseline: +4.5%


iastpropagation - 8/8

✅ no-propagation

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

Memory: ✅ 38.909MB (SLO: <42.000MB -7.4%) vs baseline: +4.2%


✅ propagation_enabled

Time: ✅ 136.033µs (SLO: <190.000µs 📉 -28.4%) vs baseline: +1.5%

Memory: ✅ 38.869MB (SLO: <42.000MB -7.5%) vs baseline: +4.0%


✅ propagation_enabled_100

Time: ✅ 1.589ms (SLO: <2.300ms 📉 -30.9%) vs baseline: +2.4%

Memory: ✅ 39.046MB (SLO: <42.000MB -7.0%) vs baseline: +4.5%


✅ propagation_enabled_1000

Time: ✅ 28.972ms (SLO: <34.550ms 📉 -16.1%) vs baseline: +0.4%

Memory: ✅ 38.987MB (SLO: <42.000MB -7.2%) vs baseline: +4.4%


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.440ms (SLO: <42.000ms -3.7%) vs baseline: +0.6%

Memory: ✅ 38.044MB (SLO: <40.750MB -6.6%) vs baseline: +4.5%


✅ add-link

Time: ✅ 36.237ms (SLO: <38.550ms -6.0%) vs baseline: +0.2%

Memory: ✅ 37.906MB (SLO: <40.750MB -7.0%) vs baseline: +3.8%


✅ add-metrics

Time: ✅ 219.197ms (SLO: <232.000ms -5.5%) vs baseline: -0.9%

Memory: ✅ 38.083MB (SLO: <40.750MB -6.5%) vs baseline: +4.6%


✅ add-tags

Time: ✅ 212.691ms (SLO: <221.600ms -4.0%) vs baseline: +0.4%

Memory: ✅ 38.024MB (SLO: <40.750MB -6.7%) vs baseline: +4.3%


✅ get-context

Time: ✅ 29.212ms (SLO: <31.300ms -6.7%) vs baseline: +0.9%

Memory: ✅ 37.945MB (SLO: <40.750MB -6.9%) vs baseline: +4.5%


✅ is-recording

Time: ✅ 29.388ms (SLO: <31.000ms -5.2%) vs baseline: +0.9%

Memory: ✅ 38.201MB (SLO: <40.750MB -6.3%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 62.867ms (SLO: <65.850ms -4.5%) vs baseline: -0.2%

Memory: ✅ 38.181MB (SLO: <40.750MB -6.3%) vs baseline: +4.8%


✅ set-status

Time: ✅ 32.065ms (SLO: <34.150ms -6.1%) vs baseline: +0.6%

Memory: ✅ 38.083MB (SLO: <40.750MB -6.5%) vs baseline: +4.6%


✅ start

Time: ✅ 29.229ms (SLO: <30.150ms -3.1%) vs baseline: +1.3%

Memory: ✅ 38.083MB (SLO: <40.750MB -6.5%) vs baseline: +4.7%


✅ start-finish

Time: ✅ 33.993ms (SLO: <35.350ms -3.8%) vs baseline: +0.4%

Memory: ✅ 37.985MB (SLO: <40.750MB -6.8%) vs baseline: +4.4%


✅ start-finish-telemetry

Time: ✅ 34.076ms (SLO: <35.450ms -3.9%) vs baseline: +0.8%

Memory: ✅ 38.103MB (SLO: <40.750MB -6.5%) vs baseline: +4.8%


✅ update-name

Time: ✅ 31.150ms (SLO: <33.400ms -6.7%) vs baseline: +0.2%

Memory: ✅ 37.985MB (SLO: <40.750MB -6.8%) vs baseline: +4.5%


otelspan - 22/22

✅ add-event

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

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


✅ add-metrics

Time: ✅ 249.988ms (SLO: <344.800ms 📉 -27.5%) vs baseline: ~same

Memory: ✅ 44.870MB (SLO: <47.500MB -5.5%) vs baseline: +4.6%


✅ add-tags

Time: ✅ 307.394ms (SLO: <330.000ms -6.9%) vs baseline: +1.1%

Memory: ✅ 44.892MB (SLO: <47.500MB -5.5%) vs baseline: +4.5%


✅ get-context

Time: ✅ 81.336ms (SLO: <92.350ms 📉 -11.9%) vs baseline: +0.7%

Memory: ✅ 40.796MB (SLO: <46.500MB 📉 -12.3%) vs baseline: +4.5%


✅ is-recording

Time: ✅ 37.054ms (SLO: <44.500ms 📉 -16.7%) vs baseline: +0.6%

Memory: ✅ 40.306MB (SLO: <47.500MB 📉 -15.1%) vs baseline: +4.5%


✅ record-exception

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

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


✅ set-status

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

Memory: ✅ 40.431MB (SLO: <47.000MB 📉 -14.0%) vs baseline: +5.1%


✅ start

Time: ✅ 38.088ms (SLO: <43.450ms 📉 -12.3%) vs baseline: +4.5%

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


✅ start-finish

Time: ✅ 85.149ms (SLO: <90.000ms -5.4%) vs baseline: +0.4%

Memory: ✅ 38.063MB (SLO: <46.500MB 📉 -18.1%) vs baseline: +4.3%


✅ start-finish-telemetry

Time: ✅ 86.948ms (SLO: <91.000ms -4.5%) vs baseline: +0.5%

Memory: ✅ 38.024MB (SLO: <46.500MB 📉 -18.2%) vs baseline: +4.2%


✅ update-name

Time: ✅ 38.244ms (SLO: <45.150ms 📉 -15.3%) vs baseline: +0.5%

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


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 346.000ms (SLO: <354.300ms -2.3%) vs baseline: -1.2%

Memory: ✅ 41.572MB (SLO: <46.000MB -9.6%) vs baseline: +5.1%


✅ cache_on

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

Memory: ✅ 40.247MB (SLO: <46.000MB 📉 -12.5%) vs baseline: +5.1%


ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.9%


✅ high_rate_limit

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

Memory: ✅ 35.488MB (SLO: <38.000MB -6.6%) vs baseline: +4.3%


✅ long_window

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

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.6%


✅ low_rate_limit

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

Memory: ✅ 35.566MB (SLO: <38.000MB -6.4%) vs baseline: +4.6%


✅ no_rate_limit

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

Memory: ✅ 35.507MB (SLO: <38.000MB -6.6%) vs baseline: +4.4%


✅ short_window

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

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.5%


recursivecomputation - 8/8

✅ deep

Time: ✅ 309.803ms (SLO: <320.950ms -3.5%) vs baseline: ~same

Memory: ✅ 36.294MB (SLO: <38.750MB -6.3%) vs baseline: +4.3%


✅ deep-profiled

Time: ✅ 331.207ms (SLO: <359.150ms -7.8%) vs baseline: +0.2%

Memory: ✅ 42.330MB (SLO: <46.000MB -8.0%) vs baseline: +4.8%


✅ medium

Time: ✅ 7.131ms (SLO: <7.400ms -3.6%) vs baseline: -0.1%

Memory: ✅ 35.468MB (SLO: <38.000MB -6.7%) vs baseline: +3.9%


✅ shallow

Time: ✅ 0.986ms (SLO: <1.050ms -6.1%) vs baseline: +2.2%

Memory: ✅ 35.429MB (SLO: <38.000MB -6.8%) vs baseline: +4.0%


samplingrules - 8/8

✅ average_match

Time: ✅ 146.947µs (SLO: <290.000µs 📉 -49.3%) vs baseline: -1.9%

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.4%


✅ high_match

Time: ✅ 191.877µs (SLO: <480.000µs 📉 -60.0%) vs baseline: -3.2%

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.8%


✅ low_match

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

Memory: ✅ 700.744MB (SLO: <780.000MB 📉 -10.2%) vs baseline: +4.8%


✅ very_low_match

Time: ✅ 2.884ms (SLO: <8.500ms 📉 -66.1%) vs baseline: -1.9%

Memory: ✅ 77.888MB (SLO: <85.000MB -8.4%) vs baseline: +4.7%


sethttpmeta - 32/32

✅ all-disabled

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

Memory: ✅ 36.176MB (SLO: <38.750MB -6.6%) vs baseline: +4.7%


✅ all-enabled

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

Memory: ✅ 35.979MB (SLO: <38.750MB -7.2%) vs baseline: +3.9%


✅ collectipvariant_exists

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

Memory: ✅ 36.156MB (SLO: <38.750MB -6.7%) vs baseline: +4.8%


✅ no-collectipvariant

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

Memory: ✅ 35.999MB (SLO: <38.750MB -7.1%) vs baseline: +4.4%


✅ no-useragentvariant

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

Memory: ✅ 36.156MB (SLO: <38.750MB -6.7%) vs baseline: +4.6%


✅ obfuscation-no-query

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

Memory: ✅ 36.117MB (SLO: <38.750MB -6.8%) vs baseline: +4.5%


✅ obfuscation-regular-case-explicit-query

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

Memory: ✅ 36.372MB (SLO: <38.750MB -6.1%) vs baseline: +4.2%


✅ obfuscation-regular-case-implicit-query

Time: ✅ 76.569µs (SLO: <90.000µs 📉 -14.9%) vs baseline: -0.5%

Memory: ✅ 36.372MB (SLO: <38.750MB -6.1%) vs baseline: +4.2%


✅ obfuscation-send-querystring-disabled

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

Memory: ✅ 36.392MB (SLO: <38.750MB -6.1%) vs baseline: +4.5%


✅ obfuscation-worst-case-explicit-query

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

Memory: ✅ 36.412MB (SLO: <38.750MB -6.0%) vs baseline: +4.5%


✅ obfuscation-worst-case-implicit-query

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

Memory: ✅ 36.451MB (SLO: <38.750MB -5.9%) vs baseline: +4.6%


✅ useragentvariant_exists_1

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

Memory: ✅ 36.176MB (SLO: <38.750MB -6.6%) vs baseline: +4.5%


✅ useragentvariant_exists_2

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

Memory: ✅ 35.999MB (SLO: <38.750MB -7.1%) vs baseline: +4.4%


✅ useragentvariant_exists_3

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

Memory: ✅ 36.176MB (SLO: <38.750MB -6.6%) vs baseline: +4.6%


✅ useragentvariant_not_exists_1

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

Memory: ✅ 36.156MB (SLO: <38.750MB -6.7%) vs baseline: +4.4%


✅ useragentvariant_not_exists_2

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

Memory: ✅ 36.097MB (SLO: <38.750MB -6.8%) vs baseline: +4.2%


span - 26/26

✅ add-event

Time: ✅ 18.615ms (SLO: <22.500ms 📉 -17.3%) vs baseline: +0.6%

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


✅ add-metrics

Time: ✅ 88.105ms (SLO: <93.500ms -5.8%) vs baseline: +0.7%

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


✅ add-tags

Time: ✅ 144.641ms (SLO: <155.000ms -6.7%) vs baseline: +0.6%

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


✅ get-context

Time: ✅ 17.087ms (SLO: <20.500ms 📉 -16.6%) vs baseline: +1.2%

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


✅ is-recording

Time: ✅ 17.132ms (SLO: <20.500ms 📉 -16.4%) vs baseline: +0.4%

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


✅ record-exception

Time: ✅ 38.134ms (SLO: <41.000ms -7.0%) vs baseline: +1.1%

Memory: ✅ 38.019MB (SLO: <53.000MB 📉 -28.3%) vs baseline: +4.4%


✅ set-status

Time: ✅ 18.787ms (SLO: <22.000ms 📉 -14.6%) vs baseline: +0.3%

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


✅ start

Time: ✅ 18.009ms (SLO: <20.500ms 📉 -12.2%) vs baseline: +7.5%

Memory: ✅ 37.454MB (SLO: <53.000MB 📉 -29.3%) vs baseline: +4.1%


✅ start-finish

Time: ✅ 53.442ms (SLO: <56.000ms -4.6%) vs baseline: +0.3%

Memory: ✅ 35.547MB (SLO: <38.000MB -6.5%) vs baseline: +4.3%


✅ start-finish-telemetry

Time: ✅ 54.551ms (SLO: <58.000ms -5.9%) vs baseline: +0.1%

Memory: ✅ 35.507MB (SLO: <38.000MB -6.6%) vs baseline: +4.2%


✅ start-finish-traceid128

Time: ✅ 55.904ms (SLO: <60.000ms -6.8%) vs baseline: +0.3%

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.2%


✅ start-traceid128

Time: ✅ 16.908ms (SLO: <22.500ms 📉 -24.9%) vs baseline: +0.5%

Memory: ✅ 37.552MB (SLO: <53.000MB 📉 -29.1%) vs baseline: +4.4%


✅ update-name

Time: ✅ 17.640ms (SLO: <22.000ms 📉 -19.8%) vs baseline: +1.1%

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


telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 2.247µs (SLO: <20.000µs 📉 -88.8%) vs baseline: +8.8%

Memory: ✅ 35.625MB (SLO: <38.000MB -6.2%) vs baseline: +4.4%


✅ 1-count-metrics-100-times

Time: ✅ 149.079µs (SLO: <220.000µs 📉 -32.2%) vs baseline: +0.2%

Memory: ✅ 35.566MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ 1-distribution-metric-1-times

Time: ✅ 2.429µs (SLO: <20.000µs 📉 -87.9%) vs baseline: +2.5%

Memory: ✅ 35.527MB (SLO: <38.000MB -6.5%) vs baseline: +4.2%


✅ 1-distribution-metrics-100-times

Time: ✅ 163.382µs (SLO: <230.000µs 📉 -29.0%) vs baseline: +0.3%

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.4%


✅ 1-gauge-metric-1-times

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

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.3%


✅ 1-gauge-metrics-100-times

Time: ✅ 136.599µs (SLO: <150.000µs -8.9%) vs baseline: +0.6%

Memory: ✅ 35.547MB (SLO: <38.000MB -6.5%) vs baseline: +4.3%


✅ 1-rate-metric-1-times

Time: ✅ 2.215µs (SLO: <20.000µs 📉 -88.9%) vs baseline: +1.1%

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ 1-rate-metrics-100-times

Time: ✅ 161.784µs (SLO: <250.000µs 📉 -35.3%) vs baseline: -1.1%

Memory: ✅ 35.566MB (SLO: <38.000MB -6.4%) vs baseline: +4.1%


✅ 100-count-metrics-100-times

Time: ✅ 15.152ms (SLO: <22.000ms 📉 -31.1%) vs baseline: -0.5%

Memory: ✅ 35.665MB (SLO: <38.000MB -6.1%) vs baseline: +4.6%


✅ 100-distribution-metrics-100-times

Time: ✅ 1.733ms (SLO: <2.550ms 📉 -32.0%) vs baseline: +1.0%

Memory: ✅ 35.547MB (SLO: <38.000MB -6.5%) vs baseline: +4.1%


✅ 100-gauge-metrics-100-times

Time: ✅ 1.397ms (SLO: <1.550ms -9.9%) vs baseline: -0.3%

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.2%


✅ 100-rate-metrics-100-times

Time: ✅ 1.694ms (SLO: <2.550ms 📉 -33.6%) vs baseline: +1.1%

Memory: ✅ 35.606MB (SLO: <38.000MB -6.3%) vs baseline: +4.5%


✅ flush-1-metric

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

Memory: ✅ 35.566MB (SLO: <38.000MB -6.4%) vs baseline: +4.5%


✅ flush-100-metrics

Time: ✅ 176.194µs (SLO: <250.000µs 📉 -29.5%) vs baseline: +1.2%

Memory: ✅ 35.586MB (SLO: <38.000MB -6.4%) vs baseline: +4.3%


✅ flush-1000-metrics

Time: ✅ 2.186ms (SLO: <2.500ms 📉 -12.6%) vs baseline: +0.5%

Memory: ✅ 36.412MB (SLO: <38.750MB -6.0%) vs baseline: +4.5%

ℹ️ Scenarios Missing SLO Configuration (46 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
  • iast_aspects-re_expand_aspect
  • iast_aspects-re_expand_noaspect
  • iast_aspects-re_findall_aspect
  • iast_aspects-re_findall_noaspect
  • iast_aspects-re_finditer_aspect
  • iast_aspects-re_finditer_noaspect
  • iast_aspects-re_fullmatch_aspect
  • iast_aspects-re_fullmatch_noaspect
  • iast_aspects-re_group_aspect
  • iast_aspects-re_group_noaspect
  • iast_aspects-re_groups_aspect
  • iast_aspects-re_groups_noaspect
  • iast_aspects-re_match_aspect
  • iast_aspects-re_match_noaspect
  • iast_aspects-re_search_aspect
  • iast_aspects-re_search_noaspect
  • iast_aspects-re_sub_aspect
  • iast_aspects-re_sub_noaspect
  • iast_aspects-re_subn_aspect
  • iast_aspects-re_subn_noaspect
  • sethttpmeta-obfuscation-disabled
  • startup-baseline
  • startup-baseline_django
  • startup-baseline_flask
  • startup-ddtrace_run
  • startup-ddtrace_run_appsec
  • startup-ddtrace_run_profiling
  • startup-ddtrace_run_runtime_metrics
  • startup-ddtrace_run_send_span
  • startup-ddtrace_run_telemetry_disabled
  • startup-ddtrace_run_telemetry_enabled
  • startup-import_ddtrace
  • startup-import_ddtrace_auto
  • startup-import_ddtrace_auto_django
  • startup-import_ddtrace_auto_flask
  • startup-import_ddtrace_django
  • startup-import_ddtrace_flask

@cit-pr-commenter-54b7da
Copy link

cit-pr-commenter-54b7da bot commented Feb 17, 2026

Codeowners resolved as

ddtrace/internal/_threads.cpp                                           @DataDog/apm-core-python
tests/internal/test_periodic.py                                         @DataDog/apm-core-python
tests/profiling/collector/test_sample_count.py                          @DataDog/profiling-python
tests/profiling/gunicorn_count_app.py                                   @DataDog/profiling-python
tests/profiling/test_gunicorn.py                                        @DataDog/profiling-python

@taegyunkim
Copy link
Contributor Author

@codex review

@taegyunkim taegyunkim changed the title fix(internal): native PeriodicThread avoids awake() after fork() fix(internal, profiling): native PeriodicThread avoids awake() after fork() Feb 17, 2026
@chatgpt-codex-connector
Copy link

Codex Review: Didn't find any major issues. Delightful!

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

@taegyunkim taegyunkim marked this pull request as ready for review February 17, 2026 23:26
Copy link

@chatgpt-codex-connector chatgpt-codex-connector bot left a comment

Choose a reason for hiding this comment

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

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: 4bc1d6e814

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

Copy link
Contributor

@KowalskiThomas KowalskiThomas left a comment

Choose a reason for hiding this comment

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

Great find! 👏

@taegyunkim taegyunkim changed the title fix(internal, profiling): native PeriodicThread avoids awake() after fork() perf(internal, profiling): native PeriodicThread avoids awake() after fork() Feb 18, 2026
@taegyunkim
Copy link
Contributor Author

Given that the problematic commit is not yet released and we're just uploading extra profiles, I'm changing the PR header to perf, dropping release note.

@taegyunkim taegyunkim added the Profiling Continous Profling label Feb 18, 2026
@taegyunkim taegyunkim added the changelog/no-changelog A changelog entry is not required for this PR. label Feb 18, 2026
Copy link
Collaborator

@emmettbutler emmettbutler left a comment

Choose a reason for hiding this comment

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

looks reasonable to me

Co-authored-by: Brett Langdon <brett.langdon@datadoghq.com>
taegyunkim added a commit that referenced this pull request Feb 18, 2026
@gh-worker-dd-mergequeue-cf854d gh-worker-dd-mergequeue-cf854d bot merged commit 295a47f into main Feb 18, 2026
1002 of 1013 checks passed
@gh-worker-dd-mergequeue-cf854d gh-worker-dd-mergequeue-cf854d bot deleted the taegyunkim/periodic-thread-fork branch February 18, 2026 23:53
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.

5 participants