Skip to content

Commit 3b7aba2

Browse files
authored
Merge branch 'master' into andrea.marziali/liberty-fix
2 parents e2f2c9a + b4aebf8 commit 3b7aba2

File tree

7 files changed

+69
-25
lines changed

7 files changed

+69
-25
lines changed

.circleci/config.continue.yml.j2

Lines changed: 41 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -179,9 +179,14 @@ commands:
179179
display_memory_usage:
180180
steps:
181181
- run:
182-
name: Max Memory Used
182+
name: Runner Memory Usage
183183
# The file does not seem to exist when DLC is disabled
184-
command: cat /sys/fs/cgroup/memory/memory.max_usage_in_bytes || true
184+
command: |
185+
# Show cgroupv2 memory usage
186+
printf "cgroup memory.peak: $(cat /sys/fs/cgroup/memory.peak 2>/dev/null || echo 'not found')%s\n"
187+
printf "cgroup memory.max : $(cat /sys/fs/cgroup/memory.max 2>/dev/null || echo 'not found')%s\n"
188+
printf "cgroup memory.high: $(cat /sys/fs/cgroup/memory.high 2>/dev/null || echo 'not found')%s\n"
189+
printf "ram memory : $(grep MemTotal /proc/meminfo | tr -s ' ' | cut -d ' ' -f 2)%s\n"
185190
when: always
186191

187192

@@ -282,9 +287,11 @@ commands:
282287
jobs:
283288
build:
284289
<<: *defaults
285-
resource_class: xlarge
286290

287291
parameters:
292+
resourceClass:
293+
type: string
294+
default: xlarge
288295
gradleTarget:
289296
type: string
290297
cacheType:
@@ -296,6 +303,7 @@ jobs:
296303
type: string
297304
default: ".*"
298305

306+
resource_class: << parameters.resourceClass >>
299307
steps:
300308
- setup_code
301309

@@ -304,15 +312,15 @@ jobs:
304312

305313
- restore_dependency_cache:
306314
cacheType: << parameters.cacheType >>
307-
315+
308316
- run:
309317
name: Build Project
310318
command: >-
311319
{% if is_nightly %}
312-
./gradlew resolveAndLockAll --write-locks &&
320+
./gradlew resolveAndLockAll --write-locks --no-daemon &&
313321
{% endif %}
314322
MAVEN_OPTS="-Xms64M -Xmx256M"
315-
GRADLE_OPTS="-Dorg.gradle.jvmargs='-Xmx2560M -Xms2560M -XX:ErrorFile=/tmp/hs_err_pid%p.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp'"
323+
GRADLE_OPTS="-Dorg.gradle.jvmargs='-Xmx2560M -XX:ErrorFile=/tmp/hs_err_pid%p.log -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp'"
316324
./gradlew clean
317325
<< parameters.gradleTarget >>
318326
-PskipTests
@@ -384,6 +392,9 @@ jobs:
384392
<<: *defaults
385393

386394
parameters:
395+
resourceClass:
396+
type: string
397+
default: medium+
387398
parallelism:
388399
type: integer
389400
default: 1
@@ -395,7 +406,7 @@ jobs:
395406
type: string
396407
default: ".*"
397408

398-
resource_class: medium+
409+
resource_class: << parameters.resourceClass >>
399410

400411
parallelism: << parameters.parallelism >>
401412

@@ -445,6 +456,8 @@ jobs:
445456
when: on_fail
446457
command: .circleci/cancel_workflow.sh
447458

459+
- display_memory_usage
460+
448461
build_clean_cache:
449462
<<: *defaults
450463

@@ -493,13 +506,13 @@ jobs:
493506

494507
tests: &tests
495508
<<: *defaults
496-
# since tests use test containers, they will use a Linux VM / Remote Docker executor, so there is no medium+ size
497-
resource_class: large
498-
499509
docker:
500510
- image: << pipeline.parameters.docker_image >>:{{ docker_image_prefix }}<< parameters.testJvm >>
501511

