Skip to content

Conversation

@dd-oleksii
Copy link

@dd-oleksii dd-oleksii commented Oct 31, 2025

Description

Integrate WIP datadog-ffe from libdatadog: DataDog/libdatadog#1289

Testing

Tested manually that native bindings work:

>>> from ddtrace.internal.native._native import ffe
>>> with open("/Users/oleksii.shmalko/dd/libdatadog/datadog-ffe/tests/data/flags-v1.json", 'rb') as f:
...     json = f.read()
... 
>>> config = ffe.Configuration(json)
>>> details = config.resolve_value("numeric_flag", ffe.FlagType.Float, {})
>>> details.variant
'pi'
>>> details.value
3.1415926

More testing will be done as part of FFE feature.

Risks

Additional Notes

Ready for review but will need to wait for DataDog/libdatadog#1289 before merging.

@dd-oleksii dd-oleksii requested a review from avara1986 October 31, 2025 02:41
@dd-oleksii dd-oleksii requested a review from a team as a code owner October 31, 2025 02:41
@dd-oleksii dd-oleksii requested a review from juanjux October 31, 2025 02:41
@github-actions
Copy link
Contributor

github-actions bot commented Oct 31, 2025

CODEOWNERS have been resolved as:

src/native/ffe.rs                                                       @DataDog/apm-core-python
tests/openfeature/config_helpers.py                                     @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-boolean-one-of-matches.json        @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-comparator-operator-flag.json      @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-disabled-flag.json                 @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-kill-switch-flag.json              @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-new-user-onboarding-flag.json      @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-no-allocations-flag.json           @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-null-operator-flag.json            @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-numeric-flag.json                  @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-numeric-one-of.json                @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-regex-flag.json                    @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-case-start-and-end-date-flag.json       @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-flag-that-does-not-exist.json           @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-json-config-flag.json                   @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-no-allocations-flag.json                @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-special-characters.json                 @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/fixtures/test-string-with-special-characters.json     @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/flags-v1.json                                         @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_client_api.py                                    @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_provider_fixtures.py                             @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_provider_status.py                               @DataDog/asm-python @DataDog/apm-core-python
ddtrace/internal/native/__init__.py                                     @DataDog/apm-core-python
ddtrace/internal/native/_native.pyi                                     @DataDog/apm-core-python
ddtrace/internal/openfeature/_config.py                                 @DataDog/apm-core-python
ddtrace/internal/openfeature/_native.py                                 @DataDog/apm-core-python
ddtrace/internal/openfeature/_provider.py                               @DataDog/apm-core-python
ddtrace/internal/openfeature/_remoteconfiguration.py                    @DataDog/apm-core-python
ddtrace/openfeature/__init__.py                                         @DataDog/asm-python @DataDog/apm-core-python
riotfile.py                                                             @DataDog/apm-python
src/native/Cargo.lock                                                   @DataDog/apm-core-python
src/native/Cargo.toml                                                   @DataDog/apm-core-python
src/native/lib.rs                                                       @DataDog/apm-core-python
tests/openfeature/test_provider.py                                      @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_provider_e2e.py                                  @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_provider_env_var.py                              @DataDog/asm-python @DataDog/apm-core-python
tests/openfeature/test_provider_exposure.py                             @DataDog/asm-python @DataDog/apm-core-python
.riot/requirements/104618a.txt                                          @DataDog/apm-python
.riot/requirements/1346280.txt                                          @DataDog/apm-python
.riot/requirements/183bf88.txt                                          @DataDog/apm-python
.riot/requirements/1d5d90b.txt                                          @DataDog/apm-python
.riot/requirements/1fd3342.txt                                          @DataDog/apm-python
.riot/requirements/68eb9ac.txt                                          @DataDog/apm-python
.riot/requirements/db50e43.txt                                          @DataDog/apm-python
ddtrace/internal/openfeature/_ffe_mock.py                               @DataDog/apm-core-python
src/native/ffande.rs                                                    @DataDog/apm-core-python
tests/internal/ffande/__init__.py                                       @DataDog/apm-core-python
tests/internal/ffande/test_ffande.py                                    @DataDog/apm-core-python

@dd-oleksii dd-oleksii added the changelog/no-changelog A changelog entry is not required for this PR. label Oct 31, 2025
@dd-oleksii dd-oleksii changed the title [ffe] integrate datadog-ffe feat(ffe): integrate datadog-ffe Oct 31, 2025
@github-actions
Copy link
Contributor

github-actions bot commented Oct 31, 2025

Bootstrap import analysis

Comparison of import times between this PR and base.

Summary

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

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

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

Import time breakdown

The following import paths have grown:

ddtrace.auto 0.064 ms (0.03%)
ddtrace 0.064 ms (0.03%)
ddtrace._logger 0.064 ms (0.03%)
ddtrace.internal.telemetry 0.064 ms (0.03%)
ddtrace.settings._agent 0.064 ms (0.03%)
ddtrace.settings._core 0.064 ms (0.03%)
ddtrace.internal.native 0.064 ms (0.03%)
ddtrace.internal.native._native 0.064 ms (0.03%)

