blob: 4f70d13bb0fae4edea7c917364f7d28693678054 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
import scala.tools.partest._
import java.io.File
// used to crash with an assertion failure in flatten because the type symbol created for the missing
// package was a ClassSymbol, not a PackageClassSymbol
// - isFlattenablePrefix(vanishingPackage) was true (wrongly)
// - therefore flatten tried to flatten the class defined in the package, but the class is
// top-level, vanishingClass.enclosingTopLevelClass is NoSymbol
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 show(): Unit = {
compileCode("""
class Outer {
class Nested extends vanishing.Vanishing
}
package vanishing {
class Vanishing
}
""")
assert(filteredInfos.isEmpty, filteredInfos)
deletePackage("vanishing")
compileCode("""
class Test {
def f(o: Outer): Outer = o
}
""")
assert(storeReporter.infos.isEmpty, storeReporter.infos.mkString("\n")) // Included a MissingRequirementError before.
}
def deletePackage(name: String) {
val directory = new File(testOutput.path, name)
for (f <- directory.listFiles()) {
assert(f.getName.endsWith(".class"))
assert(f.delete())
}
assert(directory.listFiles().isEmpty)
assert(directory.delete())
}
}
|