diff options
author | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
---|---|---|
committer | Haoyi Li <haoyi@haoyi-mbp.corp.dropbox.com> | 2014-11-26 00:45:31 -0800 |
commit | 24f31e120f9537faede7a174bb09ee35f64e1ce4 (patch) | |
tree | 06ffc3ecc7847789008352b7e2b7c040dad48907 /examples/scala-js/tools/js/src/test/scala/scala | |
parent | b89ce9cbf79363f8cab09186a5d7ba94bc0af02a (diff) | |
parent | 2c4b142503bd2d871e6818b5cab8c38627d9e4a0 (diff) | |
download | hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.tar.gz hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.tar.bz2 hands-on-scala-js-24f31e120f9537faede7a174bb09ee35f64e1ce4.zip |
Merge commit '2c4b142503bd2d871e6818b5cab8c38627d9e4a0' as 'examples/scala-js'
Diffstat (limited to 'examples/scala-js/tools/js/src/test/scala/scala')
2 files changed, 108 insertions, 0 deletions
diff --git a/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/JasmineReporter.scala b/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/JasmineReporter.scala new file mode 100644 index 0000000..7b63871 --- /dev/null +++ b/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/JasmineReporter.scala @@ -0,0 +1,71 @@ +package scala.scalajs.tools.js.test + +import org.scalajs.jasmine.Suite + +import org.scalajs.jasminetest._ + +import scala.scalajs.js.annotation.JSExport + +import scala.scalajs.testbridge._ + +object JSConsoleTestOutput extends TestOutput { + + type Color = Null + + val errorColor: Color = null + val successColor: Color = null + val infoColor: Color = null + + def color(message: String, color: Color): String = message + + def error(message: String, stack: Array[StackTraceElement]): Unit = + withStack(message, stack) + + def error(message: String): Unit = println(message) + + def failure(message: String, stack: Array[StackTraceElement]): Unit = + withStack(message, stack) + + def failure(message: String): Unit = println(message) + def succeeded(message: String): Unit = println(message) + def skipped(message: String): Unit = println(message) + def pending(message: String): Unit = println(message) + def ignored(message: String): Unit = println(message) + def canceled(message: String): Unit = println(message) + + object log extends TestOutputLog { + def info(message: String): Unit = println(message) + def warn(message: String): Unit = println(message) + def error(message: String): Unit = println(message) + } + + private def withStack(message: String, stack: Array[StackTraceElement]) = + println(message + stack.mkString("\n", "\n", "")) + +} + +@JSExport("scalajs.JasmineConsoleReporter") +class JasmineConsoleReporter(throwOnFail: Boolean = false) + extends JasmineTestReporter(JSConsoleTestOutput) { + + private var suiteFails: Int = 0 + private var suiteCount: Int = 0 + + override def reportSuiteResults(suite: Suite): Unit = { + super.reportSuiteResults(suite) + if (suite.results().failedCount > 0) + suiteFails += 1 + suiteCount += 1 + } + + override def reportRunnerResults(): Unit = { + super.reportRunnerResults() + val failed = suiteFails > 0 + val resStr = if (failed) "Failed" else "Passed" + println(s"$resStr: Total $suiteCount, Failed $suiteFails") + + if (failed && throwOnFail) + sys.error("Jasmine test suite failed.") + } + +} diff --git a/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/QuickLinker.scala b/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/QuickLinker.scala new file mode 100644 index 0000000..580c4c5 --- /dev/null +++ b/examples/scala-js/tools/js/src/test/scala/scala/scalajs/tools/js/test/QuickLinker.scala @@ -0,0 +1,37 @@ +package scala.scalajs.tools.js.test + +import scala.scalajs.tools.sem.Semantics +import scala.scalajs.tools.io._ +import scala.scalajs.tools.logging._ +import scala.scalajs.tools.classpath._ +import scala.scalajs.tools.classpath.builder._ +import scala.scalajs.tools.optimizer._ + +import scala.scalajs.js.annotation.JSExport + +@JSExport("scalajs.QuickLinker") +object QuickLinker { + + /** Link a Scala.js application on Node.js */ + @JSExport + def linkNode(cpEntries: String*): String = { + val builder = new AbstractPartialClasspathBuilder with NodeFileSystem + val cp = builder.build(cpEntries.toList) + + val complete = cp.resolve() + + val optimizer = new ScalaJSOptimizer(Semantics.Defaults.optimized) + + val out = WritableMemVirtualJSFile("out.js") + + import ScalaJSOptimizer._ + val optimized = optimizer.optimizeCP( + Inputs(complete), + OutputConfig(out), + new ScalaConsoleLogger + ) + + out.content + } + +} |