1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
package org.jetbrains.dokka.allModulesPage.templates
import kotlinx.html.a
import kotlinx.html.span
import kotlinx.html.stream.createHTML
import org.jetbrains.dokka.DokkaModuleDescriptionImpl
import org.jetbrains.dokka.allModulesPage.MultiModuleAbstractTest
import org.jetbrains.dokka.base.renderers.html.templateCommand
import org.jetbrains.dokka.base.resolvers.shared.RecognizedLinkFormat
import org.jetbrains.dokka.base.templating.ResolveLinkCommand
import org.jetbrains.dokka.links.DRI
import org.junit.Rule
import org.junit.jupiter.api.Test
import org.junit.rules.TemporaryFolder
import utils.assertHtmlEqualsIgnoringWhitespace
import java.io.File
class ResolveLinkCommandResolutionTest : MultiModuleAbstractTest() {
@get:Rule
val folder: TemporaryFolder = TemporaryFolder()
private fun configuration() = dokkaConfiguration {
modules = listOf(
DokkaModuleDescriptionImpl(
name = "module1",
relativePathToOutputDirectory = folder.root.resolve("module1"),
includes = emptySet(),
sourceOutputDirectory = folder.root.resolve("module1"),
),
DokkaModuleDescriptionImpl(
name = "module2",
relativePathToOutputDirectory = folder.root.resolve("module2"),
includes = emptySet(),
sourceOutputDirectory = folder.root.resolve("module2"),
)
)
this.outputDir = folder.root
}
@Test
fun `should resolve link to another module`() {
val testedDri = DRI(
packageName = "package2",
classNames = "Sample",
)
val link = createHTML().templateCommand(ResolveLinkCommand(testedDri)) {
span {
+"Sample"
}
}
val expected = createHTML().a {
href = "../../module2/package2/-sample/index.html"
span {
+"Sample"
}
}
val contentFile = setup(link)
val configuration = configuration()
testFromData(configuration, preserveOutputLocation = true) {
submoduleProcessingStage = {
assertHtmlEqualsIgnoringWhitespace(expected, contentFile.readText())
}
}
}
@Test
fun `should produce content when link is not resolvable`() {
val testedDri = DRI(
packageName = "not-resolvable-package",
classNames = "Sample",
)
val link = createHTML().templateCommand(ResolveLinkCommand(testedDri)) {
span {
+"Sample"
}
}
val expected = createHTML().span {
attributes["data-unresolved-link"] = testedDri.toString()
span {
+"Sample"
}
}
val contentFile = setup(link)
val configuration = configuration()
testFromData(configuration, preserveOutputLocation = true) {
submoduleProcessingStage = {
assertHtmlEqualsIgnoringWhitespace(expected, contentFile.readText())
}
}
}
fun setup(content: String): File {
folder.create()
val innerModule1 = folder.newFolder("module1", "module1")
val innerModule2 = folder.newFolder("module2", "module2")
val packageList = innerModule2.resolve("package-list")
packageList.writeText(mockedPackageListForPackages(RecognizedLinkFormat.DokkaHtml, "package2"))
val contentFile = innerModule1.resolve("index.html")
contentFile.writeText(content)
return contentFile
}
}
|