The following import paths have shrunk:

ddtrace.auto 1.981 ms (0.83%)
ddtrace.bootstrap.sitecustomize 1.301 ms (0.54%)
ddtrace.bootstrap.preload 1.301 ms (0.54%)
ddtrace.internal.remoteconfig.client 0.636 ms (0.27%)
ddtrace 0.679 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%)

@pr-commenter
Copy link

pr-commenter bot commented Oct 31, 2025

Performance SLOs

Comparing candidate datadog-ffe (c4db57e) with baseline main (06e349b)

📈 Performance Regressions (1 suite)
📈 telemetryaddmetric - 30/30

✅ 1-count-metric-1-times

Time: ✅ 3.319µs (SLO: <20.000µs 📉 -83.4%) vs baseline: 📈 +13.8%

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


✅ 1-count-metrics-100-times

Time: ✅ 208.584µs (SLO: <220.000µs -5.2%) vs baseline: +4.8%

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


✅ 1-distribution-metric-1-times

Time: ✅ 3.430µs (SLO: <20.000µs 📉 -82.9%) vs baseline: +6.3%

Memory: ✅ 31.850MB (SLO: <34.000MB -6.3%) vs baseline: +4.7%


✅ 1-distribution-metrics-100-times

Time: ✅ 218.380µs (SLO: <220.000µs 🟡 -0.7%) vs baseline: +3.0%

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


✅ 1-gauge-metric-1-times

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

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


✅ 1-gauge-metrics-100-times

Time: ✅ 138.337µs (SLO: <150.000µs -7.8%) vs baseline: +1.9%

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


✅ 1-rate-metric-1-times

Time: ✅ 3.212µs (SLO: <20.000µs 📉 -83.9%) vs baseline: +4.9%

Memory: ✅ 31.890MB (SLO: <34.000MB -6.2%) vs baseline: +4.9%


✅ 1-rate-metrics-100-times

Time: ✅ 223.080µs (SLO: <250.000µs 📉 -10.8%) vs baseline: +5.6%

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


✅ 100-count-metrics-100-times

Time: ✅ 21.494ms (SLO: <22.000ms -2.3%) vs baseline: +8.2%

Memory: ✅ 31.870MB (SLO: <34.000MB -6.3%) vs baseline: +4.8%


✅ 100-distribution-metrics-100-times

Time: ✅ 2.285ms (SLO: <2.300ms 🟡 -0.6%) vs baseline: +2.6%

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


✅ 100-gauge-metrics-100-times

Time: ✅ 1.444ms (SLO: <1.550ms -6.8%) vs baseline: +3.0%

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


✅ 100-rate-metrics-100-times

Time: ✅ 2.273ms (SLO: <2.550ms 📉 -10.9%) vs baseline: +4.6%

Memory: ✅ 31.968MB (SLO: <34.000MB -6.0%) vs baseline: +5.0%


✅ flush-1-metric

Time: ✅ 4.864µs (SLO: <20.000µs 📉 -75.7%) vs baseline: +5.0%

Memory: ✅ 31.870MB (SLO: <34.000MB -6.3%) vs baseline: +4.7%


✅ flush-100-metrics

Time: ✅ 174.432µs (SLO: <250.000µs 📉 -30.2%) vs baseline: -0.1%

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


✅ flush-1000-metrics

Time: ✅ 2.120ms (SLO: <2.500ms 📉 -15.2%) vs baseline: ~same

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

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

✅ appsec

Time: ✅ 20.520ms (SLO: <22.300ms -8.0%) vs baseline: +0.2%

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


✅ exception-replay-enabled

Time: ✅ 1.343ms (SLO: <1.450ms -7.4%) vs baseline: +0.3%

Memory: ✅ 64.398MB (SLO: <67.000MB -3.9%) vs baseline: +5.3%


✅ iast

Time: ✅ 20.453ms (SLO: <22.250ms -8.1%) vs baseline: -0.3%

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


✅ profiler

Time: ✅ 15.507ms (SLO: <16.550ms -6.3%) vs baseline: -0.8%

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


✅ resource-renaming

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

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


✅ span-code-origin

Time: ✅ 25.384ms (SLO: <28.200ms -10.0%) vs baseline: +0.1%

Memory: ✅ 67.275MB (SLO: <69.500MB -3.2%) vs baseline: +5.2%


✅ tracer

Time: ✅ 20.450ms (SLO: <21.750ms -6.0%) vs baseline: -0.3%

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


✅ tracer-and-profiler

Time: ✅ 22.629ms (SLO: <23.500ms -3.7%) vs baseline: -0.4%

Memory: ✅ 67.712MB (SLO: <68.000MB 🟡 -0.4%) vs baseline: +5.2%


✅ tracer-dont-create-db-spans

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

Memory: ✅ 66.306MB (SLO: <67.000MB 🟡 -1.0%) vs baseline: +5.3%


✅ tracer-minimal

