Skip to content

Commit

Permalink
Support coursier scala launcher tests on Windows
Browse files Browse the repository at this point in the history
  • Loading branch information
Gedochao committed Nov 29, 2024
1 parent 0c3fbbe commit 402abec
Showing 1 changed file with 90 additions and 52 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package scala.cli.integration
import com.eed3si9n.expecty.Expecty.expect
import os.CommandResult

import java.nio.charset.Charset
import scala.jdk.CollectionConverters.IteratorHasAsScala
import scala.util.Properties

class SipScalaTests extends ScalaCliSuite with SbtTestHelper with MillTestHelper {
Expand Down Expand Up @@ -833,62 +835,98 @@ class SipScalaTests extends ScalaCliSuite with SbtTestHelper with MillTestHelper
}
}

if (!Properties.isWin) // FIXME: run this test on Windows
test("coursier scala installation works in --offline mode") {
TestInputs.empty.fromRoot { root =>
val localCache = root / "local-cache"
val localBin = root / "local-bin"
val sv = "3.5.0-RC4"
os.proc(
TestUtil.cs,
"install",
"--cache",
localCache,
"--install-dir",
localBin,
s"scala:$sv"
).call(cwd = root)
val scalaBinary: os.Path = localBin / "scala"
val fileBytes = os.read.bytes(scalaBinary)
val shebang = new String(fileBytes.takeWhile(_ != '\n'), "UTF-8")
val binaryData = fileBytes.drop(shebang.length + 1)
val execLine = new String(binaryData.takeWhile(_ != '\n'), "UTF-8")
val scriptPathRegex = """exec "([^"]+/bin/scala).*"""".r
val scalaScript = execLine match { case scriptPathRegex(extractedPath) => extractedPath }
val scalaScriptPath = os.Path(scalaScript)
val lineToChange = "eval \"${SCALA_CLI_CMD_BASH[@]}\" \\"
// FIXME: the way the scala script calls the launcher currently ignores the --debug flag
val newContent = os.read(scalaScriptPath).replace(
lineToChange,
s"""SCALA_CLI_CMD_BASH=(\"\\\"${TestUtil.cliPath}\\\"\")
|$lineToChange""".stripMargin
)
os.write.over(scalaScriptPath, newContent)
val r =
os.proc(
scalaScript,
"--offline",
"--power",
"--with-compiler",
"-e",
"println(dotty.tools.dotc.config.Properties.versionNumberString)"
).call(
cwd = root,
env = Map("COURSIER_CACHE" -> localCache.toString),
check = false // need to clean up even on failure
test("coursier scala installation works in --offline mode") {
TestInputs.empty.fromRoot { root =>
val localCache = root / "local-cache"
val localBin = root / "local-bin"
val sv = Constants.scala3NextAnnounced
os.proc(
TestUtil.cs,
"install",
"--cache",
localCache,
"--install-dir",
localBin,
s"scala:$sv"
).call(cwd = root)
val launchScalaPath: os.Path =
if (Properties.isWin) {
val batchWrapperScript: os.Path = localBin / "scala.bat"
val charset = Charset.defaultCharset().toString
val batchWrapperContent = new String(os.read.bytes(batchWrapperScript), charset)
val setCommandLine = batchWrapperContent
.lines()
.iterator()
.asScala
.toList
.find(_.startsWith("SET CMDLINE="))
.getOrElse("")
val scriptPathRegex = """SET CMDLINE="(.*\\bin\\scala\.bat)" %CMD_LINE_ARGS%""".r
val batchScript =
setCommandLine match { case scriptPathRegex(extractedPath) => extractedPath }
val batchScriptPath = os.Path(batchScript)
val oldContent = os.read(batchScriptPath)
val newContent = oldContent.replace(
"call %SCALA_CLI_CMD_WIN%",
s"""set "SCALA_CLI_CMD_WIN=${TestUtil.cliPath}"
|call %SCALA_CLI_CMD_WIN%""".stripMargin
)
// clean up cs local binaries
val csPrebuiltBinaryDir =
os.Path(scalaScript.substring(0, scalaScript.indexOf(sv) + sv.length))
try os.remove.all(csPrebuiltBinaryDir)
catch {
case ex: java.nio.file.FileSystemException =>
println(s"Failed to remove $csPrebuiltBinaryDir: $ex")
expect(newContent != oldContent)
os.write.over(batchScriptPath, newContent)
batchWrapperScript
}
expect(r.exitCode == 0)
expect(r.out.trim() == sv)
else {
val scalaBinary: os.Path = localBin / "scala"
val fileBytes = os.read.bytes(scalaBinary)
val shebang = new String(fileBytes.takeWhile(_ != '\n'), "UTF-8")
val binaryData = fileBytes.drop(shebang.length + 1)
val execLine = new String(binaryData.takeWhile(_ != '\n'), "UTF-8")
val scriptPathRegex = """exec "([^"]+/bin/scala).*"""".r
val scalaScript = execLine match { case scriptPathRegex(extractedPath) => extractedPath }
val scalaScriptPath = os.Path(scalaScript)
val lineToChange = "eval \"${SCALA_CLI_CMD_BASH[@]}\" \\"
// FIXME: the way the scala script calls the launcher currently ignores the --debug flag
val newContent = os.read(scalaScriptPath).replace(
lineToChange,
s"""SCALA_CLI_CMD_BASH=(\"\\\"${TestUtil.cliPath}\\\"\")
|$lineToChange""".stripMargin
)
os.write.over(scalaScriptPath, newContent)
scalaBinary
}
val wrapperVersion = os.proc(launchScalaPath, "version", "--cli-version")
.call(cwd = root).out.trim()
val cliVersion = os.proc(TestUtil.cli, "version", "--cli-version")
.call(cwd = root).out.trim()
expect(wrapperVersion == cliVersion)
val r =
os.proc(
launchScalaPath,
"--offline",
"--power",
"--with-compiler",
"-e",
"println(dotty.tools.dotc.config.Properties.versionNumberString)"
).call(
cwd = root,
env = Map("COURSIER_CACHE" -> localCache.toString),
check = false // need to clean up even on failure
)
// clean up cs local binaries
val csPrebuiltBinaryDir =
os.Path(launchScalaPath.toString().substring(
0,
launchScalaPath.toString().indexOf(sv) + sv.length
))
try os.remove.all(csPrebuiltBinaryDir)
catch {
case ex: java.nio.file.FileSystemException =>
println(s"Failed to remove $csPrebuiltBinaryDir: $ex")
}
expect(r.exitCode == 0)
expect(r.out.trim() == sv)
}
}

// this check is just to ensure this isn't being run for LTS RC jobs
// should be adjusted when a new LTS line is released
Expand Down

0 comments on commit 402abec

Please sign in to comment.