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

Dokka K2 analysis #3094

Merged
merged 30 commits into from
Aug 28, 2023
Merged
Show file tree
Hide file tree
Changes from 23 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
1f4db2b
Support K2 Analysis Api
vmishenev Jul 17, 2023
6a676f8
Introduce TypeTranslator
vmishenev Jul 22, 2023
d849de8
Support samles, modules docs, external documentables, FullClassHierar…
vmishenev Jul 24, 2023
d19addc
Parse JavaDoc
vmishenev Jul 25, 2023
8245aea
Support TypeAliased
vmishenev Jul 25, 2023
b5d6d83
Refactor
vmishenev Jul 26, 2023
450aba9
Use `KtModule`
vmishenev Jul 26, 2023
43d7626
Move k2 dependencies to toml
vmishenev Jul 26, 2023
c46fd4b
Reuse tests for symbols
vmishenev Jul 26, 2023
af46f51
Format
vmishenev Jul 26, 2023
61ffac9
Fix tests of other plugins
vmishenev Jul 26, 2023
29dfeea
Reset JDK home
vmishenev Jul 26, 2023
7104e87
Add some minor docs
vmishenev Jul 26, 2023
bc7ba34
Add disposer
vmishenev Jul 28, 2023
718b7e4
Fix API
vmishenev Jul 28, 2023
44d9df7
Fix analysis disposing
vmishenev Aug 11, 2023
78bdf0b
Fix some review comments
vmishenev Aug 11, 2023
654d252
Rebase
vmishenev Aug 11, 2023
a646328
Use `KtSyntheticJavaPropertySymbol` instead of
vmishenev Aug 11, 2023
6488f86
Mute Java tests or using JDK
vmishenev Aug 11, 2023
b47a0c0
Refactor to extract function
vmishenev Aug 12, 2023
9b79b24
Support synthetic KDoc for enum members
vmishenev Aug 14, 2023
aa26380
Resolve KDoc links via Analysis API
vmishenev Aug 16, 2023
61e0309
Make some transitive dependencies `runtimeOnly`
vmishenev Aug 18, 2023
9e65b29
Fix review comments
vmishenev Aug 18, 2023
853083a
Exclude `analysis-kotlin-descriptors` from `baseTestUtils`
vmishenev Aug 18, 2023
5a227fe
Move `plugin` project
vmishenev Aug 19, 2023
8da7ce2
Extract a convention plugin for testing
vmishenev Aug 20, 2023
83d6ad4
Polish code
vmishenev Aug 24, 2023
de2426c
Mute extra tests
vmishenev Aug 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,12 @@ gradlePlugin-android = "4.2.2"
gradlePlugin-dokka = "1.8.20"

kotlinx-coroutines = "1.6.3"
kotlinx-collections-immutable = "0.3.4"
kotlinx-bcv = "0.12.1"

## Analysis
kotlin-compiler = "1.9.0"
kotlin-compiler-k2 = "1.9.0-release-358"

# MUST match the version of the intellij platform used in the kotlin compiler,
# otherwise this will lead to different versions of psi API and implementations
Expand Down Expand Up @@ -56,6 +58,7 @@ eclipse-jgit = "5.12.0.202106070339-r"
[libraries]

kotlinx-coroutines-core = { module = "org.jetbrains.kotlinx:kotlinx-coroutines-core", version.ref = "kotlinx-coroutines" }
kotlinx-collections-immutable = { module = "org.jetbrains.kotlinx:kotlinx-collections-immutable-jvm", version.ref = "kotlinx-collections-immutable" }