502512
parameters:
513+
resourceClass:
514+
type: string
515+
default: large
503516
environment:
504517
type: string
505518
default: ""
@@ -535,6 +548,9 @@ jobs:
535548
cacheType:
536549
type: string
537550

551+
# since tests use test containers, they will use a Linux VM / Remote Docker executor, so there is no medium+ size
552+
resource_class: << parameters.resourceClass >>
553+
538554
parallelism: << parameters.parallelism >>
539555

540556
steps:
@@ -652,13 +668,18 @@ jobs:
652668
exit 1
653669
fi
654670

671+
# TODO: merge xlarge_tests and tests? or rename this?
655672
xlarge_tests:
656673
<<: *tests
657674

658675
docker:
676+
# The first image listed in your configuration for a job is referred to as the primary container image
677+
# and this is where all steps in the job will run. Secondary containers can also be specified to run
678+
# alongside for running services, such as, databases.
659679
- image: << pipeline.parameters.docker_image >>:{{ docker_image_prefix }}<< parameters.testJvm >>
660680
environment:
661681
- CI_USE_TEST_AGENT=true
682+
662683
- image: ghcr.io/datadog/dd-apm-test-agent/ddapm-test-agent:v1.11.0
663684
environment:
664685
- LOG_LEVEL=DEBUG
@@ -667,8 +688,6 @@ jobs:
667688
- DD_POOL_TRACE_CHECK_FAILURES=true
668689
- DD_DISABLE_ERROR_RESPONSES=true
669690
- ENABLED_CHECKS=trace_content_length,trace_stall,meta_tracer_version_header,trace_count_header,trace_peer_service,trace_dd_service
670-
# TODO: merge xlarge_tests and tests? or rename this?
671-
resource_class: large
672691

673692

674693
# The only way to do fan-in in CircleCI seems to have a proper job, so let's have one that
@@ -969,15 +988,18 @@ build_test_jobs: &build_test_jobs
969988
cacheType: base
970989
- build:
971990
name: build_inst
991+
resourceClass: 2xlarge
972992
gradleTarget: :instrumentationTest
973993
cacheType: inst
974994
triggeredBy: *instrumentation_modules
975995
- build:
976996
name: build_latestdep
997+
resourceClass: 2xlarge
977998
gradleTarget: :instrumentationLatestDepTest
978999
cacheType: latestdep
9791000
- build:
9801001
name: build_smoke
1002+
resourceClass: 2xlarge
9811003
gradleTarget: :smokeTest
9821004
cacheType: smoke
9831005
- build:
@@ -1001,13 +1023,15 @@ build_test_jobs: &build_test_jobs
10011023
requires:
10021024
- ok_to_test
10031025
name: check_base
1026+
resourceClass: large
10041027
gradleTarget: ":baseCheck"
10051028
cacheType: base
10061029

10071030
- check:
10081031
requires:
10091032
- ok_to_test
10101033
name: check_inst
1034+
resourceClass: 2xlarge
10111035
parallelism: 5
10121036
gradleTarget: ":instrumentationCheck"
10131037
cacheType: inst
@@ -1017,6 +1041,7 @@ build_test_jobs: &build_test_jobs
10171041
requires:
10181042
- ok_to_test
10191043
name: check_smoke
1044+
resourceClass: large
10201045
gradleTarget: ":smokeCheck"
10211046
cacheType: smoke
10221047

