aboutsummaryrefslogtreecommitdiff
path: root/plugins/base/base-test-utils/src/main
diff options
context:
space:
mode:
authorIgnat Beresnev <ignat.beresnev@jetbrains.com>2023-11-10 11:46:54 +0100
committerGitHub <noreply@github.com>2023-11-10 11:46:54 +0100
commit8e5c63d035ef44a269b8c43430f43f5c8eebfb63 (patch)
tree1b915207b2b9f61951ddbf0ff2e687efd053d555 /plugins/base/base-test-utils/src/main
parenta44efd4ba0c2e4ab921ff75e0f53fc9335aa79db (diff)
downloaddokka-8e5c63d035ef44a269b8c43430f43f5c8eebfb63.tar.gz
dokka-8e5c63d035ef44a269b8c43430f43f5c8eebfb63.tar.bz2
dokka-8e5c63d035ef44a269b8c43430f43f5c8eebfb63.zip
Restructure the project to utilize included builds (#3174)
* Refactor and simplify artifact publishing * Update Gradle to 8.4 * Refactor and simplify convention plugins and build scripts Fixes #3132 --------- Co-authored-by: Adam <897017+aSemy@users.noreply.github.com> Co-authored-by: Oleg Yukhnevich <whyoleg@gmail.com>
Diffstat (limited to 'plugins/base/base-test-utils/src/main')
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/renderers/JsoupUtils.kt79
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/renderers/RenderingOnlyTestBase.kt12
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/renderers/SignatureUtils.kt23
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/renderers/TestPage.kt59
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/testRunner/baseTestApi.kt124
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/utils/TestOutputWriter.kt47
-rw-r--r--plugins/base/base-test-utils/src/main/kotlin/utils/assertHtmlEqualsIgnoringWhitespace.kt24
7 files changed, 0 insertions, 368 deletions
diff --git a/plugins/base/base-test-utils/src/main/kotlin/renderers/JsoupUtils.kt b/plugins/base/base-test-utils/src/main/kotlin/renderers/JsoupUtils.kt
deleted file mode 100644
index fcd73ff0..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/renderers/JsoupUtils.kt
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package utils
-
-import org.jsoup.nodes.Element
-import org.jsoup.nodes.Node
-import org.jsoup.nodes.TextNode
-
-public fun Element.match(vararg matchers: Any, ignoreSpanWithTokenStyle:Boolean = false): Unit =
- childNodes()
- .let { list ->
- if(ignoreSpanWithTokenStyle) {
- list
- .filterNot { it is Element && it.tagName() == "span" && it.attr("class").startsWith("token ") && it.childNodeSize() == 0}
- .map { if(it is Element && it.tagName() == "span"
- && it.attr("class").startsWith("token ")
- && it.childNodeSize() == 1) it.childNode(0) else it }
- .uniteConsecutiveTextNodes()
- } else list
- }
- .filter { (it !is TextNode || it.text().isNotBlank())}
- .let { it.drop(it.size - matchers.size) }
- .zip(matchers)
- .forEach { (n, m) -> m.accepts(n, ignoreSpan = ignoreSpanWithTokenStyle) }
-
-public open class Tag(
- public val name: String,
- public vararg val matchers: Any,
- public val expectedClasses: List<String> = emptyList()
-)
-public class Div(vararg matchers: Any) : Tag("div", *matchers)
-public class P(vararg matchers: Any) : Tag("p", *matchers)
-public class Span(vararg matchers: Any) : Tag("span", *matchers)
-public class A(vararg matchers: Any) : Tag("a", *matchers)
-public class B(vararg matchers: Any) : Tag("b", *matchers)
-public class I(vararg matchers: Any) : Tag("i", *matchers)
-public class STRIKE(vararg matchers: Any) : Tag("strike", *matchers)
-public class BlockQuote(vararg matchers: Any) : Tag("blockquote", *matchers)
-public class Dl(vararg matchers: Any) : Tag("dl", *matchers)
-public class Dt(vararg matchers: Any) : Tag("dt", *matchers)
-public class Dd(vararg matchers: Any) : Tag("dd", *matchers)
-public class Var(vararg matchers: Any) : Tag("var", *matchers)
-public class U(vararg matchers: Any) : Tag("u", *matchers)
-public object Wbr : Tag("wbr")
-public object Br : Tag("br")
-
-public fun Tag.withClasses(vararg classes: String): Tag = Tag(name, *matchers, expectedClasses = classes.toList())
-
-private fun Any.accepts(n: Node, ignoreSpan:Boolean = true) {
- when (this) {
- is String -> assert(n is TextNode && n.text().trim() == this.trim()) { "\"$this\" expected but found: $n" }
- is Tag -> {
- check(n is Element) { "Expected node to be Element: $n" }
- assert(n.tagName() == name) { "Tag \"$name\" expected but found: \"$n\"" }
- expectedClasses.forEach {
- assert(n.hasClass(it)) { "Expected to find class \"$it\" for tag \"$name\", found: ${n.classNames()}" }
- }
- if (matchers.isNotEmpty()) n.match(*matchers, ignoreSpanWithTokenStyle = ignoreSpan)
- }
- else -> throw IllegalArgumentException("$this is not proper matcher")
- }
-}
-
-private fun List<Node>.uniteConsecutiveTextNodes(): MutableList<Node> {
- val resList = mutableListOf<Node>()
- var acc = StringBuilder()
- forEachIndexed { index, item ->
- if (item is TextNode) {
- acc.append(item.text())
- if (!(index + 1 < size && this[index + 1] is TextNode)) {
- resList.add(TextNode(acc.toString()))
- acc = StringBuilder()
- }
- } else resList.add(item)
- }
- return resList
- }
diff --git a/plugins/base/base-test-utils/src/main/kotlin/renderers/RenderingOnlyTestBase.kt b/plugins/base/base-test-utils/src/main/kotlin/renderers/RenderingOnlyTestBase.kt
deleted file mode 100644
index d2ff3ad4..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/renderers/RenderingOnlyTestBase.kt
+++ /dev/null
@@ -1,12 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package renderers
-
-import org.jetbrains.dokka.testApi.context.MockContext
-
-public abstract class RenderingOnlyTestBase<T> {
- public abstract val context: MockContext
- public abstract val renderedContent: T
-}
diff --git a/plugins/base/base-test-utils/src/main/kotlin/renderers/SignatureUtils.kt b/plugins/base/base-test-utils/src/main/kotlin/renderers/SignatureUtils.kt
deleted file mode 100644
index ecbe809b..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/renderers/SignatureUtils.kt
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package signatures
-
-import org.jsoup.Jsoup
-import org.jsoup.nodes.Element
-import org.jsoup.select.Elements
-import utils.Tag
-import utils.TestOutputWriter
-
-public fun TestOutputWriter.renderedContent(path: String = "root/example.html"): Element =
- contents.getValue(path).let { Jsoup.parse(it) }.select("#content")
- .single()
-
-public fun Element.signature(): Elements = select("div.symbol.monospace")
-public fun Element.tab(tabName: String): Elements = select("div[data-togglable=\"$tabName\"]")
-public fun Element.firstSignature(): Element = signature().first() ?: throw NoSuchElementException("No signature found")
-public fun Element.lastSignature(): Element = signature().last() ?: throw NoSuchElementException("No signature found")
-
-public class Parameters(vararg matchers: Any) : Tag("span", *matchers, expectedClasses = listOf("parameters"))
-public class Parameter(vararg matchers: Any) : Tag("span", *matchers, expectedClasses = listOf("parameter"))
diff --git a/plugins/base/base-test-utils/src/main/kotlin/renderers/TestPage.kt b/plugins/base/base-test-utils/src/main/kotlin/renderers/TestPage.kt
deleted file mode 100644
index 6fb484bf..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/renderers/TestPage.kt
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package renderers
-
-import org.jetbrains.dokka.DokkaConfiguration
-import org.jetbrains.dokka.base.signatures.KotlinSignatureProvider
-import org.jetbrains.dokka.base.transformers.pages.comments.CommentsToContentConverter
-import org.jetbrains.dokka.base.translators.documentables.PageContentBuilder
-import org.jetbrains.dokka.links.DRI
-import org.jetbrains.dokka.model.doc.DocTag
-import org.jetbrains.dokka.model.properties.PropertyContainer
-import org.jetbrains.dokka.pages.*
-import org.jetbrains.dokka.utilities.DokkaConsoleLogger
-import org.jetbrains.dokka.utilities.LoggingLevel
-
-public fun testPage(callback: PageContentBuilder.DocumentableContentBuilder.() -> Unit): RawTestPage {
- val content = PageContentBuilder(
- EmptyCommentConverter,
- KotlinSignatureProvider(EmptyCommentConverter, DokkaConsoleLogger(LoggingLevel.DEBUG)),
- DokkaConsoleLogger(LoggingLevel.DEBUG)
- ).contentFor(
- DRI.topLevel,
- emptySet(),
- block = callback
- )
-
- return RawTestPage(content)
-}
-
-public class RawTestPage(
- override val content: ContentNode,
- override val name: String = "testPage",
- override val dri: Set<DRI> = setOf(DRI.topLevel),
- override val embeddedResources: List<String> = emptyList(),
- override val children: List<PageNode> = emptyList(),
-): RootPageNode(), ContentPage {
- override fun modified(
- name: String,
- content: ContentNode,
- dri: Set<DRI>,
- embeddedResources: List<String>,
- children: List<PageNode>
- ): ContentPage = this
-
- override fun modified(name: String, children: List<PageNode>): RootPageNode = this
-
-}
-
-internal object EmptyCommentConverter : CommentsToContentConverter {
- override fun buildContent(
- docTag: DocTag,
- dci: DCI,
- sourceSets: Set<DokkaConfiguration.DokkaSourceSet>,
- styles: Set<Style>,
- extras: PropertyContainer<ContentNode>
- ): List<ContentNode> = emptyList()
-}
diff --git a/plugins/base/base-test-utils/src/main/kotlin/testRunner/baseTestApi.kt b/plugins/base/base-test-utils/src/main/kotlin/testRunner/baseTestApi.kt
deleted file mode 100644
index 3dc0e54b..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/testRunner/baseTestApi.kt
+++ /dev/null
@@ -1,124 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package org.jetbrains.dokka.base.testApi.testRunner
-
-import org.jetbrains.dokka.CoreExtensions
-import org.jetbrains.dokka.DokkaConfiguration
-import org.jetbrains.dokka.DokkaGenerator
-import org.jetbrains.dokka.base.generation.SingleModuleGeneration
-import org.jetbrains.dokka.model.DModule
-import org.jetbrains.dokka.pages.RootPageNode
-import org.jetbrains.dokka.plugability.DokkaContext
-import org.jetbrains.dokka.plugability.DokkaPlugin
-import org.jetbrains.dokka.testApi.logger.TestLogger
-import org.jetbrains.dokka.testApi.testRunner.AbstractTest
-import org.jetbrains.dokka.testApi.testRunner.CoreTestMethods
-import org.jetbrains.dokka.testApi.testRunner.DokkaTestGenerator
-import org.jetbrains.dokka.testApi.testRunner.TestBuilder
-import org.jetbrains.dokka.utilities.DokkaConsoleLogger
-import org.jetbrains.dokka.utilities.DokkaLogger
-import org.jetbrains.dokka.utilities.LoggingLevel
-
-public class BaseDokkaTestGenerator(
- configuration: DokkaConfiguration,
- logger: DokkaLogger,
- testMethods: BaseTestMethods,
- additionalPlugins: List<DokkaPlugin> = emptyList()
-) : DokkaTestGenerator<BaseTestMethods>(configuration, logger, testMethods, additionalPlugins) {
-
- override fun generate() {
- with(testMethods) {
- val dokkaGenerator = DokkaGenerator(configuration, logger)
-
- val context =
- dokkaGenerator.initializePlugins(configuration, logger, additionalPlugins)
- pluginsSetupStage(context)
-
- val singleModuleGeneration = context.single(CoreExtensions.generation) as SingleModuleGeneration
-
- val modulesFromPlatforms = singleModuleGeneration.createDocumentationModels()
- documentablesCreationStage(modulesFromPlatforms)
-
- verificationStage { singleModuleGeneration.validityCheck(context) }
-
- val filteredModules = singleModuleGeneration.transformDocumentationModelBeforeMerge(modulesFromPlatforms)
- documentablesFirstTransformationStep(filteredModules)
-
- val documentationModel = singleModuleGeneration.mergeDocumentationModels(filteredModules)
- documentablesMergingStage(documentationModel!!)
-
- val transformedDocumentation = singleModuleGeneration.transformDocumentationModelAfterMerge(documentationModel)
- documentablesTransformationStage(transformedDocumentation)
-
- val pages = singleModuleGeneration.createPages(transformedDocumentation)
- pagesGenerationStage(pages)
-
- val transformedPages = singleModuleGeneration.transformPages(pages)
- pagesTransformationStage(transformedPages)
-
- singleModuleGeneration.render(transformedPages)
- renderingStage(transformedPages, context)
-
- singleModuleGeneration.runPostActions()
-
- singleModuleGeneration.reportAfterRendering()
- }
- }
-}
-
-public data class BaseTestMethods(
- override val pluginsSetupStage: (DokkaContext) -> Unit,
- override val verificationStage: (() -> Unit) -> Unit,
- override val documentablesCreationStage: (List<DModule>) -> Unit,
- val documentablesFirstTransformationStep: (List<DModule>) -> Unit,
- override val documentablesMergingStage: (DModule) -> Unit,
- override val documentablesTransformationStage: (DModule) -> Unit,
- override val pagesGenerationStage: (RootPageNode) -> Unit,
- override val pagesTransformationStage: (RootPageNode) -> Unit,
- override val renderingStage: (RootPageNode, DokkaContext) -> Unit
-) : CoreTestMethods(
- pluginsSetupStage,
- verificationStage,
- documentablesCreationStage,
- documentablesMergingStage,
- documentablesTransformationStage,
- pagesGenerationStage,
- pagesTransformationStage,
- renderingStage,
-)
-
-public class BaseTestBuilder : TestBuilder<BaseTestMethods>() {
- public var pluginsSetupStage: (DokkaContext) -> Unit = {}
- public var verificationStage: (() -> Unit) -> Unit = {}
- public var documentablesCreationStage: (List<DModule>) -> Unit = {}
- public var preMergeDocumentablesTransformationStage: (List<DModule>) -> Unit = {}
- public var documentablesMergingStage: (DModule) -> Unit = {}
- public var documentablesTransformationStage: (DModule) -> Unit = {}
- public var pagesGenerationStage: (RootPageNode) -> Unit = {}
- public var pagesTransformationStage: (RootPageNode) -> Unit = {}
- public var renderingStage: (RootPageNode, DokkaContext) -> Unit = { _, _ -> }
-
- override fun build(): BaseTestMethods {
- return BaseTestMethods(
- pluginsSetupStage,
- verificationStage,
- documentablesCreationStage,
- preMergeDocumentablesTransformationStage,
- documentablesMergingStage,
- documentablesTransformationStage,
- pagesGenerationStage,
- pagesTransformationStage,
- renderingStage
- )
- }
-}
-
-public abstract class BaseAbstractTest(
- logger: TestLogger = TestLogger(DokkaConsoleLogger(LoggingLevel.DEBUG))
-) : AbstractTest<BaseTestMethods, BaseTestBuilder, BaseDokkaTestGenerator>(
- ::BaseTestBuilder,
- ::BaseDokkaTestGenerator,
- logger,
-)
diff --git a/plugins/base/base-test-utils/src/main/kotlin/utils/TestOutputWriter.kt b/plugins/base/base-test-utils/src/main/kotlin/utils/TestOutputWriter.kt
deleted file mode 100644
index 089a94ca..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/utils/TestOutputWriter.kt
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package utils
-
-import org.jetbrains.dokka.base.DokkaBase
-import org.jetbrains.dokka.base.renderers.OutputWriter
-import org.jetbrains.dokka.plugability.DokkaPlugin
-import org.jetbrains.dokka.plugability.DokkaPluginApiPreview
-import org.jetbrains.dokka.plugability.Extension
-import org.jetbrains.dokka.plugability.PluginApiPreviewAcknowledgement
-import java.util.*
-
-public class TestOutputWriterPlugin(failOnOverwrite: Boolean = true) : DokkaPlugin() {
- public val writer: TestOutputWriter = TestOutputWriter(failOnOverwrite)
-
- private val dokkaBase by lazy { plugin<DokkaBase>() }
-
- public val testWriter: Extension<OutputWriter, *, *> by extending {
- (dokkaBase.outputWriter
- with writer
- override dokkaBase.fileWriter)
- }
-
- @OptIn(DokkaPluginApiPreview::class)
- override fun pluginApiPreviewAcknowledgement(): PluginApiPreviewAcknowledgement =
- PluginApiPreviewAcknowledgement
-}
-
-public class TestOutputWriter(
- private val failOnOverwrite: Boolean = true
-) : OutputWriter {
- public val contents: Map<String, String> get() = _contents
- private val _contents = Collections.synchronizedMap(mutableMapOf<String, String>())
-
- override suspend fun write(path: String, text: String, ext: String) {
- val fullPath = "$path$ext"
- _contents.putIfAbsent(fullPath, text)?.also {
- if (failOnOverwrite) throw AssertionError("File $fullPath is being overwritten.")
- }
- }
-
- override suspend fun writeResources(pathFrom: String, pathTo: String) {
- write(pathTo, "*** content of $pathFrom ***", "")
- }
-}
diff --git a/plugins/base/base-test-utils/src/main/kotlin/utils/assertHtmlEqualsIgnoringWhitespace.kt b/plugins/base/base-test-utils/src/main/kotlin/utils/assertHtmlEqualsIgnoringWhitespace.kt
deleted file mode 100644
index 207ebb8a..00000000
--- a/plugins/base/base-test-utils/src/main/kotlin/utils/assertHtmlEqualsIgnoringWhitespace.kt
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
- */
-
-package utils
-
-import org.jsoup.Jsoup
-import org.jsoup.nodes.Document
-import kotlin.test.assertEquals
-
-/**
- * Parses it using JSOUP, trims whitespace at the end of the line and asserts if they are equal
- * parsing is required to unify the formatting
- */
-public fun assertHtmlEqualsIgnoringWhitespace(expected: String, actual: String) {
- val ignoreFormattingSettings = Document.OutputSettings().indentAmount(0).outline(true)
- assertEquals(
- Jsoup.parse(expected).outputSettings(ignoreFormattingSettings).outerHtml().trimSpacesAtTheEndOfLine(),
- Jsoup.parse(actual).outputSettings(ignoreFormattingSettings).outerHtml().trimSpacesAtTheEndOfLine()
- )
-}
-
-private fun String.trimSpacesAtTheEndOfLine(): String =
- replace(" \n", "\n")