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 | |
| 3 | import org.jetbrains.jet.cli.common.messages.* |
| 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.* |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 7 | |
Ilya Ryzhenkov | a600080 | 2014-07-12 04:23:51 +0400 | [diff] [blame] | 8 | public fun verifyModel(vararg files: String, verifier: (DocumentationModule) -> Unit) { |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 9 | val messageCollector = object : MessageCollector { |
| 10 | override fun report(severity: CompilerMessageSeverity, message: String, location: CompilerMessageLocation) { |
| 11 | when (severity) { |
| 12 | CompilerMessageSeverity.WARNING, |
| 13 | CompilerMessageSeverity.LOGGING, |
| 14 | CompilerMessageSeverity.OUTPUT, |
| 15 | CompilerMessageSeverity.INFO, |
| 16 | CompilerMessageSeverity.ERROR -> { |
| 17 | println("$severity: $message at $location") |
| 18 | } |
| 19 | CompilerMessageSeverity.EXCEPTION -> { |
| 20 | fail("$severity: $message at $location") |
| 21 | } |
| 22 | } |
| 23 | } |
| 24 | } |
| 25 | |
Ilya Ryzhenkov | 044308b | 2014-07-11 20:49:04 +0400 | [diff] [blame] | 26 | val environment = AnalysisEnvironment(messageCollector) { |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 27 | addSources(files.toList()) |
| 28 | } |
| 29 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 30 | val options = DocumentationOptions(includeNonPublic = true) |
Ilya Ryzhenkov | 08e6900 | 2014-07-14 15:44:32 +0400 | [diff] [blame] | 31 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 32 | val documentation = environment.withContext { environment, module, context -> |
| 33 | val documentationModule = DocumentationModule("test") |
| 34 | val documentationBuilder = DocumentationBuilder(context, options) |
| 35 | with(documentationBuilder) { |
| 36 | documentationModule.appendFiles(environment.getSourceFiles()) |
| 37 | } |
| 38 | documentationBuilder.resolveReferences(documentationModule) |
| 39 | documentationModule |
Ilya Ryzhenkov | 08e6900 | 2014-07-14 15:44:32 +0400 | [diff] [blame] | 40 | } |
| 41 | verifier(documentation) |
Ilya Ryzhenkov | 044e1b8 | 2014-07-11 17:11:35 +0400 | [diff] [blame] | 42 | Disposer.dispose(environment) |
| 43 | } |
| 44 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 45 | fun StringBuilder.appendChildren(node: ContentNode): StringBuilder { |
Ilya Ryzhenkov | 778e2b3 | 2014-09-29 20:54:59 +0400 | [diff] [blame] | 46 | for (child in node.children) { |
| 47 | val childText = child.toTestString() |
| 48 | append(childText) |
| 49 | } |
| 50 | return this |
| 51 | } |
| 52 | |
Ilya Ryzhenkov | 11355ce | 2014-10-12 22:35:47 +0400 | [diff] [blame] | 53 | fun StringBuilder.appendNode(node: ContentNode): StringBuilder { |
Ilya Ryzhenkov | 778e2b3 | 2014-09-29 20:54:59 +0400 | [diff] [blame] | 54 | when (node) { |
| 55 | is ContentText -> { |
| 56 | append(node.text) |
| 57 | } |
| 58 | is ContentEmphasis -> append("*").appendChildren(node).append("*") |
| 59 | else -> { |
| 60 | appendChildren(node) |
| 61 | } |
| 62 | } |
| 63 | return this |
| 64 | } |
| 65 | |
| 66 | fun ContentNode.toTestString(): String { |
| 67 | val node = this |
| 68 | return StringBuilder { |
| 69 | appendNode(node) |
| 70 | }.toString() |
| 71 | } |