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
Original file line number Diff line number Diff line change
@@ -1,42 +1,24 @@
package org.scalajs.jsenv.jsdomnodejs

import scala.concurrent.Await
import scala.concurrent.duration._

import org.junit.Test

import org.scalajs.io._

import org.scalajs.jsenv._
import org.scalajs.jsenv.test.kit.TestKit

class JSDOMNodeJSEnvTest {

private val TestRunConfig = {
RunConfig()
.withInheritOut(false)
.withOnOutputStream((_, _) => ()) // ignore stdout
}

private val config = JSDOMNodeJSSuite.Config
private val kit = new TestKit(new JSDOMNodeJSEnv, 1.minute)

@Test
def historyAPIWithoutTestKit: Unit = {
assertRunSucceeds(
def historyAPI: Unit = {
kit.withRun(
"""
|console.log(window.location.href);
|window.history.pushState({}, "", "/foo");
|console.log(window.location.href);
""".stripMargin)
}

private def assertRunSucceeds(inputStr: String): Unit = {
val inputFile = MemVirtualBinaryFile.fromStringUTF8("test.js", inputStr)
val input = Input.ScriptsToLoad(List(inputFile))
val run = config.jsEnv.start(input, TestRunConfig)
try {
Await.result(run.future, config.awaitTimeout)
} finally {
run.close()
""".stripMargin) {
_.expectOut("http://localhost/\n")
.expectOut("http://localhost/foo\n")
}
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,4 @@ import org.scalajs.jsenv.test._
import org.junit.runner.RunWith

@RunWith(classOf[JSEnvSuiteRunner])
class JSDOMNodeJSSuite extends JSEnvSuite(JSDOMNodeJSSuite.Config)

object JSDOMNodeJSSuite {
val Config = {
JSEnvSuiteConfig(new JSDOMNodeJSEnv)
.withTerminateVMJSCode("__ScalaJSEnv.exitFunction(0)")
}
}
class JSDOMNodeJSSuite extends JSEnvSuite(JSEnvSuiteConfig(new JSDOMNodeJSEnv))
4 changes: 2 additions & 2 deletions project/plugins.sbt
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.0.0-M5")
addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.0.0-M6")

libraryDependencies += "org.scala-js" %% "scalajs-env-nodejs" % "1.0.0-M5"
libraryDependencies += "org.scala-js" %% "scalajs-env-nodejs" % "1.0.0-M6"

unmanagedSourceDirectories in Compile +=
baseDirectory.value.getParentFile / "jsdom-nodejs-env/src/main/scala"