@@ -1075,6 +1100,7 @@ build_test_jobs: &build_test_jobs
10751100
requires:
10761101
- ok_to_test
10771102
name: z_test_<< matrix.testJvm >>_inst
1103+
resourceClass: xlarge
10781104
gradleTarget: ":instrumentationTest"
10791105
gradleParameters: "-PskipFlakyTests"
10801106
triggeredBy: *instrumentation_modules
@@ -1103,6 +1129,7 @@ build_test_jobs: &build_test_jobs
11031129
- ok_to_test
11041130
- build_latestdep
11051131
name: test_8_inst_latest
1132+
resourceClass: xlarge
11061133
gradleTarget: ":instrumentationLatestDepTest"
11071134
gradleParameters: "-PskipFlakyTests"
11081135
triggeredBy: *instrumentation_modules
@@ -1117,6 +1144,7 @@ build_test_jobs: &build_test_jobs
11171144
- ok_to_test
11181145
- build_latestdep
11191146
name: test_17_inst_latest
1147+
resourceClass: xlarge
11201148
gradleTarget: ":instrumentationLatestDepTest"
11211149
gradleParameters: "-PskipFlakyTests"
11221150
triggeredBy: *instrumentation_modules
@@ -1304,6 +1332,7 @@ build_test_jobs: &build_test_jobs
13041332
requires:
13051333
- ok_to_test
13061334
name: z_test_8_smoke
1335+
resourceClass: xlarge
13071336
gradleTarget: "stageMainDist :smokeTest"
13081337
gradleParameters: "-PskipFlakyTests"
13091338
stage: smoke

.github/workflows/analyze-changes.yaml

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ jobs:
4040
${{ runner.os }}-gradle-
4141
4242
- name: Initialize CodeQL
43-
uses: github/codeql-action/init@28deaeda66b76a05916b6923827895f2b14ab387 # v3.28.16
43+
uses: github/codeql-action/init@60168efe1c415ce0f5521ea06d5c2062adbeed1b # v3.28.17
4444
with:
4545
languages: 'java'
4646
build-mode: 'manual'
@@ -57,7 +57,7 @@ jobs:
5757
--build-cache --parallel --stacktrace --no-daemon --max-workers=4
5858
5959
- name: Perform CodeQL Analysis and upload results to GitHub Security tab
60-
uses: github/codeql-action/analyze@28deaeda66b76a05916b6923827895f2b14ab387 # v3.28.16
60+
uses: github/codeql-action/analyze@60168efe1c415ce0f5521ea06d5c2062adbeed1b # v3.28.17
6161

6262
trivy:
6363
name: Analyze changes with Trivy
@@ -120,7 +120,7 @@ jobs:
120120
TRIVY_JAVA_DB_REPOSITORY: ghcr.io/aquasecurity/trivy-java-db,public.ecr.aws/aquasecurity/trivy-java-db
121121

122122
- name: Upload Trivy scan results to GitHub Security tab
123-
uses: github/codeql-action/upload-sarif@28deaeda66b76a05916b6923827895f2b14ab387 # v3.28.16
123+
uses: github/codeql-action/upload-sarif@60168efe1c415ce0f5521ea06d5c2062adbeed1b # v3.28.17
124124
if: always()
125125
with:
126126
sarif_file: 'trivy-results.sarif'

