From 0a4ef79fae33b378a77ec1467ca2693d13812526 Mon Sep 17 00:00:00 2001 From: Jay DeLuca Date: Wed, 1 Jan 2025 07:01:30 -0500 Subject: [PATCH 1/5] Update docs for running tests --- docs/contributing/running-tests.md | 61 ++++++++++++++++++++---------- 1 file changed, 41 insertions(+), 20 deletions(-) diff --git a/docs/contributing/running-tests.md b/docs/contributing/running-tests.md index 836a0f6d900b..da7678a16247 100644 --- a/docs/contributing/running-tests.md +++ b/docs/contributing/running-tests.md @@ -4,14 +4,14 @@ Open Telemetry Auto Instrumentation's minimal supported version is java 8. All jar files that we produce, unless noted otherwise, have bytecode -compatible with java 8 runtime. Our test suite is executed against +compatibility with the java 8 runtime. Our test suite is executed against java 8, all LTS versions and the latest non-LTS version. Some libraries that we auto-instrument may have higher minimal requirements. -In this case we compile and test corresponding auto-instrumentation with -higher java version as required by library. The resulting classes will have -higher bytecode level, but as it matches library's java version, no runtime -problem arise. +In these cases, we compile and test the corresponding auto-instrumentation with +higher java versions as required by the libraries. The resulting classes will +have a higher bytecode level, but since it will match the library's java version, +no runtime problems arise. ## Instrumentation tests @@ -22,10 +22,11 @@ instrumented library. ### Executing tests with specific java version -We run all tests on Java 11 by default, along with Java 8 and 15. To run on the later, set the -`testJavaVersion` Gradle property to the desired major version, e.g., `./gradlew test -PtestJavaVersion=8`, -`./gradlew test -PtestJavaVersion=15`. If you don't have a JDK of these versions -installed, Gradle will automatically download it for you. +We run all tests on Java 21 by default, along with Java 8, 11, 17, and 23. To run on +a specific version, set the `testJavaVersion` gradle property to the desired major +version, e.g., `./gradlew test -PtestJavaVersion=8`, `./gradlew test -PtestJavaVersion=23`. +If you don't have a JDK of these versions installed, Gradle will automatically download +it for you. ### Executing tests against the latest versions of libraries under instrumentation @@ -36,7 +37,7 @@ To run these tests locally, add `-PtestLatestDeps=true` to your existing `gradle ### Executing single test -Executing `./gradlew :instrumentation::test --tests ` will run only the selected test. +Executing `./gradlew :instrumentation::test --tests ` will run only the selected test. ### How to prevent linting and formatting warnings from failing tests @@ -52,7 +53,7 @@ The `dev` flag will ignore warnings in tests. ## Smoke tests -The smoke tests are not run as part of a global `test` task run since they take a long time and are +The smoke tests are not run as part of a global `test` task since they take a long time and are not relevant for most contributions. Explicitly specify `:smoke-tests:test` to run them. If you need to run a specific smoke test suite: @@ -73,11 +74,10 @@ If you want to run a specific smoke test: ./gradlew :smoke-tests:test --tests '*SpringBootSmokeTest*' ``` -## Smoke OpenTelemetry starter tests +## OpenTelemetry starter smoke tests -Smoke tests for the [OpenTelemetry Spring starter](../../instrumentation/spring/starters/spring-boot-starter/README.md). - -You can execute the tests in a JVM (`./gradlew smoke-tests-otel-starter:test`) or as Spring native tests (`./gradlew smoke-tests-otel-starter:nativeTest`). +Smoke tests for the [OpenTelemetry Spring starter](../../instrumentation/spring/starters/spring-boot-starter/README.md) +can be executed in a JVM (`./gradlew smoke-tests-otel-starter:test`) or as Spring native tests (`./gradlew smoke-tests-otel-starter:nativeTest`). ## GraalVM native test @@ -100,13 +100,27 @@ old containers, images and volumes using `docker system prune --volumes`. For some container environments, such as rootless Podman or a remotely hosted Docker, testcontainers may need additional configuration to successfully run the tests. The following environment variables can be used for configuration: - - `TESTCONTAINERS_DOCKER_SOCKET_OVERRIDE` - The location of the Docker socket on the host. Default is `/var/run/docker.sock` - - `TESTCONTAINERS_HOST_OVERRIDE` - The hostname used for container-to-container communication. Default Docker is `localhost`, but rootless Podman uses `host.containers.internal` +- `TESTCONTAINERS_DOCKER_SOCKET_OVERRIDE` - The location of the Docker socket on the host. Default is `/var/run/docker.sock` +- `TESTCONTAINERS_HOST_OVERRIDE` - The hostname used for container-to-container communication. Default Docker is `localhost`, but rootless Podman uses `host.containers.internal` # Troubleshooting CI Test Failures -CI test logs are pretty big around 75MB. To make it easier to troubleshoot test failures, you can download the raw logs from the CI job and then look for -`Publishing build scan...` in the logs. Copy the URL from the logs and open it in a browser. This will give you a nice view of the test execution breakdown. +CI test logs are pretty large, sometimes exceeding 75MB. To make it easier to troubleshoot test failures, you can download or +view the raw logs from the CI job and then look for `Publishing build scan...` in the logs. There may be several occurrences +of this phrase, so look for the one that follows "BUILD FAILED". + +Example: + +``` +2025-01-01T05:06:24.8710392Z BUILD FAILED in 15m 4s +2025-01-01T05:06:24.8710682Z +2025-01-01T05:06:24.8713216Z 1121 actionable tasks: 1103 executed, 18 up-to-date +2025-01-01T05:06:25.2671952Z +2025-01-01T05:06:25.2672609Z Publishing build scan... +2025-01-01T05:06:25.4674291Z https://gradle.com/s/u4vbxhlidd5ka +``` + +Copy the gradle.com URL and open it in a browser. This will give you a nice view of the test execution breakdown. ## How to download the raw logs @@ -114,8 +128,15 @@ CI test logs are pretty big around 75MB. To make it easier to troubleshoot test 2. Click on one of the failed tests in the left panel. 3. Click on the `Setting` gear in the top right corner of the logs panel. 4. Right click on 'View raw logs' and then 'Save link as' to save the page as a text file locally. -5. Once the file is downloaded, open it in a text editor and search for `Publishing build scan...` to find the URL. +5. Once the file is downloaded, open it in a text editor and search for `Publishing build scan...` that follows an occurrence of "BUILD FAILED" to find the URL. 6. Open the URL in a browser to view the test execution breakdown. It might prompt you to "Activate your Build Scan" the very 1st time, you can use your own email address and activate it via email. Unfortunately, the Build Scan service hosted via Develocity has an allowed size limits of the free build scans. Once you exceed the limit, then you won't be able to view the scan anymore. Then you can just use the raw logs to search for "FAILED" or "Task failed with an exception" to identify the failing tests. + +# Using breakpoints in instrumentation + +For instrumentation that has been migrated to use the [invokedynamic based instrumentation mechanism](https://github.com/open-telemetry/opentelemetry-java-instrumentation/issues/8999), +you can leverage breakpoints and standard debugging strategies by adding `-PtestIndy=true` to the gradle command: + +`./gradlew -PtestIndy=true :instrumentation::test` From cc50bdb41aff7cac7b40fb98c9af22b1d73b1c1f Mon Sep 17 00:00:00 2001 From: Jay DeLuca Date: Wed, 1 Jan 2025 08:27:05 -0500 Subject: [PATCH 2/5] Update docs/contributing/running-tests.md Co-authored-by: Steve Rao --- docs/contributing/running-tests.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/contributing/running-tests.md b/docs/contributing/running-tests.md index da7678a16247..5c038e2bf161 100644 --- a/docs/contributing/running-tests.md +++ b/docs/contributing/running-tests.md @@ -77,7 +77,7 @@ If you want to run a specific smoke test: ## OpenTelemetry starter smoke tests Smoke tests for the [OpenTelemetry Spring starter](../../instrumentation/spring/starters/spring-boot-starter/README.md) -can be executed in a JVM (`./gradlew smoke-tests-otel-starter:test`) or as Spring native tests (`./gradlew smoke-tests-otel-starter:nativeTest`). +can be executed in a JVM (`./gradlew smoke-tests-otel-starter:test`) or as Spring Native tests (`./gradlew smoke-tests-otel-starter:nativeTest`). ## GraalVM native test From 758753b76a97170f5d67589adb0464a9d07def5b Mon Sep 17 00:00:00 2001 From: Jay DeLuca Date: Wed, 1 Jan 2025 08:33:50 -0500 Subject: [PATCH 3/5] Update docs/contributing/running-tests.md Co-authored-by: Steve Rao --- docs/contributing/running-tests.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/contributing/running-tests.md b/docs/contributing/running-tests.md index 5c038e2bf161..099cd64382ef 100644 --- a/docs/contributing/running-tests.md +++ b/docs/contributing/running-tests.md @@ -22,7 +22,7 @@ instrumented library. ### Executing tests with specific java version -We run all tests on Java 21 by default, along with Java 8, 11, 17, and 23. To run on +We run all tests on `Java 21` by default, along with Java 8, 11, 17, and 23. To run on a specific version, set the `testJavaVersion` gradle property to the desired major version, e.g., `./gradlew test -PtestJavaVersion=8`, `./gradlew test -PtestJavaVersion=23`. If you don't have a JDK of these versions installed, Gradle will automatically download From 961171ec882b2642248d0d646dfc79adaf541802 Mon Sep 17 00:00:00 2001 From: Jay DeLuca Date: Wed, 1 Jan 2025 08:35:00 -0500 Subject: [PATCH 4/5] Use different code block style --- docs/contributing/running-tests.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/contributing/running-tests.md b/docs/contributing/running-tests.md index 099cd64382ef..623eb556f263 100644 --- a/docs/contributing/running-tests.md +++ b/docs/contributing/running-tests.md @@ -139,4 +139,6 @@ Then you can just use the raw logs to search for "FAILED" or "Task failed with a For instrumentation that has been migrated to use the [invokedynamic based instrumentation mechanism](https://github.com/open-telemetry/opentelemetry-java-instrumentation/issues/8999), you can leverage breakpoints and standard debugging strategies by adding `-PtestIndy=true` to the gradle command: -`./gradlew -PtestIndy=true :instrumentation::test` +``` +./gradlew -PtestIndy=true :instrumentation::test +``` From 1c0edf529ceea38815543af5303b8fcd82195a7b Mon Sep 17 00:00:00 2001 From: Jay DeLuca Date: Mon, 6 Jan 2025 21:05:14 -0500 Subject: [PATCH 5/5] review notes --- CONTRIBUTING.md | 3 ++- docs/contributing/debugging.md | 11 +++++++++ docs/contributing/running-tests.md | 38 +++--------------------------- 3 files changed, 16 insertions(+), 36 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index cf8c178434a7..92d478166450 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -87,7 +87,8 @@ https://gradle.com/s/ila4qwp5lcf5s ``` Opening the build scan link can sometimes take several seconds (it's a large build), but it -typically makes it a lot clearer what's failing. +typically makes it a lot clearer what's failing. Sometimes there will be several build scans in a +log, so look for one that follows the "BUILD FAILED" message. You can also try the "Explain error" button at the top of the GitHub Actions page, which often does a reasonable job of parsing the long build log and displaying the important part. diff --git a/docs/contributing/debugging.md b/docs/contributing/debugging.md index ba9cbedce2b5..89a7d76afb65 100644 --- a/docs/contributing/debugging.md +++ b/docs/contributing/debugging.md @@ -3,6 +3,17 @@ Debugging javaagent instrumentation can be a challenging task since instrumentation code is directly inlined into target classes. +## Indy compatible instrumentation + +For instrumentation that has been migrated to use the +[invokedynamic based instrumentation mechanism](https://github.com/open-telemetry/opentelemetry-java-instrumentation/issues/8999), +you can leverage breakpoints and standard debugging strategies by adding `-PtestIndy=true` to the +gradle command when running tests: + +``` +./gradlew -PtestIndy=true :instrumentation::test +``` + ## Advice methods Breakpoints do not work in advice methods, because their code is directly inlined diff --git a/docs/contributing/running-tests.md b/docs/contributing/running-tests.md index 623eb556f263..b886ee8646a9 100644 --- a/docs/contributing/running-tests.md +++ b/docs/contributing/running-tests.md @@ -105,40 +105,8 @@ The following environment variables can be used for configuration: # Troubleshooting CI Test Failures -CI test logs are pretty large, sometimes exceeding 75MB. To make it easier to troubleshoot test failures, you can download or -view the raw logs from the CI job and then look for `Publishing build scan...` in the logs. There may be several occurrences -of this phrase, so look for the one that follows "BUILD FAILED". +See [Troubleshooting CI Test Failures](../../CONTRIBUTING.md#troubleshooting-pr-build-failures) for common issues and solutions. -Example: +# Debugging -``` -2025-01-01T05:06:24.8710392Z BUILD FAILED in 15m 4s -2025-01-01T05:06:24.8710682Z -2025-01-01T05:06:24.8713216Z 1121 actionable tasks: 1103 executed, 18 up-to-date -2025-01-01T05:06:25.2671952Z -2025-01-01T05:06:25.2672609Z Publishing build scan... -2025-01-01T05:06:25.4674291Z https://gradle.com/s/u4vbxhlidd5ka -``` - -Copy the gradle.com URL and open it in a browser. This will give you a nice view of the test execution breakdown. - -## How to download the raw logs - -1. Click on the `Details` link in one of the failing CI jobs under `Some checks were not successful` section of your PR. -2. Click on one of the failed tests in the left panel. -3. Click on the `Setting` gear in the top right corner of the logs panel. -4. Right click on 'View raw logs' and then 'Save link as' to save the page as a text file locally. -5. Once the file is downloaded, open it in a text editor and search for `Publishing build scan...` that follows an occurrence of "BUILD FAILED" to find the URL. -6. Open the URL in a browser to view the test execution breakdown. It might prompt you to "Activate your Build Scan" the very 1st time, you can use your own email address and activate it via email. - -Unfortunately, the Build Scan service hosted via Develocity has an allowed size limits of the free build scans. Once you exceed the limit, then you won't be able to view the scan anymore. -Then you can just use the raw logs to search for "FAILED" or "Task failed with an exception" to identify the failing tests. - -# Using breakpoints in instrumentation - -For instrumentation that has been migrated to use the [invokedynamic based instrumentation mechanism](https://github.com/open-telemetry/opentelemetry-java-instrumentation/issues/8999), -you can leverage breakpoints and standard debugging strategies by adding `-PtestIndy=true` to the gradle command: - -``` -./gradlew -PtestIndy=true :instrumentation::test -``` +For information on debugging tests or instrumentation, see [Debugging](debugging.md).