Time: ✅ 16.552ms (SLO: <17.500ms -5.4%) vs baseline: -0.4%

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


✅ tracer-native

Time: ✅ 20.435ms (SLO: <21.750ms -6.0%) vs baseline: +0.1%

Memory: ✅ 71.623MB (SLO: <72.500MB 🟡 -1.2%) vs baseline: +5.1%


✅ tracer-no-caches

Time: ✅ 18.444ms (SLO: <19.650ms -6.1%) vs baseline: -0.1%

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


✅ tracer-no-databases

Time: ✅ 18.815ms (SLO: <20.100ms -6.4%) vs baseline: +0.4%

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


✅ tracer-no-middleware

Time: ✅ 20.146ms (SLO: <21.500ms -6.3%) vs baseline: -0.2%

Memory: ✅ 66.313MB (SLO: <67.000MB 🟡 -1.0%) vs baseline: +5.2%


✅ tracer-no-templates

Time: ✅ 20.218ms (SLO: <22.000ms -8.1%) vs baseline: -0.3%

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


🟡 errortrackingdjangosimple - 6/6

✅ errortracking-enabled-all

Time: ✅ 18.059ms (SLO: <19.850ms -9.0%) vs baseline: ~same

Memory: ✅ 66.316MB (SLO: <66.500MB 🟡 -0.3%) vs baseline: +5.5%


✅ errortracking-enabled-user

Time: ✅ 18.109ms (SLO: <19.400ms -6.7%) vs baseline: +0.3%

Memory: ✅ 66.257MB (SLO: <66.500MB 🟡 -0.4%) vs baseline: +5.5%


✅ tracer-enabled

Time: ✅ 18.063ms (SLO: <19.450ms -7.1%) vs baseline: ~same

Memory: ✅ 66.139MB (SLO: <66.500MB 🟡 -0.5%) vs baseline: +5.4%


🟡 errortrackingflasksqli - 6/6

✅ errortracking-enabled-all

Time: ✅ 2.084ms (SLO: <2.300ms -9.4%) vs baseline: +0.6%

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


✅ errortracking-enabled-user

Time: ✅ 2.071ms (SLO: <2.250ms -8.0%) vs baseline: ~same

Memory: ✅ 52.691MB (SLO: <53.500MB 🟡 -1.5%) vs baseline: +5.4%


✅ tracer-enabled

Time: ✅ 2.081ms (SLO: <2.300ms -9.5%) vs baseline: +0.8%

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


🟡 flasksimple - 18/18

✅ appsec-get

Time: ✅ 4.594ms (SLO: <4.750ms -3.3%) vs baseline: -0.2%

Memory: ✅ 62.493MB (SLO: <65.000MB -3.9%) vs baseline: +5.3%


✅ appsec-post

Time: ✅ 6.625ms (SLO: <6.750ms 🟡 -1.8%) vs baseline: -0.2%

Memory: ✅ 62.474MB (SLO: <65.000MB -3.9%) vs baseline: +5.2%


✅ appsec-telemetry

Time: ✅ 4.592ms (SLO: <4.750ms -3.3%) vs baseline: -0.2%

Memory: ✅ 62.475MB (SLO: <65.000MB -3.9%) vs baseline: +5.1%


✅ debugger

Time: ✅ 1.857ms (SLO: <2.000ms -7.2%) vs baseline: -0.5%

Memory: ✅ 45.468MB (SLO: <47.000MB -3.3%) vs baseline: +5.5%


✅ iast-get

Time: ✅ 1.856ms (SLO: <2.000ms -7.2%) vs baseline: ~same

Memory: ✅ 42.080MB (SLO: <49.000MB 📉 -14.1%) vs baseline: +4.9%


✅ profiler

Time: ✅ 1.917ms (SLO: <2.100ms -8.7%) vs baseline: +0.3%

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


✅ resource-renaming

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

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


✅ tracer

Time: ✅ 3.354ms (SLO: <3.650ms -8.1%) vs baseline: ~same

Memory: ✅ 52.674MB (SLO: <53.500MB 🟡 -1.5%) vs baseline: +5.4%


✅ tracer-native

Time: ✅ 3.356ms (SLO: <3.650ms -8.1%) vs baseline: +0.2%

Memory: ✅ 58.334MB (SLO: <60.000MB -2.8%) vs baseline: +5.3%


🟡 flasksqli - 6/6

✅ appsec-enabled

Time: ✅ 3.967ms (SLO: <4.200ms -5.5%) vs baseline: -0.4%

Memory: ✅ 62.482MB (SLO: <66.000MB -5.3%) vs baseline: +5.3%


✅ iast-enabled

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

Memory: ✅ 59.317MB (SLO: <60.000MB 🟡 -1.1%) vs baseline: +5.2%


✅ tracer-enabled

Time: ✅ 2.061ms (SLO: <2.250ms -8.4%) vs baseline: -0.1%

Memory: ✅ 52.691MB (SLO: <54.500MB -3.3%) vs baseline: +5.2%

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