.gitlab-ci.yml

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,8 @@
11
include:
2-
- remote: https://gitlab-templates.ddbuild.io/libdatadog/include/ci_authenticated_job.yml
3-
- remote: https://gitlab-templates.ddbuild.io/libdatadog/include/one-pipeline.yml
2+
- project: DataDog/apm-reliability/libdatadog-build
3+
ref: 0f677257308e1c379af490b754febfb40fa2c06d
4+
file: templates/ci_authenticated_job.yml
5+
- local: ".gitlab/one-pipeline.locked.yml"
46
- local: ".gitlab/benchmarks.yml"
57
- local: ".gitlab/macrobenchmarks.yml"
68
- local: ".gitlab/exploration-tests.yml"
@@ -394,7 +396,7 @@ muzzle-dep-report:
394396
- if: $CI_COMMIT_BRANCH == "master"
395397
when: on_success
396398
script:
397-
- >
399+
- >
398400
if [ "$PROFILE_TESTS" == "true" ] && [ "$testJvm" != "ibm8" ] && [ "$testJvm" != "oracle8" ];
399401
then
400402
export PROFILER_COMMAND="-XX:StartFlightRecording=settings=profile,filename=/tmp/${CI_JOB_NAME_SLUG}.jfr,dumponexit=true";
@@ -799,4 +801,4 @@ tracer-base-image-snapshot:
799801
- echo $GH_TOKEN|docker login ghcr.io/datadog -u uploader --password-stdin
800802
- mkdir -p ./tooling/ci/binaries/ && cp workspace/dd-java-agent/build/libs/*.jar ./tooling/ci/binaries/dd-java-agent.jar
801803
- docker buildx build -t ghcr.io/datadog/dd-trace-java/dd-trace-java:latest_snapshot -f ./tooling/ci/Dockerfile .
802-
- docker push ghcr.io/datadog/dd-trace-java/dd-trace-java:latest_snapshot
804+
- docker push ghcr.io/datadog/dd-trace-java/dd-trace-java:latest_snapshot

.gitlab/one-pipeline.locked.yml

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
# DO NOT EDIT THIS FILE MANUALLY
2+
# This file is auto-generated by automation.
3+
include:
4+
- remote: https://gitlab-templates.ddbuild.io/libdatadog/one-pipeline/ca/05e116339b9780a138a474d0348e97debfca97f27bbc4ca489cf4e4c90d9cc94/one-pipeline.yml

dd-java-agent/instrumentation/kotlin-coroutines/src/main/java/datadog/trace/instrumentation/kotlin/coroutines/LazyCoroutineInstrumentation.java

Lines changed: 13 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,25 +1,34 @@
11
package datadog.trace.instrumentation.kotlin.coroutines;
22

3+
import static datadog.trace.agent.tooling.bytebuddy.matcher.HierarchyMatchers.extendsClass;
34
import static datadog.trace.agent.tooling.bytebuddy.matcher.NameMatchers.named;
45
import static net.bytebuddy.matcher.ElementMatchers.isMethod;
6+
import static net.bytebuddy.matcher.ElementMatchers.takesNoArguments;
57

68
import datadog.trace.agent.tooling.Instrumenter;
79
import kotlinx.coroutines.AbstractCoroutine;
810
import net.bytebuddy.asm.Advice;
11+
import net.bytebuddy.description.type.TypeDescription;
12+
import net.bytebuddy.matcher.ElementMatcher;
913

1014
/** Captures the Datadog context when lazy coroutines start. */
1115
public class LazyCoroutineInstrumentation
12-
implements Instrumenter.ForSingleType, Instrumenter.HasMethodAdvice {
16+
implements Instrumenter.ForTypeHierarchy, Instrumenter.HasMethodAdvice {
1317

1418
@Override
15-
public String instrumentedType() {
16-
return "kotlinx.coroutines.LazyDeferredCoroutine";
19+
public String hierarchyMarkerType() {
20+
return "kotlinx.coroutines.AbstractCoroutine";
21+
}
22+
23+
@Override
24+
public ElementMatcher<TypeDescription> hierarchyMatcher() {
25+
return extendsClass(named(hierarchyMarkerType()));
1726
}
1827

1928
@Override
2029
public void methodAdvice(MethodTransformer transformer) {
2130
transformer.applyAdvice(
22-
isMethod().and(named("onStart")),
31+
isMethod().and(named("onStart")).and(takesNoArguments()),
2332
LazyCoroutineInstrumentation.class.getName() + "$OnStartAdvice");
2433
}
2534

dd-java-agent/instrumentation/vertx-mysql-client-4.0/build.gradle

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ muzzle {
55
pass {
66
group = 'io.vertx'
77
module = 'vertx-mysql-client'
8-
versions = '[4.0.0,5.0.0)'
8+
versions = '[4.0.0,)'
99
assertInverse = true
1010
}
1111
}

dd-java-agent/instrumentation/vertx-mysql-client-4.4.2/build.gradle

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ muzzle {
55
pass {
66
group = 'io.vertx'
77
module = 'vertx-mysql-client'
8-
versions = '[4.4.2,4.6.0)'
8+
versions = '[4.4.2,)'
99
assertInverse = true
1010
}
1111
}

0 commit comments

Comments
 (0)