diff options
Diffstat (limited to 'crashbox-worker/src/test/scala/io/crashbox/ci')
3 files changed, 104 insertions, 0 deletions
diff --git a/crashbox-worker/src/test/scala/io/crashbox/ci/TestUtil.scala b/crashbox-worker/src/test/scala/io/crashbox/ci/TestUtil.scala new file mode 100644 index 0000000..eb177f8 --- /dev/null +++ b/crashbox-worker/src/test/scala/io/crashbox/ci/TestUtil.scala @@ -0,0 +1,13 @@ +package io.crashbox.ci + +import java.io.{ File, OutputStream } +import java.nio.file.Files + +object TestUtil { + + def withTempDir[A](f: File => A): A = { + val dir = Files.createTempDirectory("crashbox-test").toFile + try f(dir) finally dir.delete() + } + +} diff --git a/crashbox-worker/src/test/scala/io/crashbox/ci/build/ShellBuildersSpec.scala b/crashbox-worker/src/test/scala/io/crashbox/ci/build/ShellBuildersSpec.scala new file mode 100644 index 0000000..9419804 --- /dev/null +++ b/crashbox-worker/src/test/scala/io/crashbox/ci/build/ShellBuildersSpec.scala @@ -0,0 +1,55 @@ +package io.crashbox.ci +package build + +import java.io.{ BufferedOutputStream, ByteArrayOutputStream, File } +import java.nio.file.Files +import java.net.URL +import org.eclipse.jgit.util.Paths +import scala.concurrent.duration._ +import scala.concurrent.Await +import org.scalatest._ + +class ShellBuildersSpec extends FlatSpec with Matchers with ShellBuilders { + + val Timeout = 10.seconds + + def runScript(script: String): (Int, String, String) = { + val stdout = new ByteArrayOutputStream(4096) + val stderr = new ByteArrayOutputStream(4096) + + val result = TestUtil.withTempDir{ dir => + val exec = new File(dir, "crashbox") + exec.createNewFile() + Files.write(exec.toPath, script.getBytes) + exec.setExecutable(true) + + Await.result(build(dir, stdout, stderr), Timeout) + } + stdout.close() + stderr.close() + + (result, new String(stdout.toByteArray(), "utf-8"), new String(stderr.toByteArray(), "utf-8")) + } + + "ShellBuilders" should "run a shell script" in { + val script = """|#!/bin/sh + |echo "hello world" + |echo "foo" >&2 + |""".stripMargin + val (res, stdout, stderr) = runScript(script: String) + + assert(res == 0) + assert(stdout == "hello world\n") + assert(stderr == "foo\n") + } + + it should "report a failed script" in { + val script = """|#!/bin/sh + |exit 1 + |""".stripMargin + val (res, _, _) = runScript(script: String) + + assert(res == 1) + } + +} diff --git a/crashbox-worker/src/test/scala/io/crashbox/ci/source/GitFetchersSpec.scala b/crashbox-worker/src/test/scala/io/crashbox/ci/source/GitFetchersSpec.scala new file mode 100644 index 0000000..a0886a5 --- /dev/null +++ b/crashbox-worker/src/test/scala/io/crashbox/ci/source/GitFetchersSpec.scala @@ -0,0 +1,36 @@ +package io.crashbox.ci +package source + +import java.io.File +import java.nio.file.Files +import java.net.URL +import org.eclipse.jgit.api.Git +import scala.concurrent.duration._ +import scala.concurrent.Await +import org.scalatest._ + +class GitFetchersSpec extends FlatSpec with Matchers with GitFetchers { + + val Timeout = 10.seconds + + def makeRepo(dir: File): Unit = { + Git.init().setDirectory(dir).call() + val file1 = new File(dir, "file1") + file1.createNewFile() + val file2 = new File(dir, "file2") + file2.createNewFile() + Git.open(dir).add().addFilepattern(".").call() + Git.open(dir).commit().setMessage("initial commit").call() + } + + "GitFetchers" should "be able to clone a local repository" in { + TestUtil.withTempDir{ remote => + makeRepo(remote) + TestUtil.withTempDir { local => + val cloned = Await.result(fetch(remote.toURI().toURL(), local), Timeout) + assert(cloned.listFiles().length == 3) + } + } + } + +} |