⚠️ context_with_data_listeners

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +5.2%


✅ context_with_data_no_listeners

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

Memory: ✅ 31.457MB (SLO: <33.500MB -6.1%) vs baseline: +4.7%


✅ get_item_exists

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

Memory: ✅ 31.575MB (SLO: <33.500MB -5.7%) vs baseline: +5.2%


✅ get_item_missing

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

Memory: ✅ 31.497MB (SLO: <33.500MB -6.0%) vs baseline: +5.0%


✅ set_item

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

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

✅ All Tests Passing (17 suites)
httppropagationextract - 60/60

✅ all_styles_all_headers

Time: ✅ 83.435µs (SLO: <100.000µs 📉 -16.6%) vs baseline: +2.2%

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


✅ b3_headers

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

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


✅ b3_single_headers

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

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


✅ datadog_tracecontext_tracestate_not_propagated_on_trace_id_no_match

Time: ✅ 63.687µs (SLO: <80.000µs 📉 -20.4%) vs baseline: -0.9%

Memory: ✅ 31.909MB (SLO: <33.500MB -4.7%) vs baseline: +4.9%


✅ datadog_tracecontext_tracestate_propagated_on_trace_id_match

Time: ✅ 66.042µs (SLO: <80.000µs 📉 -17.4%) vs baseline: -0.2%

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


✅ empty_headers

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

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


✅ full_t_id_datadog_headers

Time: ✅ 22.778µs (SLO: <30.000µs 📉 -24.1%) vs baseline: -1.0%

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


✅ invalid_priority_header

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

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


✅ invalid_span_id_header

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

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


✅ invalid_tags_header

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

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


✅ invalid_trace_id_header

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

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


✅ large_header_no_matches

Time: ✅ 27.594µs (SLO: <30.000µs -8.0%) vs baseline: +0.1%

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


✅ large_valid_headers_all

Time: ✅ 28.901µs (SLO: <40.000µs 📉 -27.7%) vs baseline: +0.8%

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


✅ medium_header_no_matches

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

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


✅ medium_valid_headers_all

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

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


✅ none_propagation_style

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

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


✅ tracecontext_headers

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

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


✅ valid_headers_all

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

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


✅ valid_headers_basic

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

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


✅ wsgi_empty_headers

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

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


✅ wsgi_invalid_priority_header

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

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


✅ wsgi_invalid_span_id_header

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

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


✅ wsgi_invalid_tags_header

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

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


✅ wsgi_invalid_trace_id_header

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

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


✅ wsgi_large_header_no_matches

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

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


✅ wsgi_large_valid_headers_all

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

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


✅ wsgi_medium_header_no_matches

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

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


✅ wsgi_medium_valid_headers_all

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

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


✅ wsgi_valid_headers_all

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

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


✅ wsgi_valid_headers_basic

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

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


httppropagationinject - 16/16

✅ ids_only

Time: ✅ 20.759µs (SLO: <30.000µs 📉 -30.8%) vs baseline: -0.8%

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


✅ with_all

Time: ✅ 28.969µs (SLO: <40.000µs 📉 -27.6%) vs baseline: +2.3%

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


✅ with_dd_origin

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

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


✅ with_priority_and_origin

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

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


✅ with_sampling_priority

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

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


✅ with_tags

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

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


✅ with_tags_invalid

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

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


✅ with_tags_max_size

Time: ✅ 28.098µs (SLO: <40.000µs 📉 -29.8%) vs baseline: +4.7%

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


iast_aspects - 40/40

✅ re_expand_aspect

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

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


✅ re_expand_noaspect

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

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


✅ re_findall_aspect

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

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


✅ re_findall_noaspect

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

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


✅ re_finditer_aspect

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

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


✅ re_finditer_noaspect

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

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


✅ re_fullmatch_aspect

Time: ✅ 2.656µs (SLO: <10.000µs 📉 -73.4%) vs baseline: -3.0%

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


✅ re_fullmatch_noaspect

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

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


✅ re_group_aspect

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

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


✅ re_group_noaspect

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

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


✅ re_groups_aspect

Time: ✅ 3.290µs (SLO: <10.000µs 📉 -67.1%) vs baseline: +7.1%

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


✅ re_groups_noaspect

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

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


✅ re_match_aspect

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

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


✅ re_match_noaspect

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

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


✅ re_search_aspect

Time: ✅ 2.669µs (SLO: <10.000µs 📉 -73.3%) vs baseline: +4.1%

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


✅ re_search_noaspect

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

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


✅ re_sub_aspect

Time: ✅ 3.570µs (SLO: <10.000µs 📉 -64.3%) vs baseline: +4.9%

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


✅ re_sub_noaspect

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

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


✅ re_subn_aspect

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

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


✅ re_subn_noaspect

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

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


iastaspects - 118/118

✅ add_aspect

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

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


✅ add_inplace_aspect

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

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


✅ add_inplace_noaspect

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

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


✅ add_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.4%


✅ bytearray_aspect

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

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


