diff options
author | Adriaan Moors <adriaan.moors@typesafe.com> | 2012-11-25 13:52:36 -0800 |
---|---|---|
committer | Adriaan Moors <adriaan.moors@typesafe.com> | 2012-11-25 13:52:36 -0800 |
commit | 9afc00c0408e49a111f381334cbdb7fcdaa4f340 (patch) | |
tree | 9807c35aa0bc818bf487a2c93bd577e37e1adce0 /test/files/run/t6440.scala | |
parent | 889ceade520ae5d2d1485edf2826696fa91a0e91 (diff) | |
parent | f0e9237834d00ea9e27937e44dc8b8382be32db6 (diff) | |
download | scala-9afc00c0408e49a111f381334cbdb7fcdaa4f340.tar.gz scala-9afc00c0408e49a111f381334cbdb7fcdaa4f340.tar.bz2 scala-9afc00c0408e49a111f381334cbdb7fcdaa4f340.zip |
Merge pull request #1664 from paulp/merge-2.10.x-master
Merge 2.10.x into master.
Diffstat (limited to 'test/files/run/t6440.scala')
-rw-r--r-- | test/files/run/t6440.scala | 47 |
1 files changed, 44 insertions, 3 deletions
diff --git a/test/files/run/t6440.scala b/test/files/run/t6440.scala index 2b690f31e1..5a3a4150d9 100644 --- a/test/files/run/t6440.scala +++ b/test/files/run/t6440.scala @@ -1,7 +1,48 @@ -object Test { +import scala.tools.partest._ +import java.io.File - def main(args: Array[String]): Unit = { - println(Stream.continually(()).filterNot(_ => false).take(2)) +object Test extends StoreReporterDirectTest { + def code = ??? + + def compileCode(code: String) = { + val classpath = List(sys.props("partest.lib"), testOutput.path) mkString sys.props("path.separator") + compileString(newCompiler("-cp", classpath, "-d", testOutput.path))(code) } + def library1 = """ + package pack1 + trait T + """ + + def library2 = """ + package pack2 + trait U extends pack1.T + """ + + def app = """ + package pack3 + object X { + trait U + } + import X._ + import pack2._ + + trait V extends U + """ + + def show(): Unit = { + Seq(library1, library2) foreach compileCode + assert(filteredInfos.isEmpty, filteredInfos) + + // blow away the entire package + val pack1 = new File(testOutput.path, "pack1") + val tClass = new File(pack1, "T.class") + assert(tClass.exists) + assert(tClass.delete()) + assert(pack1.delete()) + + // bad symbolic reference error expected (but no stack trace!) + compileCode(app) + println(filteredInfos.mkString("\n")) + } } |