#### Gradle plugins ####
# The Maven coordinates of Gradle plugins that are either used in convention plugins, or in Dokka subprojects
Expand All @@ -68,6 +71,19 @@ gradlePlugin-gradlePublish= { module = "com.gradle.publish:plugin-publish-plugin
#### Kotlin analysis ####
kotlin-compiler = { module = "org.jetbrains.kotlin:kotlin-compiler", version.ref = "kotlin-compiler" }

###### K2 analysis ######
kotlin-compiler-k2 = { module = "org.jetbrains.kotlin:kotlin-compiler", version.ref = "kotlin-compiler-k2" }
kotlin-high-level-api-api = { module = "org.jetbrains.kotlin:high-level-api-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-high-level-api-impl = { module = "org.jetbrains.kotlin:high-level-api-impl-base-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-high-level-api-fir = { module = "org.jetbrains.kotlin:high-level-api-fir-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-high-level-api-fe10 = { module = "org.jetbrains.kotlin:high-level-api-fe10-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-low-level-api-fir = { module = "org.jetbrains.kotlin:low-level-api-fir-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-analysis-project-structure = { module = "org.jetbrains.kotlin:analysis-project-structure-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-analysis-api-standalone = { module = "org.jetbrains.kotlin:analysis-api-standalone-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-analysis-api-providers = { module = "org.jetbrains.kotlin:analysis-api-providers-for-ide", version.ref = "kotlin-compiler-k2" }
kotlin-symbol-light-classes = { module = "org.jetbrains.kotlin:symbol-light-classes-for-ide", version.ref = "kotlin-compiler-k2" }


#### Java analysis ####
intellij-java-psi-api = { module = "com.jetbrains.intellij.java:java-psi", version.ref = "intellij-platform" }
intellij-java-psi-impl = { module = "com.jetbrains.intellij.java:java-psi-impl", version.ref = "intellij-platform" }
Expand Down
1 change: 1 addition & 0 deletions plugins/all-modules-page/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,5 @@ dependencies {
testImplementation(projects.core.testApi)
testImplementation(platform(libs.junit.bom))
testImplementation(libs.junit.jupiter)
testRuntimeOnly(project(path = ":subprojects:analysis-kotlin-descriptors", configuration = "shadow"))
IgnatBeresnev marked this conversation as resolved.
Show resolved Hide resolved
}
1 change: 1 addition & 0 deletions plugins/android-documentation/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ dependencies {
testImplementation(projects.core.testApi)
testImplementation(platform(libs.junit.bom))
testImplementation(libs.junit.jupiter)
testRuntimeOnly(project(path = ":subprojects:analysis-kotlin-descriptors", configuration = "shadow"))
}

registerDokkaArtifactPublication("androidDocumentationPlugin") {
Expand Down
3 changes: 2 additions & 1 deletion plugins/base/base-test-utils/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@ dependencies {
api(projects.subprojects.analysisKotlinApi)

// TODO [beresnev] analysis switcher
runtimeOnly(project(path = ":subprojects:analysis-kotlin-descriptors", configuration = "shadow"))
//runtimeOnly(project(path = ":subprojects:analysis-kotlin-symbols", configuration = "shadow"))
//runtimeOnly(project(path = ":subprojects:analysis-kotlin-descriptors", configuration = "shadow"))
Copy link
Member

Choose a reason for hiding this comment

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

I believe removing this line will break 3rd party plugins, even for K1, as their tests will have no analysis implementation. It's worth checking or reverting it to play it safe.


implementation(kotlin("reflect"))

Expand Down
34 changes: 34 additions & 0 deletions plugins/base/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,40 @@ dependencies {
}
}

val descriptorsTestConfiguration: Configuration by configurations.creating {
extendsFrom(configurations.testImplementation.get())
}
val symbolsTestConfiguration: Configuration by configurations.creating {
extendsFrom(configurations.testImplementation.get())
}

dependencies {
symbolsTestConfiguration(project(path = ":subprojects:analysis-kotlin-symbols", configuration = "shadow"))
descriptorsTestConfiguration(project(path = ":subprojects:analysis-kotlin-descriptors", configuration = "shadow"))
}


val symbolsTest = tasks.register<Test>("symbolsTest") {
useJUnitPlatform {
excludeTags("onlyDescriptors", "onlyDescriptorsMPP", "javaCode", "usingJDK")
}
classpath += symbolsTestConfiguration
}
// run symbols and descriptors tests
tasks.test {
//enabled = false
classpath += descriptorsTestConfiguration
dependsOn(symbolsTest)
}

val descriptorsTest = tasks.register<Test>("descriptorsTest") {
classpath += descriptorsTestConfiguration
}

tasks.check {
dependsOn(symbolsTest)
}

// access the frontend files via the dependency on :plugins:base:frontend
val dokkaHtmlFrontendFiles: Provider<FileCollection> =
configurations.dokkaHtmlFrontendFiles.map { frontendFiles ->
Expand Down
1 change: 1 addition & 0 deletions plugins/base/src/test/kotlin/basic/DRITest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import org.jetbrains.dokka.pages.ClasslikePageNode
import org.jetbrains.dokka.pages.ContentPage
import org.jetbrains.dokka.pages.MemberPageNode
import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Tag
import org.junit.jupiter.api.Test

class DRITest : BaseAbstractTest() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,7 @@ import org.jetbrains.dokka.pages.ContentText
import org.jetbrains.dokka.pages.MemberPageNode
import org.jetbrains.dokka.pages.PackagePageNode
import org.junit.jupiter.api.Test
import utils.ParamAttributes
import utils.assertNotNull
import utils.bareSignature
import utils.propertySignature
import utils.*
import kotlin.test.assertEquals
import kotlin.test.assertTrue

Expand Down Expand Up @@ -318,6 +315,7 @@ class ContentForAnnotationsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `annotated bounds in Java`() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,12 @@ import org.jetbrains.dokka.model.properties.WithExtraProperties
import org.jetbrains.dokka.pages.ContentPage
import org.jetbrains.dokka.pages.ContentStyle
import org.junit.jupiter.api.Test
import utils.JavaCode
import utils.pWrapped
import kotlin.test.assertEquals
import kotlin.test.assertTrue

@JavaCode
class JavaDeprecatedTest : BaseAbstractTest() {

private val testConfiguration = dokkaConfiguration {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,7 @@ import org.jetbrains.dokka.base.DokkaBase
import org.jetbrains.dokka.base.testApi.testRunner.BaseAbstractTest
import org.jetbrains.dokka.model.DisplaySourceSet
import org.junit.jupiter.api.Test
import utils.ParamAttributes
import utils.bareSignature
import utils.findTestType
import utils.*
import kotlin.test.assertEquals

class ContentForExceptions : BaseAbstractTest() {
Expand Down Expand Up @@ -55,6 +53,7 @@ class ContentForExceptions : BaseAbstractTest() {
)
}

@OnlyDescriptors("Fixed in 1.9.20 (IMPORT STAR)")
@Test
fun `function with navigatable thrown exception`() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import org.jetbrains.dokka.PluginConfigurationImpl
import org.jetbrains.dokka.base.DokkaBase
import org.jetbrains.dokka.base.testApi.testRunner.BaseAbstractTest
import org.junit.jupiter.api.Test
import utils.OnlyDescriptors
import utils.classSignature
import utils.findTestType
import kotlin.test.assertEquals
Expand Down Expand Up @@ -128,6 +129,7 @@ class ContentForInheritorsTest : BaseAbstractTest() {
}
}

@OnlyDescriptors("Order of inheritors is different in K2")
@Test
fun `interface with few inheritors has table in description`() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -242,6 +242,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `deprecated with multiple links inside`() {
testInline(
Expand Down Expand Up @@ -346,6 +347,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `deprecated with an multiple inline links`() {
testInline(
Expand Down Expand Up @@ -410,6 +412,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `multiline throws with comment`() {
testInline(
Expand Down Expand Up @@ -473,6 +476,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@OnlyDescriptors("Fixed in 1.9.20 (IMPORT STAR)")
@Test
fun `multiline kotlin throws with comment`() {
testInline(
Expand Down Expand Up @@ -590,6 +594,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `multiline throws where exception is not in the same line as description`() {
testInline(
Expand Down Expand Up @@ -673,6 +678,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}


@JavaCode
@Test
fun `documentation splitted in 2 using enters`() {
testInline(
Expand Down Expand Up @@ -718,6 +724,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `multiline return tag with param`() {
testInline(
Expand Down Expand Up @@ -783,6 +790,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@UsingJDK
@Test
fun `return tag in kotlin`() {
testInline(
Expand Down Expand Up @@ -830,6 +838,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun `list with links and description`() {
testInline(
Expand Down Expand Up @@ -1476,6 +1485,7 @@ class ContentForParamsTest : BaseAbstractTest() {
}
}

@JavaCode
@Test
fun javaDocCommentWithDocumentedParameters() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -171,6 +171,7 @@ class ContentForSeeAlsoTest : BaseAbstractTest() {
}
}

@OnlyDescriptors("No link for `abc` in K1")
@Test
fun `undocumented seealso with reference to parameter for class`() {
testInline(
Expand Down Expand Up @@ -201,7 +202,7 @@ class ContentForSeeAlsoTest : BaseAbstractTest() {
header(4) { +"See also" }
table {
group {
+"abc"
+"abc" // link { +"abc" }
}
}
}
Expand Down Expand Up @@ -751,6 +752,7 @@ class ContentForSeeAlsoTest : BaseAbstractTest() {
}
}

@OnlyDescriptorsMPP
@Test
fun `multiplatform class with seealso in few platforms`() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import org.jetbrains.dokka.base.testApi.testRunner.BaseAbstractTest
import org.jetbrains.dokka.pages.BasicTabbedContentType
import org.jetbrains.dokka.pages.ContentPage
import org.junit.jupiter.api.Test
import utils.OnlyDescriptors

class ConstructorsSignaturesTest : BaseAbstractTest() {
private val testConfiguration = dokkaConfiguration {
Expand Down Expand Up @@ -157,6 +158,7 @@ class ConstructorsSignaturesTest : BaseAbstractTest() {
}
}

@OnlyDescriptors("Order of constructors is different in K2")
@Test
fun `class with a parameterless secondary constructor`() {
testInline(
Expand Down Expand Up @@ -227,6 +229,7 @@ class ConstructorsSignaturesTest : BaseAbstractTest() {
}


@OnlyDescriptors("Order of constructors is different in K2")
@Test
fun `class with a few documented constructors`() {
testInline(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,10 @@ import org.junit.jupiter.api.Test
import org.junit.jupiter.params.ParameterizedTest
import org.junit.jupiter.params.provider.MethodSource
import testApi.testRunner.dokkaConfiguration
import utils.JavaCode
import kotlin.test.assertEquals

@JavaCode
class JavaVisibilityFilterTest : BaseAbstractTest() {

@Test
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import org.jetbrains.dokka.model.GenericTypeConstructor
import org.jetbrains.dokka.model.Invariance
import org.junit.jupiter.api.Assertions
import org.junit.jupiter.api.Test
import utils.OnlyDescriptors

class KotlinArrayDocumentableReplacerTest : BaseAbstractTest() {
private val configuration = dokkaConfiguration {
Expand Down Expand Up @@ -157,6 +158,8 @@ class KotlinArrayDocumentableReplacerTest : BaseAbstractTest() {
}
}
}

@OnlyDescriptors("Fix module.contentScope in new Standalone API") // TODO fix module.contentScope [getKtModuleForKtElement]
@Test
fun `no jvm source set`() {
val configurationWithNoJVM = dokkaConfiguration {
Expand All @@ -167,7 +170,7 @@ class KotlinArrayDocumentableReplacerTest : BaseAbstractTest() {
}
sourceSet {
sourceRoots = listOf("src/main/kotlin/basic/TestJS.kt")
analysisPlatform = "js"
analysisPlatform = "jvm"
vmishenev marked this conversation as resolved.
Show resolved Hide resolved
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ import org.jetbrains.dokka.pages.*
import org.jsoup.Jsoup
import org.junit.jupiter.api.Assertions
import org.junit.jupiter.api.Test
import utils.OnlyDescriptors
import utils.OnlyDescriptorsMPP
import utils.TestOutputWriterPlugin
import utils.assertNotNull
import java.net.URL
Expand All @@ -18,6 +20,7 @@ import kotlin.test.assertEquals

class LinkableContentTest : BaseAbstractTest() {

@OnlyDescriptorsMPP
@Test
fun `Include module and package documentation`() {

Expand Down Expand Up @@ -143,6 +146,7 @@ class LinkableContentTest : BaseAbstractTest() {
}
}

@OnlyDescriptorsMPP
@Test
fun `Samples multiplatform documentation`() {

Expand Down
2 changes: 2 additions & 0 deletions plugins/base/src/test/kotlin/linking/EnumValuesLinkingTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,13 @@ import org.jsoup.Jsoup
import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Assertions.assertNotNull
import org.junit.jupiter.api.Test
import utils.OnlyDescriptors
import utils.TestOutputWriterPlugin
import java.nio.file.Paths

class EnumValuesLinkingTest : BaseAbstractTest() {

@OnlyDescriptors // TODO
@Test
fun `check if enum values are correctly linked`() {
val writerPlugin = TestOutputWriterPlugin()
Expand Down
2 changes: 2 additions & 0 deletions plugins/base/src/test/kotlin/markdown/LinkTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,10 @@ import org.jetbrains.dokka.pages.MemberPageNode
import org.junit.jupiter.api.Assertions.assertEquals
import org.junit.jupiter.api.Assertions.assertNotNull
import org.junit.jupiter.api.Test
import utils.UsingJDK

class LinkTest : BaseAbstractTest() {
@UsingJDK
@Test
fun linkToClassLoader() {
val configuration = dokkaConfiguration {
Expand Down
Loading