✅ bytearray_extend_aspect

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

Memory: ✅ 38.063MB (SLO: <39.000MB -2.4%) vs baseline: +5.5%


✅ bytearray_extend_noaspect

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

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


✅ bytearray_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ bytes_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ bytes_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ bytesio_aspect

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

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


✅ bytesio_noaspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.2%


✅ capitalize_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ capitalize_noaspect

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

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


✅ casefold_aspect

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

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


✅ casefold_noaspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ decode_aspect

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

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


✅ decode_noaspect

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

Memory: ✅ 38.024MB (SLO: <39.000MB -2.5%) vs baseline: +5.1%


✅ encode_aspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ encode_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.3%


✅ format_aspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ format_map_aspect

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

Memory: ✅ 37.906MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ format_map_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ format_noaspect

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

Memory: ✅ 38.044MB (SLO: <39.000MB -2.5%) vs baseline: +5.4%


✅ index_aspect

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

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


✅ index_noaspect

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

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


✅ join_aspect

Time: ✅ 1.316µs (SLO: <10.000µs 📉 -86.8%) vs baseline: -3.4%

Memory: ✅ 38.024MB (SLO: <39.000MB -2.5%) vs baseline: +5.5%


✅ join_noaspect

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

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


✅ ljust_aspect

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

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


✅ ljust_noaspect

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

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +5.1%


✅ lower_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ lower_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.3%


✅ lstrip_aspect

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

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


✅ lstrip_noaspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.5%


✅ modulo_aspect

Time: ✅ 1.000µs (SLO: <10.000µs 📉 -90.0%) vs baseline: -4.1%

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +5.0%


✅ modulo_aspect_for_bytearray_bytearray

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

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


✅ modulo_aspect_for_bytes

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

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


✅ modulo_aspect_for_bytes_bytearray

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ modulo_noaspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.2%


✅ replace_aspect

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

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


✅ replace_noaspect

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

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


✅ repr_aspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.1%


✅ repr_noaspect

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

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


✅ rstrip_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.3%


✅ rstrip_noaspect

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

Memory: ✅ 38.044MB (SLO: <39.000MB -2.5%) vs baseline: +5.3%


✅ slice_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.3%


✅ slice_noaspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.3%


✅ stringio_aspect

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

Memory: ✅ 38.024MB (SLO: <39.000MB -2.5%) vs baseline: +5.3%


✅ stringio_noaspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.2%


✅ strip_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


✅ strip_noaspect

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

Memory: ✅ 38.044MB (SLO: <39.000MB -2.5%) vs baseline: +5.6%


✅ swapcase_aspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.3%


✅ swapcase_noaspect

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

Memory: ✅ 38.024MB (SLO: <39.000MB -2.5%) vs baseline: +5.3%


✅ title_aspect

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

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


✅ title_noaspect

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

Memory: ✅ 38.044MB (SLO: <39.000MB -2.5%) vs baseline: +5.5%


✅ translate_aspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.2%


✅ translate_noaspect

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

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +5.1%


✅ upper_aspect

Time: ✅ 2.266µs (SLO: <10.000µs 📉 -77.3%) vs baseline: +2.5%

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


✅ upper_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.2%


iastaspectsospath - 24/24

✅ ospathbasename_aspect

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

Memory: ✅ 37.906MB (SLO: <39.000MB -2.8%) vs baseline: +6.0%


✅ ospathbasename_noaspect

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

Memory: ✅ 37.867MB (SLO: <39.000MB -2.9%) vs baseline: +5.9%


✅ ospathjoin_aspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.7%


✅ ospathjoin_noaspect

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

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


✅ ospathnormcase_aspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +6.1%


✅ ospathnormcase_noaspect

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

Memory: ✅ 37.847MB (SLO: <39.000MB -3.0%) vs baseline: +5.6%


✅ ospathsplit_aspect

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

Memory: ✅ 37.926MB (SLO: <39.000MB -2.8%) vs baseline: +5.2%


✅ ospathsplit_noaspect

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

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +5.7%


✅ ospathsplitdrive_aspect

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

Memory: ✅ 37.985MB (SLO: <39.000MB -2.6%) vs baseline: +5.6%


✅ ospathsplitdrive_noaspect

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

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


✅ ospathsplitext_aspect

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

Memory: ✅ 37.886MB (SLO: <39.000MB -2.9%) vs baseline: +5.9%


✅ ospathsplitext_noaspect

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

Memory: ✅ 37.965MB (SLO: <39.000MB -2.7%) vs baseline: +5.8%


iastaspectssplit - 12/12

✅ rsplit_aspect

Time: ✅ 1.427µs (SLO: <10.000µs 📉 -85.7%) vs baseline: -2.5%

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


✅ rsplit_noaspect

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

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


✅ split_aspect

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

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


✅ split_noaspect

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

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


✅ splitlines_aspect

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

Memory: ✅ 37.788MB (SLO: <39.000MB -3.1%) vs baseline: +5.8%


✅ splitlines_noaspect

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

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


iastpropagation - 2/2

