Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions src/test/kotlin/io/bazel/kotlin/integration/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
load("//kotlin:jvm.bzl", "kt_jvm_library", "kt_jvm_test")

kt_jvm_library(
name = "lib",
srcs = glob(
["*.kt"],
exclude = ["*Test.kt"],
),
)

kt_jvm_test(
name = "WriteWorkspaceTest",
size = "enormous",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Heh

srcs = ["WriteWorkspaceTest.kt"],
deps = [
":lib",
"@com_github_jetbrains_kotlin//:kotlin-test",
"@kotlin_rules_maven//:com_google_truth_truth",
"@kotlin_rules_maven//:junit_junit",
],
)

kt_jvm_test(
name = "MixedSourceCompileTest",
srcs = ["MixedSourceCompileTest.kt"],
resources = [
"//:rules_kotlin_release.tgz",
],
tags = ["local"], # necessary for running Bazel in a test.
test_class = "io.bazel.kotlin.integration.MixedSourceCompileTest",
deps = [
":lib",
"@com_github_jetbrains_kotlin//:kotlin-test",
"@kotlin_rules_maven//:com_google_truth_truth",
"@kotlin_rules_maven//:junit_junit",
],
)
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
package io.bazel.kotlin.integration

import com.google.common.truth.Truth
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unnecessary?

import com.google.common.truth.Truth.assertWithMessage
import io.bazel.kotlin.integration.RulesKotlinWorkspace.Companion.build
import org.junit.Test
import java.nio.file.Files

class MixedSourceCompileTest {

@Test
fun `kotlin and java sources with dependency`() {
val workspace = RulesKotlinWorkspace.write(rulesRepo = "rules_kotlin_release") {

workspace {
val (kt_register_toolchains) = load(
"@rules_kotlin_release//kotlin:core.bzl",
"kt_register_toolchains"
)
kt_register_toolchains()
}

"library" {
build {
val (ktJvmLibrary) = load("@rules_kotlin_release//kotlin:jvm.bzl", "kt_jvm_library")

ktJvmLibrary(
"name" to "library",
"srcs" to !"['Library.kt']",
"visibility" to !"['//:__subpackages__']"
)
}
kotlin("Library.kt") {
`package`("library")
`class`("Library") {}
}
}

"mixed" {
build {
val (ktJvmLibrary) = load("@rules_kotlin_release//kotlin:jvm.bzl", "kt_jvm_library")

ktJvmLibrary(
"name" to "mixed",
"srcs".list("Main.java", "Dep.kt"),
"visibility" to !"['//:__subpackages__']",
"deps".list("//library")
)
}

java("Main.java") {
`package`("mixed")

"public class Main" {
"public void run()" {
+"new Dep();"
}
}
}

kotlin("Dep.kt") {
`package`("mixed")
`class`("Dep") {}
}
}
}

val result = workspace.build("//mixed")
assertWithMessage("failed with $result").that(result.exit).isEqualTo(0)
}
}
113 changes: 113 additions & 0 deletions src/test/kotlin/io/bazel/kotlin/integration/RulesKotlinWorkspace.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,113 @@
package io.bazel.kotlin.integration

import io.bazel.kotlin.integration.WriteWorkspace.BzlWorkspace
import io.bazel.kotlin.integration.WriteWorkspace.Workspace
import java.nio.file.Files
import java.nio.file.Path
import java.nio.file.StandardOpenOption.CREATE_NEW
import java.util.concurrent.TimeUnit

class RulesKotlinWorkspace private constructor(
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we start adding some class level kdocs, at least for new types please?

private val rulesRepo: String,
private val write: Workspace
) : Workspace by write {

companion object {
fun write(
rulesRepo: String = "rules_kotlin_release",
contents: RulesKotlinWorkspace.() -> Unit
): Path {
return WriteWorkspace.using<RulesKotlinWorkspace> {
RulesKotlinWorkspace(rulesRepo, this)
.apply(contents)
}
}

fun Path.build(vararg targets: String): BuildResult {
val out = Files.createTempFile("out", "txt").toFile().apply {
deleteOnExit()
}
val err = Files.createTempFile("err", "txt").toFile().apply {
deleteOnExit()
}

return ProcessBuilder()
.command(
listOf(
"bazel",
"build",
) + targets
)
.redirectOutput(out)
.redirectError(err)
.directory(this.toFile())
.start().runCatching {
if (!waitFor(5, TimeUnit.MINUTES)) {
error("build took too long:\nout: ${out.readText(Charsets.UTF_8)}\nerr: ${err.readText(
Charsets.UTF_8
)}")
}
BuildResult(
exit = exitValue(),
out = out.readText(Charsets.UTF_8),
err = err.readText(Charsets.UTF_8)
)
}
.recover { exception ->
BuildResult(
exit = 1,
out = "",
err = exception.toString()
)
}
.getOrThrow()
}
data class BuildResult(
val exit: Int,
val out: String,
val err: String,
)
}

override fun workspace(contents: BzlWorkspace.() -> Unit) {
val rulesRepo = this.rulesRepo
val (location, archive_repository) = defineArchiveRepository()
val releaseArchive = writeReleaseArchive().toString()
write.workspace {
load(location, archive_repository)
archive_repository(
"name" to rulesRepo,
"path" to releaseArchive
)
load("@$rulesRepo//kotlin:repositories.bzl", "kotlin_repositories")
"kotlin_repositories"()
apply(contents)
}
}

private fun writeReleaseArchive(): Path {
return RulesKotlinWorkspace::class.java.classLoader.getResourceAsStream("_release.tgz")
?.let { stream ->
Files.createTempDirectory("rules_kotlin_release").resolve("$rulesRepo.tgz").also {
Files.newOutputStream(it, CREATE_NEW).buffered().write(stream.readAllBytes())
}
}
?: error("Cannot find release repo")
}

private fun defineArchiveRepository(): Pair<String, String> {
starlark("archive_repository.bzl") {
"def _archive_repository_impl"(!"repository_ctx") {
"repository_ctx.extract"(
"archive" to !"repository_ctx.attr.path",
)
}

"archive_repository=repository_rule"(
"implementation" to !"_archive_repository_impl",
"attrs" to !"{'path': attr.string()}"
)
}
return "@//:archive_repository.bzl" to "archive_repository"
}
}
Loading