Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve Context API null handling and Javadoc #8129

Merged
merged 1 commit into from
Dec 30, 2024

Conversation

PerfectSlayer
Copy link
Contributor

@PerfectSlayer PerfectSlayer commented Dec 23, 2024

What Does This Do

This PR is a follow up of #8117:

  • Improve Javadoc about usage and thread safety
  • Improve null handling and document parameters and results
  • Improve tests to cover all context implementations

Motivation

The goal is to make the most explicit possible the new API and document how it is supposed to behave with unexpected cases.

Additional Notes

Contributor Checklist

Jira ticket: LANGPLAT-39

@pr-commenter
Copy link

pr-commenter bot commented Dec 23, 2024

Benchmarks

Startup

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master bbujon/context-api
git_commit_date 1735554168 1735561248
git_commit_sha 7d4150e c4da3f7
release_version 1.45.0-SNAPSHOT~7d4150eb06 1.45.0-SNAPSHOT~c4da3f7ab2
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1735563686 1735563686
ci_job_id 750838768 750838768
ci_pipeline_id 51900574 51900574
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
module Agent Agent
parent None None
variant iast iast

Summary

Found 1 performance improvements and 0 performance regressions! Performance is the same for 58 metrics, 4 unstable metrics.

scenario Δ mean execution_time candidate mean execution_time baseline mean execution_time
scenario:startup:petclinic:profiling:Remote Config better
[-44.261µs; -19.972µs] or [-6.578%; -2.968%]
640.709µs 672.826µs
Startup time reports for petclinic
gantt
    title petclinic - global startup overhead: candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.057 s) : 0, 1057406
