aboutsummaryrefslogtreecommitdiff
path: root/src/test/scala/firrtlTests/annotationTests/TargetDirAnnotationSpec.scala
blob: 8f157131dec4a938bc54fa69589227332a099bd2 (plain)
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
61
62
63
64
65
66
67
68
69
70
// See LICENSE for license details.

package firrtlTests
package annotationTests

import firrtlTests._
import firrtl._
import firrtl.stage.TargetDirAnnotation

/** Looks for [[TargetDirAnnotation]] */
class FindTargetDirTransform(expected: String) extends Transform {
  def inputForm = HighForm
  def outputForm = HighForm
  var foundTargetDir = false
  var run = false
  def execute(state: CircuitState): CircuitState = {
    run = true
    state.annotations.collectFirst {
      case TargetDirAnnotation(expected) =>
        foundTargetDir = true
    }
    state
  }
}

class TargetDirAnnotationSpec extends FirrtlFlatSpec {
  behavior of "The target directory"

  val input =
    """circuit Top :
      |  module Top :
      |    input foo : UInt<32>
      |    output bar : UInt<32>
      |    bar <= foo
      """.stripMargin
  val targetDir = "a/b/c"

  it should "be available as an annotation when using execution options" in {
    val findTargetDir = new FindTargetDirTransform(targetDir) // looks for the annotation

    val optionsManager = new ExecutionOptionsManager("TargetDir") with HasFirrtlOptions {
      commonOptions = commonOptions.copy(targetDirName = targetDir,
                                         topName = "Top")
      firrtlOptions = firrtlOptions.copy(compilerName = "high",
                                         firrtlSource = Some(input),
                                         customTransforms = Seq(findTargetDir))
    }
    Driver.execute(optionsManager)

    // Check that FindTargetDirTransform transform is run and finds the annotation
    findTargetDir.run should be (true)
    findTargetDir.foundTargetDir should be (true)

    // Delete created directory
    val dir = new java.io.File(targetDir)
    dir.exists should be (true)
    FileUtils.deleteDirectoryHierarchy("a") should be (true)
  }

  it should "NOT be available as an annotation when using a raw compiler" in {
    val findTargetDir = new FindTargetDirTransform(targetDir) // looks for the annotation
    val compiler = new VerilogCompiler
    val circuit = Parser.parse(input split "\n")
    compiler.compileAndEmit(CircuitState(circuit, HighForm), Seq(findTargetDir))

    // Check that FindTargetDirTransform does not find the annotation
    findTargetDir.run should be (true)
    findTargetDir.foundTargetDir should be (false)
  }
}