✅ no-propagation

Time: ✅ 48.399µs (SLO: <60.000µs 📉 -19.3%) vs baseline: -0.6%

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


otelsdkspan - 24/24

✅ add-event

Time: ✅ 40.439ms (SLO: <42.000ms -3.7%) vs baseline: ~same

Memory: ✅ 34.308MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.8%


✅ add-link

Time: ✅ 36.309ms (SLO: <38.550ms -5.8%) vs baseline: +0.4%

Memory: ✅ 34.426MB (SLO: <39.000MB 📉 -11.7%) vs baseline: +5.2%


✅ add-metrics

Time: ✅ 217.467ms (SLO: <232.000ms -6.3%) vs baseline: -0.3%

Memory: ✅ 34.406MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +5.2%


✅ add-tags

Time: ✅ 212.553ms (SLO: <221.600ms -4.1%) vs baseline: -0.2%

Memory: ✅ 34.367MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.1%


✅ get-context

Time: ✅ 28.994ms (SLO: <31.300ms -7.4%) vs baseline: -0.1%

Memory: ✅ 34.426MB (SLO: <39.000MB 📉 -11.7%) vs baseline: +5.1%


✅ is-recording

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

Memory: ✅ 34.387MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +4.9%


✅ record-exception

Time: ✅ 63.046ms (SLO: <65.850ms -4.3%) vs baseline: +0.1%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.0%


✅ set-status

Time: ✅ 32.022ms (SLO: <34.150ms -6.2%) vs baseline: -0.3%

Memory: ✅ 34.367MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +5.0%


✅ start

Time: ✅ 28.826ms (SLO: <30.150ms -4.4%) vs baseline: +0.5%

Memory: ✅ 34.347MB (SLO: <39.000MB 📉 -11.9%) vs baseline: +4.9%


✅ start-finish

Time: ✅ 33.927ms (SLO: <35.350ms -4.0%) vs baseline: ~same

Memory: ✅ 34.328MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +5.0%


✅ start-finish-telemetry

Time: ✅ 33.910ms (SLO: <35.450ms -4.3%) vs baseline: -0.3%

Memory: ✅ 34.387MB (SLO: <39.000MB 📉 -11.8%) vs baseline: +5.0%


✅ update-name

Time: ✅ 31.099ms (SLO: <33.400ms -6.9%) vs baseline: ~same

Memory: ✅ 34.308MB (SLO: <39.000MB 📉 -12.0%) vs baseline: +4.8%


otelspan - 22/22

✅ add-event

Time: ✅ 40.294ms (SLO: <47.150ms 📉 -14.5%) vs baseline: ~same

Memory: ✅ 43.628MB (SLO: <47.000MB -7.2%) vs baseline: +4.9%


✅ add-metrics

Time: ✅ 315.151ms (SLO: <344.800ms -8.6%) vs baseline: -0.4%

Memory: ✅ 652.313MB (SLO: <675.000MB -3.4%) vs baseline: +4.9%


✅ add-tags

Time: ✅ 288.129ms (SLO: <314.000ms -8.2%) vs baseline: +0.5%

Memory: ✅ 654.123MB (SLO: <675.000MB -3.1%) vs baseline: +4.9%


✅ get-context

Time: ✅ 82.159ms (SLO: <92.350ms 📉 -11.0%) vs baseline: +2.6%

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


✅ is-recording

Time: ✅ 38.874ms (SLO: <44.500ms 📉 -12.6%) vs baseline: +2.2%

Memory: ✅ 42.973MB (SLO: <47.500MB -9.5%) vs baseline: +5.1%


✅ record-exception

Time: ✅ 58.182ms (SLO: <67.650ms 📉 -14.0%) vs baseline: -0.2%

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


✅ set-status

Time: ✅ 44.129ms (SLO: <50.400ms 📉 -12.4%) vs baseline: +0.7%

Memory: ✅ 42.981MB (SLO: <47.000MB -8.6%) vs baseline: +4.9%


✅ start

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

Memory: ✅ 43.021MB (SLO: <47.000MB -8.5%) vs baseline: +5.1%


✅ start-finish

Time: ✅ 81.719ms (SLO: <88.000ms -7.1%) vs baseline: -0.2%

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


✅ start-finish-telemetry

Time: ✅ 83.049ms (SLO: <89.000ms -6.7%) vs baseline: -0.2%

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


✅ update-name

Time: ✅ 38.994ms (SLO: <45.150ms 📉 -13.6%) vs baseline: +0.3%

Memory: ✅ 43.344MB (SLO: <47.000MB -7.8%) vs baseline: +5.0%


packagespackageforrootmodulemapping - 4/4

✅ cache_off

Time: ✅ 339.982ms (SLO: <354.300ms -4.0%) vs baseline: -0.7%

Memory: ✅ 37.710MB (SLO: <40.000MB -5.7%) vs baseline: +5.1%


✅ cache_on

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

Memory: ✅ 36.820MB (SLO: <39.000MB -5.6%) vs baseline: +5.1%


