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

KT-64377 use Java Test Suites for Gradle integration tests #3427

Merged
merged 40 commits into from
Feb 7, 2024

Conversation

adam-enko
Copy link
Member

@adam-enko adam-enko commented Dec 20, 2023

Restructure Gradle Integration tests to use Java Test Suites

  • create a test suite for each project under test (a separate test suite helps with Gradle caching, task avoidance, and parallelising)
  • update GitHub Action steps to run specific test-suite tasks
  • disable caching integration test tasks due to dependency on Maven Local publishing (this will be fixed in KT-64377 Maven dev publish #3433)

Contains:

@adam-enko adam-enko changed the base branch from master to KT-64377/update-integration-test-build-config December 20, 2023 14:02
@adam-enko adam-enko force-pushed the KT-64377/java-test-suites branch from 2f78af9 to 9d36bbd Compare January 15, 2024 15:50
- create a test suite for each project under test (helps with Gradle caching, task avoidance)
- update CI/CD tasks to run specific test-suite tasks
- disable integration test tasks due to dependency on Maven Local publishing (this will be fixed in an upcoming PR)
@adam-enko adam-enko force-pushed the KT-64377/java-test-suites branch from 9d36bbd to 10fe4b5 Compare January 15, 2024 16:15
@adam-enko adam-enko changed the base branch from KT-64377/update-integration-test-build-config to master January 19, 2024 14:07
# Conflicts:
#	build-logic/src/main/kotlin/dokkabuild/DokkaBuildProperties.kt
#	dokka-integration-tests/gradle/README.md
#	dokka-integration-tests/gradle/build.gradle.kts
#	dokka-integration-tests/utilities/src/main/kotlin/org/jetbrains/dokka/it/AbstractIntegrationTest.kt
@adam-enko
Copy link
Member Author

adam-enko commented Jan 22, 2024

I don't know why Publish preview to web (S3) / kotlinx-serialization is failing, the error seems unrelated.

    * Where:
    Script '/tmp/junit4521301651836114530/project/gradle/native-targets.gradle' line: 102

    * What went wrong:
    A problem occurred evaluating script.
    > No signature of method: static java.util.Arrays.compare() is applicable for argument types: ([Ljava.lang.String;, [Ljava.lang.String;, native_targets_1w0e7ne0z5gs2bcbvygztfbme$_run_closure1$_closure5$_closure8) values: [[1, 9, 0], [1, 9, 20], native_targets_1w0e7ne0z5gs2bcbvygztfbme$_run_closure1$_closure5$_closure8@64766701]

I guess this is the code that's failing https://github.com/Kotlin/kotlinx.serialization/blob/8baa04b4259274305eea6b02f5c5590b44ea126c/gradle/native-targets.gradle#L102

Is the test important?


EDIT I saw the KDoc on NonCacheableIntegrationTest and remembered about DOKKA_TEST_OUTPUT_PATH. I've added DOKKA_TEST_OUTPUT_PATH as a test-task input/output, so Gradle should re-run the tasks if required.


EDIT2

DOKKA_TEST_OUTPUT_PATH is important, but isn't relevant.

The actual problem is because KxS uses Arrays.compare(T[] a, T[] b, Comparator<? super T> cmp) in a Gradle script, but this is only available on JVM 9+. Prior to this PR all integration tests used JVM11, because that is what Coroutines required, and there was no way to set a javaLauncher per test. In this PR I split up the tests, and so Coroutines needed JVM11 but the others could use the default version. Or so I thought... and actually KxS needs JVM11 too.

Using JVM11 to test KxS is a simple fix, that's now implemented. The test should pass now.

@adam-enko adam-enko marked this pull request as ready for review January 22, 2024 11:24
@adam-enko adam-enko force-pushed the KT-64377/java-test-suites branch from 4c52c05 to 57b93cf Compare January 22, 2024 15:08
@adam-enko adam-enko force-pushed the KT-64377/java-test-suites branch from a8c8e86 to 84255e2 Compare January 23, 2024 16:37
.github/workflows/tests-thorough.yml Show resolved Hide resolved
build.gradle.kts Outdated
@@ -6,6 +6,10 @@ plugins {
id("dokkabuild.base")
}

tasks.check {
Copy link
Member

Choose a reason for hiding this comment

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

Sorry, but I strongly believe that check or test or any other similar basic task should not run anything as heavyweight / complicated as all of Dokka's "integration tests".

I don't know if the reworked tests have the same problems as the current ones, but now you are unable to run integration tests locally if you

  • didn't initialize git submodules (not done by default, fails with obscure errors like "unable to find a file")
  • don't have Android SDK installed (the android test is executed regardless)
  • have less than 32gb of ram
  • can't leave some hungry process running for 1h (I had to close my IDEs and chrome to run tests when I had 16gb of ram, and it still didn't work half the time)

If you do manage to run these tests and they fail, it's not obvious at all to external contributors or members without context as to what to do about it and how to fix it (especially if it's a false positive or is expected), so for them it's virtually useless.

Integration tests were run by default before, and it was very annoying for the reasons outlined by Oleg. I ran pretty much every build with test -x integrationTest, but it might be impossible after this change because there's no taskgraph between tasks of included builds (all the addDependencyOnSameTasksOfIncludedBuilds calls), so they will be run whether you want it or not


As a side note (not a requirement or a comment for this PR specifically, there's no need to implement it).

Ideally, I think the workflow should be the following:

  1. run basic checks locally (<= 1-2 min)
  2. push a commit that triggers more complex CI checks (smoke, <= 30m), merge the PR
  3. even more complex CI checks are triggered for every commit in master / nightly / manually (>= 30m)

This idea was mentioned in #2925 (comment):

The current integration tests take 1h+ to run, which is painful in PRs and hogs CI agents. There should be a a differentiation between "full tests" that run everything, and their subset in the form of "smoke tests", that only test specific versions (maybe only the latest) or projects (maybe only 2 out of 10 user projects). Smoke tests are intended to be run for commits in PRs, and full tests - overnight or triggered manually.

Copy link
Member

@ALikhachev ALikhachev left a comment

Choose a reason for hiding this comment

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

In general, LGTM 👍

dokka-integration-tests/gradle/build.gradle.kts Outdated Show resolved Hide resolved
dokka-integration-tests/gradle/build.gradle.kts Outdated Show resolved Hide resolved
@adam-enko adam-enko requested a review from ALikhachev January 31, 2024 12:21
@adam-enko adam-enko merged commit 19164dc into master Feb 7, 2024
13 checks passed
@adam-enko adam-enko deleted the KT-64377/java-test-suites branch February 7, 2024 11:43
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
infrastructure Everything related to builds tools, CI configurations and project tooling
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants