Ilya Ryzhenkov | 8a4dad4 | 2014-07-11 20:41:53 +0400 | [diff] [blame] | 1 | package org.jetbrains.dokka.tests |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 2 | |
Alexander Udalov | 5dbadfe | 2015-01-12 12:36:54 +0300 | [diff] [blame] | 3 | import org.jetbrains.kotlin.cli.common.messages.* |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 4 | import com.intellij.openapi.util.* |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 5 | import kotlin.test.fail |
Ilya Ryzhenkov | 044308b | 2014-07-11 20:49:04 +0400 | [diff] [blame] | 6 | import org.jetbrains.dokka.* |
Dmitry Jemerov | c43a437 | 2014-12-29 20:22:43 +0100 | [diff] [blame] | 7 | import java.io.File |
Dmitry Jemerov | 69dd298 | 2014-12-30 18:47:03 +0100 | [diff] [blame] | 8 | import com.intellij.openapi.application.PathManager |
Dmitry Jemerov | 7fbff24 | 2015-01-09 18:54:06 +0100 | [diff] [blame] | 9 | import org.junit.Assert |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 10 | |
Ilya Ryzhenkov | a600080 | 2014-07-12 04:23:51 +0400 | [diff] [blame] | 11 | public fun verifyModel(vararg files: String, verifier: (DocumentationModule) -> Unit) { |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 12 | val messageCollector = object : MessageCollector { |
| 13 | override fun report(severity: CompilerMessageSeverity, message: String, location: CompilerMessageLocation) { |
| 14 | when (severity) { |
| 15 | CompilerMessageSeverity.WARNING, |
| 16 | CompilerMessageSeverity.LOGGING, |
| 17 | CompilerMessageSeverity.OUTPUT, |
| 18 | CompilerMessageSeverity.INFO, |
| 19 | CompilerMessageSeverity.ERROR -> { |
| 20 | println("$severity: $message at $location") |
| 21 | } |
| 22 | CompilerMessageSeverity.EXCEPTION -> { |
| 23 | fail("$severity: $message at $location") |
| 24 | } |
| 25 | } |
| 26 | } |
| 27 | } |
| 28 | |
Ilya Ryzhenkov | 044308b | 2014-07-11 20:49:04 +0400 | [diff] [blame] | 29 | val environment = AnalysisEnvironment(messageCollector) { |
Dmitry Jemerov | 69dd298 | 2014-12-30 18:47:03 +0100 | [diff] [blame] | 30 | val stringRoot = PathManager.getResourceRoot(javaClass<String>(), "/java/lang/String.class") |
| 31 | addClasspath(File(stringRoot)) |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 32 | addSources(files.toList()) |
| 33 | } |
| 34 | |
Dmitry Jemerov | fac6872 | 2015-01-14 20:21:49 +0100 | [diff] [blame^] | 35 | val options = DocumentationOptions(includeNonPublic = true, sourceLinks = listOf<SourceLinkDefinition>()) |
Ilya Ryzhenkov | 08e6900 | 2014-07-14 15:44:32 +0400 | [diff] [blame] | 36 | |
Ilya Ryzhenkov | 1cb3af9 | 2014-10-13 20:14:45 +0400 | [diff] [blame] | 37 | val documentation = environment.withContext { environment, session -> |
| 38 | val fragments = environment.getSourceFiles().map { session.getPackageFragment(it.getPackageFqName()) }.filterNotNull().distinct() |
Ilya Ryzhenkov | 2ebfb98 | 2014-10-13 00:19:18 +0400 | [diff] [blame] | 39 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 40 | val documentationModule = DocumentationModule("test") |
Ilya Ryzhenkov | 1cb3af9 | 2014-10-13 20:14:45 +0400 | [diff] [blame] | 41 | val documentationBuilder = DocumentationBuilder(session, options) |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 42 | with(documentationBuilder) { |
Ilya Ryzhenkov | 2ebfb98 | 2014-10-13 00:19:18 +0400 | [diff] [blame] | 43 | documentationModule.appendFragments(fragments) |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 44 | } |
| 45 | documentationBuilder.resolveReferences(documentationModule) |
| 46 | documentationModule |
Ilya Ryzhenkov | 08e6900 | 2014-07-14 15:44:32 +0400 | [diff] [blame] | 47 | } |
| 48 | verifier(documentation) |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 49 | Disposer.dispose(environment) |
| 50 | } |
| 51 | |
Dmitry Jemerov | 8ef6818 | 2014-12-30 12:36:14 +0100 | [diff] [blame] | 52 | public fun verifyOutput(path: String, outputExtension: String, outputGenerator: (DocumentationModule, StringBuilder) -> Unit) { |
Dmitry Jemerov | c43a437 | 2014-12-29 20:22:43 +0100 | [diff] [blame] | 53 | verifyModel(path) { |
| 54 | val output = StringBuilder() |
| 55 | outputGenerator(it, output) |
Dmitry Jemerov | 1ce5373 | 2015-01-13 16:19:42 +0100 | [diff] [blame] | 56 | val expectedOutput = File(path.replace(".kt", outputExtension)).readText().replace("\r\n", "\n") |
Dmitry Jemerov | 7fbff24 | 2015-01-09 18:54:06 +0100 | [diff] [blame] | 57 | Assert.assertEquals(expectedOutput, output.toString()) |
Dmitry Jemerov | c43a437 | 2014-12-29 20:22:43 +0100 | [diff] [blame] | 58 | } |
| 59 | } |
| 60 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 61 | fun StringBuilder.appendChildren(node: ContentNode): StringBuilder { |
Ilya Ryzhenkov | 778e2b3 | 2014-09-29 20:54:59 +0400 | [diff] [blame] | 62 | for (child in node.children) { |
| 63 | val childText = child.toTestString() |
| 64 | append(childText) |
| 65 | } |
| 66 | return this |
| 67 | } |
| 68 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 69 | fun StringBuilder.appendNode(node: ContentNode): StringBuilder { |
Ilya Ryzhenkov | 778e2b3 | 2014-09-29 20:54:59 +0400 | [diff] [blame] | 70 | when (node) { |
| 71 | is ContentText -> { |
| 72 | append(node.text) |
| 73 | } |
| 74 | is ContentEmphasis -> append("*").appendChildren(node).append("*") |
Ilya Ryzhenkov | 1b5f12b | 2014-12-22 20:01:01 +0300 | [diff] [blame] | 75 | is ContentBlockCode -> { |
| 76 | appendln("[code]") |
| 77 | appendChildren(node) |
| 78 | appendln() |
| 79 | appendln("[/code]") |
| 80 | } |
Ilya Ryzhenkov | bd6cddd | 2014-12-16 21:41:32 +0300 | [diff] [blame] | 81 | is ContentNodeLink -> { |
| 82 | append("[") |
| 83 | appendChildren(node) |
| 84 | append(" -> ") |
| 85 | append(node.node.toString()) |
| 86 | append("]") |
| 87 | } |
Ilya Ryzhenkov | 778e2b3 | 2014-09-29 20:54:59 +0400 | [diff] [blame] | 88 | else -> { |
| 89 | appendChildren(node) |
| 90 | } |
| 91 | } |
| 92 | return this |
| 93 | } |
| 94 | |
| 95 | fun ContentNode.toTestString(): String { |
| 96 | val node = this |
| 97 | return StringBuilder { |
| 98 | appendNode(node) |
| 99 | }.toString() |
| 100 | } |
Dmitry Jemerov | c43a437 | 2014-12-29 20:22:43 +0100 | [diff] [blame] | 101 | |
| 102 | val tempLocation = Location(File("/tmp/out")) |
| 103 | |
| 104 | object InMemoryLocationService: LocationService { |
| 105 | override fun location(node: DocumentationNode) = tempLocation; |
| 106 | } |