packagesupdateimporteddependencies - 24/24

✅ import_many

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

Memory: ✅ 37.036MB (SLO: <38.500MB -3.8%) vs baseline: +5.4%


✅ import_many_cached

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

Memory: ✅ 36.927MB (SLO: <38.500MB -4.1%) vs baseline: +5.4%


✅ import_many_stdlib

Time: ✅ 1.624ms (SLO: <1.750ms -7.2%) vs baseline: +0.5%

Memory: ✅ 37.140MB (SLO: <38.500MB -3.5%) vs baseline: +5.6%


✅ import_many_stdlib_cached

Time: ✅ 0.976ms (SLO: <1.100ms 📉 -11.3%) vs baseline: -0.3%

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


✅ import_many_unknown

Time: ✅ 830.668µs (SLO: <890.000µs -6.7%) vs baseline: +0.4%

Memory: ✅ 37.238MB (SLO: <38.500MB -3.3%) vs baseline: +5.5%


✅ import_many_unknown_cached

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

Memory: ✅ 37.020MB (SLO: <38.500MB -3.8%) vs baseline: +5.5%


✅ import_one

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

Memory: ✅ 36.988MB (SLO: <39.000MB -5.2%) vs baseline: +5.1%


✅ import_one_cache

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

Memory: ✅ 37.147MB (SLO: <38.500MB -3.5%) vs baseline: +6.1%


✅ import_one_stdlib

Time: ✅ 18.828µs (SLO: <20.000µs -5.9%) vs baseline: +0.9%

Memory: ✅ 37.160MB (SLO: <38.500MB -3.5%) vs baseline: +5.9%


✅ import_one_stdlib_cache

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

Memory: ✅ 36.871MB (SLO: <38.500MB -4.2%) vs baseline: +5.0%


✅ import_one_unknown

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

Memory: ✅ 37.001MB (SLO: <38.500MB -3.9%) vs baseline: +5.5%


✅ import_one_unknown_cache

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

Memory: ✅ 36.894MB (SLO: <38.500MB -4.2%) vs baseline: +5.1%


ratelimiter - 12/12

✅ defaults

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +5.2%


✅ high_rate_limit

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

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


✅ long_window

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

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


✅ low_rate_limit

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

Memory: ✅ 31.536MB (SLO: <34.000MB -7.2%) vs baseline: +5.1%


✅ no_rate_limit

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

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


✅ short_window

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

Memory: ✅ 31.516MB (SLO: <34.000MB -7.3%) vs baseline: +5.1%


recursivecomputation - 8/8

✅ deep

Time: ✅ 308.439ms (SLO: <320.950ms -3.9%) vs baseline: ~same

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


✅ deep-profiled

Time: ✅ 328.611ms (SLO: <359.150ms -8.5%) vs baseline: +0.4%

Memory: ✅ 37.367MB (SLO: <39.000MB -4.2%) vs baseline: +5.5%


✅ medium

Time: ✅ 7.037ms (SLO: <7.400ms -4.9%) vs baseline: +0.4%

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


✅ shallow

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

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


samplingrules - 8/8

✅ average_match

Time: ✅ 136.968µs (SLO: <290.000µs 📉 -52.8%) vs baseline: -0.6%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.2%


✅ high_match

Time: ✅ 172.793µs (SLO: <480.000µs 📉 -64.0%) vs baseline: -0.7%

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


✅ low_match

Time: ✅ 99.257µs (SLO: <120.000µs 📉 -17.3%) vs baseline: +1.0%

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


✅ very_low_match

Time: ✅ 2.690ms (SLO: <8.500ms 📉 -68.4%) vs baseline: +0.9%

Memory: ✅ 68.085MB (SLO: <75.000MB -9.2%) vs baseline: +5.0%


sethttpmeta - 32/32

✅ all-disabled

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

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


✅ all-enabled

Time: ✅ 39.762µs (SLO: <50.000µs 📉 -20.5%) vs baseline: -1.0%

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


✅ collectipvariant_exists

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

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


✅ no-collectipvariant

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

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


✅ no-useragentvariant

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

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


✅ obfuscation-no-query

Time: ✅ 40.466µs (SLO: <50.000µs 📉 -19.1%) vs baseline: -0.8%

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


✅ obfuscation-regular-case-explicit-query

Time: ✅ 75.575µs (SLO: <90.000µs 📉 -16.0%) vs baseline: -0.6%

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


✅ obfuscation-regular-case-implicit-query

Time: ✅ 77.490µs (SLO: <90.000µs 📉 -13.9%) vs baseline: +1.3%

Memory: ✅ 32.775MB (SLO: <34.000MB -3.6%) vs baseline: +5.4%


✅ obfuscation-send-querystring-disabled

Time: ✅ 154.164µs (SLO: <170.000µs -9.3%) vs baseline: -0.1%

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


✅ obfuscation-worst-case-explicit-query

Time: ✅ 148.233µs (SLO: <160.000µs -7.4%) vs baseline: -0.1%

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


