Skip to content

Commit

Permalink
Disable i19170b on Windows (#19471)
Browse files Browse the repository at this point in the history
This is currently broken on the `main` branch.

This fails due to a different exception in Windows. In that case it is
not obvious how the heuristic can identify a probable classpath issue.
  • Loading branch information
jchyb authored Jan 18, 2024
2 parents 2c388fa + a7f514a commit e64a5a5
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 6 deletions.
2 changes: 1 addition & 1 deletion staging/src/scala/quoted/staging/QuoteDriver.scala
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ private class QuoteDriver(appClassloader: ClassLoader) extends Driver:
try method.invoke(inst).asInstanceOf[T]
catch case ex: java.lang.reflect.InvocationTargetException =>
ex.getCause match
case ex: java.lang.NoClassDefFoundError =>
case _: java.lang.NoClassDefFoundError =>
throw new Exception(
s"""`scala.quoted.staging.run` failed to load a class.
|The classloader used for the `staging.Compiler` instance might not be the correct one.
Expand Down
11 changes: 6 additions & 5 deletions tests/run-staging/i19170b.scala
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,10 @@ class A(i: Int)
def f(i: Expr[Int])(using Quotes): Expr[A] = { '{ new A($i) } }

@main def Test = {
try
val g: Int => A = staging.run { '{ (i: Int) => ${ f('{i}) } } }
println(g(3))
catch case ex: Exception =>
assert(ex.getMessage().startsWith("`scala.quoted.staging.run` failed to load a class."))
if !System.getProperty("os.name").contains("Windows") then
try
val g: Int => A = staging.run { '{ (i: Int) => ${ f('{i}) } } }
println(g(3))
catch case ex: Exception =>
assert(ex.getMessage().startsWith("`scala.quoted.staging.run` failed to load a class."), ex.getMessage())
}

0 comments on commit e64a5a5

Please sign in to comment.