aboutsummaryrefslogtreecommitdiff
path: root/integration-tests/src/main/kotlin/org/jetbrains
diff options
context:
space:
mode:
Diffstat (limited to 'integration-tests/src/main/kotlin/org/jetbrains')
-rw-r--r--integration-tests/src/main/kotlin/org/jetbrains/dokka/it/AbstractIntegrationTest.kt168
-rw-r--r--integration-tests/src/main/kotlin/org/jetbrains/dokka/it/TestOutputCopier.kt20
-rw-r--r--integration-tests/src/main/kotlin/org/jetbrains/dokka/it/gitSubmoduleUtils.kt45
-rw-r--r--integration-tests/src/main/kotlin/org/jetbrains/dokka/it/processUtils.kt55
4 files changed, 0 insertions, 288 deletions
diff --git a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/AbstractIntegrationTest.kt b/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/AbstractIntegrationTest.kt
deleted file mode 100644
index ec96ac01..00000000
--- a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/AbstractIntegrationTest.kt
+++ /dev/null
@@ -1,168 +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.it
-
-import org.jsoup.Jsoup
-import org.junit.jupiter.api.io.TempDir
-import java.io.File
-import java.net.URL
-import kotlin.test.assertEquals
-import kotlin.test.assertFalse
-import kotlin.test.assertNotNull
-import kotlin.test.assertTrue
-
-public abstract class AbstractIntegrationTest {
-
- @field:TempDir
- public lateinit var tempFolder: File
-
- public val projectDir: File get() = File(tempFolder, "project")
-
- public fun File.allDescendentsWithExtension(extension: String): Sequence<File> =
- this.walkTopDown().filter { it.isFile && it.extension == extension }
-
- public fun File.allHtmlFiles(): Sequence<File> = allDescendentsWithExtension("html")
-
- public fun File.allGfmFiles(): Sequence<File> = allDescendentsWithExtension("md")
-
- protected fun assertContainsNoErrorClass(file: File) {
- val fileText = file.readText()
- assertFalse(
- fileText.contains("ERROR CLASS", ignoreCase = true),
- "Unexpected `ERROR CLASS` in ${file.path}\n" + fileText
- )
- }
-
- protected fun assertNoEmptyLinks(file: File) {
- val regex = Regex("[\"']#[\"']")
- val fileText = file.readText()
- assertFalse(
- fileText.contains(regex),
- "Unexpected empty link in ${file.path}\n" + fileText
- )
- }
-
- protected fun assertNoUnresolvedLinks(file: File, exceptions: Set<String> = emptySet()) {
- val fileText = file.readText()
- val regex = Regex("""data-unresolved-link="\[(.+?(?=]"))""")
- val match = regex.findAll(fileText).map { it.groups[1]!!.value }
-
- assertTrue(
- match.filterNot { it in exceptions }.toList().isEmpty(),
- "Unexpected unresolved link in ${file.path}\n" + fileText
- )
- }
-
- protected fun assertNoHrefToMissingLocalFileOrDirectory(
- file: File, fileExtensions: Set<String> = setOf("html")
- ) {
- val fileText = file.readText()
- val html = Jsoup.parse(fileText)
- html.allElements.toList().forEach { element ->
- val href = element.attr("href")
- if (href.startsWith("https")) return@forEach
- if (href.startsWith("http")) return@forEach
-
- val hrefWithoutAnchors = if (href.contains("#")) {
- val hrefSplits = href.split("#")
- if (hrefSplits.count() != 2) return@forEach
- hrefSplits.first()
- } else href
-
- val targetFile = if (href.startsWith("file:/")) {
- File(URL(hrefWithoutAnchors).path)
- } else {
- File(file.parent, hrefWithoutAnchors)
- }
-
- if (targetFile.extension.isNotEmpty() && targetFile.extension !in fileExtensions) return@forEach
-
- if (targetFile.extension.isEmpty() || targetFile.extension == "html" && !href.startsWith("#")) {
- assertTrue(
- targetFile.exists(),
- "${file.relativeTo(projectDir).path}: href=\"$href\"\n" +
- "file does not exist: ${targetFile.path}"
- )
- }
- }
- }
-
- protected fun assertNoSuppressedMarker(file: File) {
- val fileText = file.readText()
- assertFalse(
- fileText.contains("§SUPPRESSED§"),
- "Unexpected `§SUPPRESSED§` in file ${file.path}"
- )
- }
-
- protected fun assertNoEmptySpans(file: File) {
- val fileText = file.readText()
- assertFalse(
- fileText.contains(Regex("""<span>\s*</span>""")),
- "Unexpected empty <span></span> in file ${file.path}"
- )
- }
-
- protected fun assertNoUnsubstitutedTemplatesInHtml(file: File) {
- val parsedFile = Jsoup.parse(file, "UTF-8")
- assertTrue(
- parsedFile.select("dokka-template-command").isEmpty(),
- "Expected all templates to be substituted"
- )
- }
-
- /**
- * Asserts that [contentFiles] have no pages where content contains special visibility markers,
- * such as §INTERNAL§ for `internal`, §PROTECTED§ for `protected` and §PRIVATE§ for `private` modifiers
- *
- * This can be used to check whether actual documented code corresponds to configured documented visibility
- *
- * @param contentFiles any readable content file such as html/md/rst/etc
- */
- protected fun assertContentVisibility(
- contentFiles: List<File>,
- documentPublic: Boolean,
- documentProtected: Boolean,
- documentInternal: Boolean,
- documentPrivate: Boolean
- ) {
- val hasPublic = contentFiles.any { file -> "§PUBLIC§" in file.readText() }
- assertEquals(documentPublic, hasPublic, "Expected content visibility and file content do not match for public")
-
- val hasInternal = contentFiles.any { file -> "§INTERNAL§" in file.readText() }
- assertEquals(
- documentInternal,
- hasInternal,
- "Expected content visibility and file content do not match for internal"
- )
-
- val hasProtected = contentFiles.any { file -> "§PROTECTED§" in file.readText() }
- assertEquals(
- documentProtected,
- hasProtected,
- "Expected content visibility and file content do not match for protected"
- )
-
- val hasPrivate = contentFiles.any { file -> "§PRIVATE§" in file.readText() }
- assertEquals(
- documentPrivate,
- hasPrivate,
- "Expected content visibility and file content do not match for private"
- )
- }
-
- /**
- * Check that [outputFiles] contain specific file paths provided in [expectedFilePaths].
- * Can be used for checking whether expected folders/pages have been created.
- */
- protected fun assertContainsFilePaths(outputFiles: List<File>, expectedFilePaths: List<Regex>) {
- expectedFilePaths.forEach { pathRegex ->
- assertNotNull(
- outputFiles.any { it.absolutePath.contains(pathRegex) },
- "Expected to find a file with path regex $pathRegex, but found nothing"
- )
- }
- }
-}
diff --git a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/TestOutputCopier.kt b/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/TestOutputCopier.kt
deleted file mode 100644
index 2e2113a9..00000000
--- a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/TestOutputCopier.kt
+++ /dev/null
@@ -1,20 +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.it
-
-import java.io.File
-import kotlin.test.AfterTest
-
-public interface TestOutputCopier {
- public val projectOutputLocation: File
-
- @AfterTest
- public fun copyToLocation() {
- System.getenv("DOKKA_TEST_OUTPUT_PATH")?.also { location ->
- println("Copying to ${File(location).absolutePath}")
- projectOutputLocation.copyRecursively(File(location))
- } ?: println("No path via env. variable 'DOKKA_TEST_OUTPUT_PATH' provided, skipping copying")
- }
-}
diff --git a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/gitSubmoduleUtils.kt b/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/gitSubmoduleUtils.kt
deleted file mode 100644
index b4c63330..00000000
--- a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/gitSubmoduleUtils.kt
+++ /dev/null
@@ -1,45 +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.it
-
-import org.eclipse.jgit.api.Git
-import org.eclipse.jgit.storage.file.FileRepositoryBuilder
-import java.io.File
-import java.nio.file.Path
-
-public fun AbstractIntegrationTest.copyAndApplyGitDiff(diffFile: File) {
- copyGitDiffFileToParent(diffFile).let(::applyGitDiffFromFile)
-}
-
-public fun AbstractIntegrationTest.copyGitDiffFileToParent(originalDiffFile: File): File =
- originalDiffFile.copyTo(File(projectDir.parent, originalDiffFile.name))
-
-public fun AbstractIntegrationTest.applyGitDiffFromFile(diffFile: File) {
- val projectGitFile = projectDir.resolve(".git")
- val git = if (projectGitFile.exists()) {
- if (projectGitFile.isFile) {
- println(".git file inside project directory exists, removing")
- removeGitFile(projectDir.toPath())
- Git.init().setDirectory(projectDir).call()
- } else {
- println(".git directory inside project directory exists, reusing")
- FileRepositoryBuilder().apply {
- isMustExist = true
- gitDir = projectDir
- }.let { Git(it.build()) }
- }
- } else {
- Git.init().setDirectory(projectDir).call()
- }
- git.apply().setPatch(diffFile.inputStream()).call()
-}
-
-private fun removeGitFile(repository: Path) =
- repository.toFile()
- .listFiles().orEmpty()
- .filter { it.name.toLowerCase() == ".git" }
- .forEach { it.delete() }
-
-
diff --git a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/processUtils.kt b/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/processUtils.kt
deleted file mode 100644
index 06b8b1e3..00000000
--- a/integration-tests/src/main/kotlin/org/jetbrains/dokka/it/processUtils.kt
+++ /dev/null
@@ -1,55 +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.it
-
-import kotlinx.coroutines.CompletableDeferred
-import kotlinx.coroutines.async
-import kotlinx.coroutines.runBlocking
-import kotlin.concurrent.thread
-
-public class ProcessResult(
- public val exitCode: Int,
- public val output: String
-)
-
-public fun Process.awaitProcessResult(): ProcessResult = runBlocking {
- val exitCode = async { awaitExitCode() }
- val output = async { awaitOutput() }
- ProcessResult(
- exitCode.await(),
- output.await()
- )
-}
-
-private suspend fun Process.awaitExitCode(): Int {
- val deferred = CompletableDeferred<Int>()
- thread {
- try {
- deferred.complete(this.waitFor())
- } catch (e: Throwable) {
- deferred.completeExceptionally(e)
- }
- }
-
- return deferred.await()
-}
-
-private suspend fun Process.awaitOutput(): String {
- val deferred = CompletableDeferred<String>()
- thread {
- try {
- var string = ""
- this.inputStream.bufferedReader().forEachLine { line ->
- println(line)
- string += line + System.lineSeparator()
- }
- deferred.complete(string)
- } catch (e: Throwable) {
- deferred.completeExceptionally(e)
- }
- }
-
- return deferred.await()
-}