✅ obfuscation-worst-case-implicit-query

Time: ✅ 154.394µs (SLO: <170.000µs -9.2%) vs baseline: -0.3%

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


✅ useragentvariant_exists_1

Time: ✅ 39.179µs (SLO: <50.000µs 📉 -21.6%) vs baseline: -1.1%

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


✅ useragentvariant_exists_2

Time: ✅ 40.315µs (SLO: <50.000µs 📉 -19.4%) vs baseline: -1.0%

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


✅ useragentvariant_exists_3

Time: ✅ 39.771µs (SLO: <50.000µs 📉 -20.5%) vs baseline: -1.0%

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


✅ useragentvariant_not_exists_1

Time: ✅ 39.175µs (SLO: <50.000µs 📉 -21.6%) vs baseline: -1.3%

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


✅ useragentvariant_not_exists_2

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

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


span - 26/26

✅ add-event

Time: ✅ 20.430ms (SLO: <22.500ms -9.2%) vs baseline: +2.4%

Memory: ✅ 48.557MB (SLO: <53.000MB -8.4%) vs baseline: +5.1%


✅ add-metrics

Time: ✅ 89.349ms (SLO: <93.500ms -4.4%) vs baseline: -1.6%

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


✅ add-tags

Time: ✅ 147.180ms (SLO: <155.000ms -5.0%) vs baseline: +0.8%

Memory: ✅ 735.891MB (SLO: <962.500MB 📉 -23.5%) vs baseline: +5.0%


✅ get-context

Time: ✅ 18.793ms (SLO: <20.500ms -8.3%) vs baseline: +3.2%

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


✅ is-recording

Time: ✅ 18.472ms (SLO: <20.500ms -9.9%) vs baseline: +0.3%

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


✅ record-exception

Time: ✅ 37.717ms (SLO: <40.000ms -5.7%) vs baseline: +0.9%

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


✅ set-status

Time: ✅ 20.447ms (SLO: <22.000ms -7.1%) vs baseline: +1.8%

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


✅ start

Time: ✅ 18.612ms (SLO: <20.500ms -9.2%) vs baseline: +2.7%

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


✅ start-finish

Time: ✅ 50.624ms (SLO: <52.500ms -3.6%) vs baseline: +0.6%

Memory: ✅ 31.929MB (SLO: <34.000MB -6.1%) vs baseline: +5.1%


✅ start-finish-telemetry

Time: ✅ 52.661ms (SLO: <54.500ms -3.4%) vs baseline: +1.4%

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


✅ start-finish-traceid128

Time: ✅ 54.586ms (SLO: <57.000ms -4.2%) vs baseline: +2.2%

Memory: ✅ 31.988MB (SLO: <34.000MB -5.9%) vs baseline: +5.2%


✅ start-traceid128

Time: ✅ 19.173ms (SLO: <22.500ms 📉 -14.8%) vs baseline: +3.1%

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


✅ update-name

Time: ✅ 18.962ms (SLO: <22.000ms 📉 -13.8%) vs baseline: +2.1%

Memory: ✅ 47.997MB (SLO: <53.000MB -9.4%) vs baseline: +5.2%


tracer - 6/6

✅ large

Time: ✅ 28.942ms (SLO: <32.950ms 📉 -12.2%) vs baseline: -0.3%

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


✅ medium

Time: ✅ 2.879ms (SLO: <3.200ms 📉 -10.0%) vs baseline: -0.2%

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


✅ small

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

Memory: ✅ 31.634MB (SLO: <34.000MB -7.0%) vs baseline: +5.3%

ℹ️ Scenarios Missing SLO Configuration (9 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

@avara1986 avara1986 requested a review from a team as a code owner October 31, 2025 11:29
@avara1986
Copy link
Member

Tests fixed, libdatadog commit be5b5b22039141078d5e125824e338751f2d54a3 (branch avara1986/ffe-pyo3-methods)

@avara1986 avara1986 requested a review from a team as a code owner November 3, 2025 14:51
@avara1986 avara1986 requested a review from a team as a code owner November 3, 2025 17:52
@emmettbutler emmettbutler removed the changelog/no-changelog A changelog entry is not required for this PR. label Nov 3, 2025
@avara1986 avara1986 added the changelog/no-changelog A changelog entry is not required for this PR. label Nov 3, 2025
datadog-ddsketch = { git = "https://github.com/DataDog/libdatadog", rev = "v22.1.0" }
datadog-library-config = { git = "https://github.com/DataDog/libdatadog", rev = "v22.1.0" }
datadog-log = { git = "https://github.com/DataDog/libdatadog", rev = "v22.1.0" }
datadog-ffe = { git = "https://github.com/DataDog/libdatadog", rev = "36fe6be7f9a10f6cb44fc4f72ee33185c2a0cad1", features = ["pyo3"] }
Copy link
Member

Choose a reason for hiding this comment

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

We need to update the datadog-ffe module with the next libdatadog version

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

changelog/no-changelog A changelog entry is not required for this PR.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants