summaryrefslogtreecommitdiff
path: root/test/files/run/sd275.scala
blob: 8cdee3ae155e57e964a6b4c1de0aabf131d99960 (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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import scala.tools.partest._
import java.io.File

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("""
package sample {

  class A1 {
    def irrelevant: p1.p2.p3.DeleteMe = null
  }
  object A1 {
    class A1_Inner
  }
}

package p1 {
  class LeaveMe
  package p2 {
    package p3 {
      class DeleteMe
    }
  }
}
      """)
    assert(filteredInfos.isEmpty, filteredInfos)
    deletePackage("p1/p2/p3")
    deletePackage("p1/p2")

    compileCode("""
package sample

class Test {
  final class Inner extends A1.A1_Inner {
    def foo = 42
  }

  def test = new Inner().foo
}
    """)
    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())
  }
}