Total [baseline] (10.442 s) : 0, 10442304
Agent [candidate] (1.052 s) : 0, 1051999
Total [candidate] (10.408 s) : 0, 10408097
section appsec
Agent [baseline] (1.185 s) : 0, 1185432
Total [baseline] (10.714 s) : 0, 10713694
Agent [candidate] (1.189 s) : 0, 1188612
Total [candidate] (10.705 s) : 0, 10704510
section iast
Agent [baseline] (1.179 s) : 0, 1179011
Total [baseline] (10.985 s) : 0, 10985429
Agent [candidate] (1.177 s) : 0, 1177001
Total [candidate] (10.903 s) : 0, 10902544
section profiling
Agent [baseline] (1.276 s) : 0, 1275885
Total [baseline] (10.809 s) : 0, 10809213
Agent [candidate] (1.275 s) : 0, 1274732
Total [candidate] (10.747 s) : 0, 10746717
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.057 s -
Agent appsec 1.185 s 128.026 ms (12.1%)
Agent iast 1.179 s 121.605 ms (11.5%)
Agent profiling 1.276 s 218.48 ms (20.7%)
Total tracing 10.442 s -
Total appsec 10.714 s 271.39 ms (2.6%)
Total iast 10.985 s 543.125 ms (5.2%)
Total profiling 10.809 s 366.909 ms (3.5%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.052 s -
Agent appsec 1.189 s 136.614 ms (13.0%)
Agent iast 1.177 s 125.003 ms (11.9%)
Agent profiling 1.275 s 222.733 ms (21.2%)
Total tracing 10.408 s -
Total appsec 10.705 s 296.413 ms (2.8%)
Total iast 10.903 s 494.447 ms (4.8%)
Total profiling 10.747 s 338.62 ms (3.3%)
gantt
    title petclinic - break down per module: candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (715.598 ms) : 0, 715598
BytebuddyAgent [candidate] (710.601 ms) : 0, 710601
GlobalTracer [baseline] (257.795 ms) : 0, 257795
GlobalTracer [candidate] (255.449 ms) : 0, 255449
AppSec [baseline] (55.414 ms) : 0, 55414
AppSec [candidate] (56.916 ms) : 0, 56916
Remote Config [baseline] (715.616 µs) : 0, 716
Remote Config [candidate] (689.663 µs) : 0, 690
Telemetry [baseline] (12.721 ms) : 0, 12721
Telemetry [candidate] (13.361 ms) : 0, 13361
section appsec
BytebuddyAgent [baseline] (728.808 ms) : 0, 728808
BytebuddyAgent [candidate] (730.726 ms) : 0, 730726
GlobalTracer [baseline] (252.647 ms) : 0, 252647
GlobalTracer [candidate] (253.176 ms) : 0, 253176
AppSec [baseline] (170.208 ms) : 0, 170208
AppSec [candidate] (171.269 ms) : 0, 171269
IAST [baseline] (19.376 ms) : 0, 19376
IAST [candidate] (19.603 ms) : 0, 19603
Remote Config [baseline] (663.183 µs) : 0, 663
Remote Config [candidate] (665.77 µs) : 0, 666
Telemetry [baseline] (8.399 ms) : 0, 8399
Telemetry [candidate] (7.975 ms) : 0, 7975
section iast
BytebuddyAgent [baseline] (828.802 ms) : 0, 828802
BytebuddyAgent [candidate] (828.101 ms) : 0, 828101
GlobalTracer [baseline] (246.583 ms) : 0, 246583
GlobalTracer [candidate] (245.823 ms) : 0, 245823
AppSec [baseline] (58.085 ms) : 0, 58085
AppSec [candidate] (57.73 ms) : 0, 57730
IAST [baseline] (21.35 ms) : 0, 21350
IAST [candidate] (21.226 ms) : 0, 21226
Remote Config [baseline] (667.338 µs) : 0, 667
Remote Config [candidate] (652.287 µs) : 0, 652
Telemetry [baseline] (8.461 ms) : 0, 8461
Telemetry [candidate] (8.486 ms) : 0, 8486
section profiling
BytebuddyAgent [baseline] (704.726 ms) : 0, 704726
BytebuddyAgent [candidate] (703.453 ms) : 0, 703453
GlobalTracer [baseline] (371.194 ms) : 0, 371194
GlobalTracer [candidate] (371.153 ms) : 0, 371153
AppSec [baseline] (54.229 ms) : 0, 54229
AppSec [candidate] (53.891 ms) : 0, 53891
Remote Config [baseline] (672.826 µs) : 0, 673
Remote Config [candidate] (640.709 µs) : 0, 641
Telemetry [baseline] (7.855 ms) : 0, 7855
Telemetry [candidate] (7.819 ms) : 0, 7819
ProfilingAgent [baseline] (95.222 ms) : 0, 95222
ProfilingAgent [candidate] (95.815 ms) : 0, 95815
Profiling [baseline] (95.247 ms) : 0, 95247
Profiling [candidate] (95.839 ms) : 0, 95839
Loading
Startup time reports for insecure-bank
gantt
    title insecure-bank - global startup overhead: candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06

    dateFormat X
    axisFormat %s
section tracing
Agent [baseline] (1.055 s) : 0, 1054856
Total [baseline] (8.595 s) : 0, 8595225
Agent [candidate] (1.051 s) : 0, 1050836
Total [candidate] (8.585 s) : 0, 8584798
section iast
Agent [baseline] (1.175 s) : 0, 1174605
Total [baseline] (9.185 s) : 0, 9184893
Agent [candidate] (1.184 s) : 0, 1183996
Total [candidate] (9.189 s) : 0, 9189071
section iast_HARDCODED_SECRET_DISABLED
Agent [baseline] (1.179 s) : 0, 1178837
Total [baseline] (9.228 s) : 0, 9227716
Agent [candidate] (1.177 s) : 0, 1177380
Total [candidate] (9.156 s) : 0, 9155941
section iast_TELEMETRY_OFF
Agent [baseline] (1.178 s) : 0, 1178380
Total [baseline] (9.169 s) : 0, 9168919
Agent [candidate] (1.175 s) : 0, 1175054
Total [candidate] (9.166 s) : 0, 9165922
Loading
  • baseline results
Module Variant Duration Δ tracing
Agent tracing 1.055 s -
Agent iast 1.175 s 119.748 ms (11.4%)
Agent iast_HARDCODED_SECRET_DISABLED 1.179 s 123.981 ms (11.8%)
Agent iast_TELEMETRY_OFF 1.178 s 123.524 ms (11.7%)
Total tracing 8.595 s -
Total iast 9.185 s 589.668 ms (6.9%)
Total iast_HARDCODED_SECRET_DISABLED 9.228 s 632.491 ms (7.4%)
Total iast_TELEMETRY_OFF 9.169 s 573.694 ms (6.7%)
  • candidate results
Module Variant Duration Δ tracing
Agent tracing 1.051 s -
Agent iast 1.184 s 133.16 ms (12.7%)
Agent iast_HARDCODED_SECRET_DISABLED 1.177 s 126.544 ms (12.0%)
Agent iast_TELEMETRY_OFF 1.175 s 124.218 ms (11.8%)
Total tracing 8.585 s -
Total iast 9.189 s 604.273 ms (7.0%)
Total iast_HARDCODED_SECRET_DISABLED 9.156 s 571.144 ms (6.7%)
Total iast_TELEMETRY_OFF 9.166 s 581.124 ms (6.8%)
gantt
    title insecure-bank - break down per module: candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06

    dateFormat X
    axisFormat %s
section tracing
BytebuddyAgent [baseline] (716.138 ms) : 0, 716138
BytebuddyAgent [candidate] (709.808 ms) : 0, 709808
GlobalTracer [baseline] (256.965 ms) : 0, 256965
GlobalTracer [candidate] (255.381 ms) : 0, 255381
AppSec [baseline] (55.308 ms) : 0, 55308
AppSec [candidate] (58.142 ms) : 0, 58142
Remote Config [baseline] (710.089 µs) : 0, 710
Remote Config [candidate] (692.715 µs) : 0, 693
Telemetry [baseline] (10.609 ms) : 0, 10609
Telemetry [candidate] (11.917 ms) : 0, 11917
section iast
BytebuddyAgent [baseline] (826.075 ms) : 0, 826075
BytebuddyAgent [candidate] (833.44 ms) : 0, 833440
GlobalTracer [baseline] (245.417 ms) : 0, 245417
GlobalTracer [candidate] (247.363 ms) : 0, 247363
AppSec [baseline] (57.572 ms) : 0, 57572
AppSec [candidate] (57.824 ms) : 0, 57824
IAST [baseline] (21.421 ms) : 0, 21421
IAST [candidate] (21.194 ms) : 0, 21194
Remote Config [baseline] (640.163 µs) : 0, 640
Remote Config [candidate] (646.97 µs) : 0, 647
Telemetry [baseline] (8.462 ms) : 0, 8462
Telemetry [candidate] (8.523 ms) : 0, 8523
section iast_HARDCODED_SECRET_DISABLED
BytebuddyAgent [baseline] (826.95 ms) : 0, 826950
BytebuddyAgent [candidate] (827.822 ms) : 0, 827822
GlobalTracer [baseline] (247.26 ms) : 0, 247260
GlobalTracer [candidate] (246.44 ms) : 0, 246440
AppSec [baseline] (58.473 ms) : 0, 58473
AppSec [candidate] (57.936 ms) : 0, 57936
IAST [baseline] (21.696 ms) : 0, 21696
IAST [candidate] (21.16 ms) : 0, 21160
Remote Config [baseline] (661.731 µs) : 0, 662
Remote Config [candidate] (656.279 µs) : 0, 656
Telemetry [baseline] (8.711 ms) : 0, 8711
Telemetry [candidate] (8.457 ms) : 0, 8457
section iast_TELEMETRY_OFF
BytebuddyAgent [baseline] (826.967 ms) : 0, 826967
BytebuddyAgent [candidate] (825.657 ms) : 0, 825657
GlobalTracer [baseline] (248.296 ms) : 0, 248296
GlobalTracer [candidate] (246.61 ms) : 0, 246610
AppSec [baseline] (57.939 ms) : 0, 57939
AppSec [candidate] (57.883 ms) : 0, 57883
IAST [baseline] (20.977 ms) : 0, 20977
IAST [candidate] (20.879 ms) : 0, 20879
Remote Config [baseline] (656.502 µs) : 0, 657
Remote Config [candidate] (640.34 µs) : 0, 640
Telemetry [baseline] (8.507 ms) : 0, 8507
Telemetry [candidate] (8.39 ms) : 0, 8390
Loading

Load

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
end_time 2024-12-30T12:31:59 2024-12-30T12:38:59
git_branch master bbujon/context-api
git_commit_date 1735554168 1735561248
git_commit_sha 7d4150e c4da3f7
release_version 1.45.0-SNAPSHOT~7d4150eb06 1.45.0-SNAPSHOT~c4da3f7ab2
start_time 2024-12-30T12:31:45 2024-12-30T12:38:45
See matching parameters
Baseline Candidate
application insecure-bank insecure-bank
ci_job_date 1735562694 1735562694
ci_job_id 750838769 750838769
ci_pipeline_id 51900574 51900574
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
variant iast iast

Summary

Found 0 performance improvements and 0 performance regressions! Performance is the same for 12 metrics, 16 unstable metrics.

Request duration reports for insecure-bank
gantt
    title insecure-bank - request duration [CI 0.99] : candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06
    dateFormat X
    axisFormat %s
section baseline
no_agent (381.235 µs) : 360, 402
.   : milestone, 381,
iast (503.178 µs) : 481, 525
.   : milestone, 503,
iast_FULL (659.57 µs) : 638, 681
.   : milestone, 660,
iast_GLOBAL (522.413 µs) : 501, 544
.   : milestone, 522,
iast_HARDCODED_SECRET_DISABLED (493.439 µs) : 471, 515
.   : milestone, 493,
iast_INACTIVE (451.563 µs) : 431, 473
.   : milestone, 452,
iast_TELEMETRY_OFF (480.508 µs) : 459, 502
.   : milestone, 481,
tracing (457.109 µs) : 436, 478
.   : milestone, 457,
section candidate
no_agent (383.983 µs) : 364, 404
.   : milestone, 384,
iast (495.883 µs) : 474, 517
.   : milestone, 496,
iast_FULL (662.597 µs) : 641, 684
.   : milestone, 663,
iast_GLOBAL (528.815 µs) : 507, 551
.   : milestone, 529,
iast_HARDCODED_SECRET_DISABLED (497.025 µs) : 476, 518
.   : milestone, 497,
iast_INACTIVE (463.987 µs) : 442, 486
.   : milestone, 464,
iast_TELEMETRY_OFF (485.463 µs) : 464, 507
.   : milestone, 485,
tracing (450.576 µs) : 430, 471
.   : milestone, 451,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 381.235 µs [359.974 µs, 402.496 µs] -
iast 503.178 µs [481.461 µs, 524.895 µs] 121.943 µs (32.0%)
iast_FULL 659.57 µs [637.931 µs, 681.208 µs] 278.335 µs (73.0%)
iast_GLOBAL 522.413 µs [501.211 µs, 543.614 µs] 141.178 µs (37.0%)
iast_HARDCODED_SECRET_DISABLED 493.439 µs [471.472 µs, 515.406 µs] 112.204 µs (29.4%)
iast_INACTIVE 451.563 µs [430.625 µs, 472.502 µs] 70.329 µs (18.4%)
iast_TELEMETRY_OFF 480.508 µs [459.266 µs, 501.75 µs] 99.273 µs (26.0%)
tracing 457.109 µs [435.831 µs, 478.387 µs] 75.874 µs (19.9%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 383.983 µs [363.986 µs, 403.979 µs] -
iast 495.883 µs [474.463 µs, 517.304 µs] 111.9 µs (29.1%)
iast_FULL 662.597 µs [640.774 µs, 684.42 µs] 278.614 µs (72.6%)
iast_GLOBAL 528.815 µs [507.123 µs, 550.506 µs] 144.832 µs (37.7%)
iast_HARDCODED_SECRET_DISABLED 497.025 µs [475.761 µs, 518.288 µs] 113.042 µs (29.4%)
iast_INACTIVE 463.987 µs [441.938 µs, 486.035 µs] 80.004 µs (20.8%)
iast_TELEMETRY_OFF 485.463 µs [463.843 µs, 507.082 µs] 101.48 µs (26.4%)
tracing 450.576 µs [429.928 µs, 471.225 µs] 66.594 µs (17.3%)
Request duration reports for petclinic
gantt
    title petclinic - request duration [CI 0.99] : candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.359 ms) : 1339, 1379
.   : milestone, 1359,
appsec (1.757 ms) : 1733, 1780
.   : milestone, 1757,
appsec_no_iast (1.77 ms) : 1745, 1796
.   : milestone, 1770,
iast (1.509 ms) : 1485, 1532
.   : milestone, 1509,
profiling (1.521 ms) : 1497, 1544
.   : milestone, 1521,
tracing (1.504 ms) : 1477, 1530
.   : milestone, 1504,
section candidate
no_agent (1.374 ms) : 1354, 1394
.   : milestone, 1374,
appsec (1.737 ms) : 1713, 1761
.   : milestone, 1737,
appsec_no_iast (1.775 ms) : 1750, 1799
.   : milestone, 1775,
iast (1.521 ms) : 1498, 1545
.   : milestone, 1521,
profiling (1.565 ms) : 1540, 1590
.   : milestone, 1565,
tracing (1.505 ms) : 1480, 1529
.   : milestone, 1505,
Loading
  • baseline results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.359 ms [1.339 ms, 1.379 ms] -
appsec 1.757 ms [1.733 ms, 1.78 ms] 397.507 µs (29.2%)
appsec_no_iast 1.77 ms [1.745 ms, 1.796 ms] 411.485 µs (30.3%)
iast 1.509 ms [1.485 ms, 1.532 ms] 149.735 µs (11.0%)
profiling 1.521 ms [1.497 ms, 1.544 ms] 161.803 µs (11.9%)
tracing 1.504 ms [1.477 ms, 1.53 ms] 144.708 µs (10.6%)
  • candidate results
Variant Request duration [CI 0.99] Δ no_agent
no_agent 1.374 ms [1.354 ms, 1.394 ms] -
appsec 1.737 ms [1.713 ms, 1.761 ms] 362.57 µs (26.4%)
appsec_no_iast 1.775 ms [1.75 ms, 1.799 ms] 400.645 µs (29.2%)
iast 1.521 ms [1.498 ms, 1.545 ms] 147.225 µs (10.7%)
profiling 1.565 ms [1.54 ms, 1.59 ms] 190.523 µs (13.9%)
tracing 1.505 ms [1.48 ms, 1.529 ms] 130.674 µs (9.5%)

Dacapo

Parameters

Baseline Candidate
baseline_or_candidate baseline candidate
git_branch master bbujon/context-api
git_commit_date 1735554168 1735561248
git_commit_sha 7d4150e c4da3f7
release_version 1.45.0-SNAPSHOT~7d4150eb06 1.45.0-SNAPSHOT~c4da3f7ab2
See matching parameters
Baseline Candidate
application biojava biojava
ci_job_date 1735563255 1735563255
ci_job_id 750838770 750838770
ci_pipeline_id 51900574 51900574
cpu_model Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz Intel(R) Xeon(R) Platinum 8259CL CPU @ 2.50GHz
variant appsec appsec

Summary

Found 0 performance improvements and 0 performance regressions! Performance is the same for 12 metrics, 0 unstable metrics.

Execution time for biojava
gantt
    title biojava - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06
    dateFormat X
    axisFormat %s
section baseline
no_agent (14.938 s) : 14938000, 14938000
.   : milestone, 14938000,
appsec (15.865 s) : 15865000, 15865000
.   : milestone, 15865000,
iast (19.043 s) : 19043000, 19043000
.   : milestone, 19043000,
iast_GLOBAL (18.069 s) : 18069000, 18069000
.   : milestone, 18069000,
profiling (15.635 s) : 15635000, 15635000
.   : milestone, 15635000,
tracing (15.41 s) : 15410000, 15410000
.   : milestone, 15410000,
section candidate
no_agent (15.597 s) : 15597000, 15597000
.   : milestone, 15597000,
appsec (15.066 s) : 15066000, 15066000
.   : milestone, 15066000,
iast (18.942 s) : 18942000, 18942000
.   : milestone, 18942000,
iast_GLOBAL (17.991 s) : 17991000, 17991000
.   : milestone, 17991000,
profiling (15.681 s) : 15681000, 15681000
.   : milestone, 15681000,
tracing (14.754 s) : 14754000, 14754000
.   : milestone, 14754000,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 14.938 s [14.938 s, 14.938 s] -
appsec 15.865 s [15.865 s, 15.865 s] 927.0 ms (6.2%)
iast 19.043 s [19.043 s, 19.043 s] 4.105 s (27.5%)
iast_GLOBAL 18.069 s [18.069 s, 18.069 s] 3.131 s (21.0%)
profiling 15.635 s [15.635 s, 15.635 s] 697.0 ms (4.7%)
tracing 15.41 s [15.41 s, 15.41 s] 472.0 ms (3.2%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 15.597 s [15.597 s, 15.597 s] -
appsec 15.066 s [15.066 s, 15.066 s] -531.0 ms (-3.4%)
iast 18.942 s [18.942 s, 18.942 s] 3.345 s (21.4%)
iast_GLOBAL 17.991 s [17.991 s, 17.991 s] 2.394 s (15.3%)
profiling 15.681 s [15.681 s, 15.681 s] 84.0 ms (0.5%)
tracing 14.754 s [14.754 s, 14.754 s] -843.0 ms (-5.4%)
Execution time for tomcat
gantt
    title tomcat - execution time [CI 0.99] : candidate=1.45.0-SNAPSHOT~c4da3f7ab2, baseline=1.45.0-SNAPSHOT~7d4150eb06
    dateFormat X
    axisFormat %s
section baseline
no_agent (1.476 ms) : 1465, 1488
.   : milestone, 1476,
appsec (2.355 ms) : 2313, 2397
.   : milestone, 2355,
iast (2.115 ms) : 2062, 2169
.   : milestone, 2115,
iast_GLOBAL (2.15 ms) : 2096, 2203
.   : milestone, 2150,
profiling (1.973 ms) : 1929, 2016
.   : milestone, 1973,
tracing (1.946 ms) : 1905, 1988
.   : milestone, 1946,
section candidate
no_agent (1.47 ms) : 1459, 1482
.   : milestone, 1470,
appsec (2.367 ms) : 2325, 2409
.   : milestone, 2367,
iast (2.1 ms) : 2046, 2153
.   : milestone, 2100,
iast_GLOBAL (2.143 ms) : 2090, 2197
.   : milestone, 2143,
profiling (1.975 ms) : 1931, 2018
.   : milestone, 1975,
tracing (1.939 ms) : 1899, 1980
.   : milestone, 1939,
Loading
  • baseline results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.476 ms [1.465 ms, 1.488 ms] -
appsec 2.355 ms [2.313 ms, 2.397 ms] 878.688 µs (59.5%)
iast 2.115 ms [2.062 ms, 2.169 ms] 638.725 µs (43.3%)
iast_GLOBAL 2.15 ms [2.096 ms, 2.203 ms] 673.497 µs (45.6%)
profiling 1.973 ms [1.929 ms, 2.016 ms] 496.248 µs (33.6%)
tracing 1.946 ms [1.905 ms, 1.988 ms] 470.132 µs (31.8%)
  • candidate results
Variant Execution Time [CI 0.99] Δ no_agent
no_agent 1.47 ms [1.459 ms, 1.482 ms] -
appsec 2.367 ms [2.325 ms, 2.409 ms] 896.202 µs (60.9%)
iast 2.1 ms [2.046 ms, 2.153 ms] 629.514 µs (42.8%)
iast_GLOBAL 2.143 ms [2.09 ms, 2.197 ms] 673.008 µs (45.8%)
profiling 1.975 ms [1.931 ms, 2.018 ms] 504.375 µs (34.3%)
tracing 1.939 ms [1.899 ms, 1.98 ms] 468.827 µs (31.9%)

Copy link
Contributor

@mcculls mcculls left a comment

Choose a reason for hiding this comment

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

+1 thanks for the diligent cleanup!

Improve Javadoc about usage and thread safety
Improve null handling using defensive checks, and document parameters and results
Improve tests to cover all context implementations
@PerfectSlayer PerfectSlayer merged commit 0dc9c08 into master Dec 30, 2024
147 of 148 checks passed
@PerfectSlayer PerfectSlayer deleted the bbujon/context-api branch December 30, 2024 14:17
@github-actions github-actions bot added this to the 1.45.0 milestone Dec 30, 2024
svc-squareup-copybara pushed a commit to cashapp/misk that referenced this pull request Jan 9, 2025
| Package | Type | Package file | Manager | Update | Change |
|---|---|---|---|---|---|
|
[com.google.api.grpc:proto-google-common-protos](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.50.0` -> `2.50.1` |
|
[com.google.cloud:google-cloud-core-http](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.49.0` -> `2.49.1` |
|
[com.google.cloud:google-cloud-core](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.49.0` -> `2.49.1` |
| [com.google.api:gax](https://github.com/googleapis/sdk-platform-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.59.0` -> `2.59.1` |
| [com.datadoghq:dd-trace-api](https://github.com/datadog/dd-trace-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | minor |
`1.44.1` -> `1.45.0` |
| [com.datadoghq:dd-trace-ot](https://github.com/datadog/dd-trace-java)
| dependencies | misk/gradle/libs.versions.toml | gradle | minor |
`1.44.1` -> `1.45.0` |
| [software.amazon.awssdk:sdk-core](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
|
[software.amazon.awssdk:dynamodb-enhanced](https://aws.amazon.com/sdkforjava)
| dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:dynamodb](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:aws-core](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:bom](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |
| [software.amazon.awssdk:auth](https://aws.amazon.com/sdkforjava) |
dependencies | misk/gradle/libs.versions.toml | gradle | patch |
`2.29.47` -> `2.29.48` |

---

### Release Notes

<details>
<summary>datadog/dd-trace-java (com.datadoghq:dd-trace-api)</summary>

###
[`v1.45.0`](https://github.com/DataDog/dd-trace-java/releases/tag/v1.45.0):
1.45.0

##### Breaking changes

> \[!WARNING]\
> Support for custom scope manager using OpenTelemetry tracer artifact
(`dd-trace-ot`) is dropped.
> Tracing with OpenTracing API and custom scope manager will continue to
work on 1.44.x releases.

##### Components

##### Application Security Management (IAST)

- ✨ Add propagation to URI#toURL method
([#&#8203;8146](DataDog/dd-trace-java#8146) -
[@&#8203;manuel-alvarez-alvarez](https://github.com/manuel-alvarez-alvarez))
- ✨ Increase IAST propagation to StringBuilder setLength
([#&#8203;8119](DataDog/dd-trace-java#8119) -
[@&#8203;Mariovido](https://github.com/Mariovido))
- ✨ Increase IAST propagation to StringBuffer append
([#&#8203;8082](DataDog/dd-trace-java#8082) -
[@&#8203;Mariovido](https://github.com/Mariovido))
- ✨ Handle IAST security controls custom validation and
sanitization methods
([#&#8203;7997](DataDog/dd-trace-java#7997) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Application Security Management (WAF)

- ✨ Update user lifecycle tracking to V3
([#&#8203;8108](DataDog/dd-trace-java#8108) -
[@&#8203;manuel-alvarez-alvarez](https://github.com/manuel-alvarez-alvarez))
- ✨ Exploit prevention for Shell Injection / Command Injection
([#&#8203;7615](DataDog/dd-trace-java#7615) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Build & Tooling

- 💡 Support instrumentation of repackaged libraries
([#&#8203;8153](DataDog/dd-trace-java#8153) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Configure native image build setting for JDK-22 based
GraalVM
([#&#8203;8092](DataDog/dd-trace-java#8092) -
[@&#8203;MattAlp](https://github.com/MattAlp))

##### Database Monitoring

- ✨ Add full APM/DBM mode for Oracle
([#&#8203;8090](DataDog/dd-trace-java#8090) -
[@&#8203;nenadnoveljic](https://github.com/nenadnoveljic))

##### Dynamic Instrumentation

- 🐛 make local var hoisting disabled by default
([#&#8203;8158](DataDog/dd-trace-java#8158) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- 🐛 Fix var hoisting issue when no previous store
([#&#8203;8122](DataDog/dd-trace-java#8122) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- ✨ Only decorate spans without code origin information
([#&#8203;8105](DataDog/dd-trace-java#8105) -
[@&#8203;evanchooly](https://github.com/evanchooly))
- 🐛 Fix suspend Kotlin methods instrumentation
([#&#8203;8080](DataDog/dd-trace-java#8080) -
[@&#8203;jpbempel](https://github.com/jpbempel))
- 🐛 Fix class file version detection
([#&#8203;8057](DataDog/dd-trace-java#8057) -
[@&#8203;jpbempel](https://github.com/jpbempel))

##### GraalVM native-image

- ✨ Configure native image build setting for JDK-22 based
GraalVM
([#&#8203;8092](DataDog/dd-trace-java#8092) -
[@&#8203;MattAlp](https://github.com/MattAlp))

##### ML Observability (LLMObs)

- ✨🧪 Add LLMObs configuration
([#&#8203;8076](DataDog/dd-trace-java#8076) -
[@&#8203;gary-huang](https://github.com/gary-huang))

##### Metrics

- Bump integrations-core submodule to 7.60.0
([#&#8203;8098](DataDog/dd-trace-java#8098) -
[@&#8203;mcculls](https://github.com/mcculls))
- Upgrade to java-dogstatsd-client v4.4.3
([#&#8203;8096](DataDog/dd-trace-java#8096) -
[@&#8203;mcculls](https://github.com/mcculls))

##### OpenTracing

- ⚠️🧹 Remove custom scope manager support
([#&#8203;8164](DataDog/dd-trace-java#8164) -
[@&#8203;PerfectSlayer](https://github.com/PerfectSlayer))

##### Telemetry

- ✨ Retry telemetry requests if CI Visibility is enabled
([#&#8203;8147](DataDog/dd-trace-java#8147) -
[@&#8203;nikita-tkachenko-datadog](https://github.com/nikita-tkachenko-datadog))
- ✨ Add configurable Dependency service resolution period
([#&#8203;8079](DataDog/dd-trace-java#8079) -
[@&#8203;jandro996](https://github.com/jandro996))

##### Testing

- 🐛 Remove restriction to not run vertx4 latest tests on java 17
([#&#8203;8133](DataDog/dd-trace-java#8133) -
[@&#8203;vandonr](https://github.com/vandonr))

##### Tracer core

- ✨ Defer remote components to avoid OkHttp class-loading
side-effects
([#&#8203;8131](DataDog/dd-trace-java#8131) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Improve Context API null handling and Javadoc
([#&#8203;8129](DataDog/dd-trace-java#8129) -
[@&#8203;PerfectSlayer](https://github.com/PerfectSlayer))
- 🐛⚡ Avoid performing blocking I/O operation on application
thread
([#&#8203;8120](DataDog/dd-trace-java#8120) -
[@&#8203;mcculls](https://github.com/mcculls))
- 💡 Introduce a shared context component, independent of tracing
([#&#8203;8117](DataDog/dd-trace-java#8117) -
[@&#8203;mcculls](https://github.com/mcculls))
- ✨ Improves ServiceNameCollector
([#&#8203;8109](DataDog/dd-trace-java#8109) -
[@&#8203;amarziali](https://github.com/amarziali))
- Upgrade to ASM 9.7.1 (adds new constant for Java 24)
([#&#8203;8097](DataDog/dd-trace-java#8097) -
[@&#8203;mcculls](https://github.com/mcculls))
- 🐛 Dynamically evaluate service name for message consumers
([#&#8203;8088](DataDog/dd-trace-java#8088) -
[@&#8203;amarziali](https://github.com/amarziali))

##### Serverless

- 🐛 Add avoid double instrumenting lambda non-streaming handlers.
([#&#8203;8073](DataDog/dd-trace-java#8073) -
[@&#8203;purple4reina](https://github.com/purple4reina))

##### Instrumentations

##### AWS SDK instrumentation

- 💡 Instrument EMR's relocated AWS SDK
([#&#8203;8157](DataDog/dd-trace-java#8157) -
[@&#8203;mcculls](https://github.com/mcculls))

##### Eclipse Vert.x instrumentation

- 🐛 Remove restriction to not run vertx4 latest tests on java 17
([#&#8203;8133](DataDog/dd-trace-java#8133) -
[@&#8203;vandonr](https://github.com/vandonr))

##### JDBC instrumentation

- ✨ Add full APM/DBM mode for Oracle
([#&#8203;8090](DataDog/dd-trace-java#8090) -
[@&#8203;nenadnoveljic](https://github.com/nenadnoveljic))

##### Jetty instrumentation

- 🐛 Ensure jetty 12 has servlet.path starting with /
([#&#8203;8093](DataDog/dd-trace-java#8093) -
[@&#8203;github-actions](https://github.com/github-actions)\[bot])

##### JMS instrumentation

- 🧹 Re-use `javax` JMS module for `jakarta` namespace
([#&#8203;8155](DataDog/dd-trace-java#8155) -
[@&#8203;mcculls](https://github.com/mcculls))
- 🧹 Group `javax.jms` instrumentations under a single module
([#&#8203;8154](DataDog/dd-trace-java#8154) -
[@&#8203;mcculls](https://github.com/mcculls))

##### Reactor instrumentation

- 🐛 Reactor: early propagate span in context when subscribing
([#&#8203;8166](DataDog/dd-trace-java#8166) -
[@&#8203;amarziali](https://github.com/amarziali))

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "after 6pm every weekday,before 2am
every weekday" in timezone Australia/Melbourne, Automerge - At any time
(no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

👻 **Immortal**: This PR will be recreated if closed unmerged. Get
[config help](https://github.com/renovatebot/renovate/discussions) if
that's undesired.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://github.com/renovatebot/renovate).

GitOrigin-RevId: ba2355aa4e2e39ab1fee27319cc4176238efd90b
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants