aboutsummaryrefslogtreecommitdiff
path: root/src/test
diff options
context:
space:
mode:
Diffstat (limited to 'src/test')
-rw-r--r--src/test/scala/firrtlTests/InfoSpec.scala17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/test/scala/firrtlTests/InfoSpec.scala b/src/test/scala/firrtlTests/InfoSpec.scala
index 0a95b462..12ba9151 100644
--- a/src/test/scala/firrtlTests/InfoSpec.scala
+++ b/src/test/scala/firrtlTests/InfoSpec.scala
@@ -6,8 +6,9 @@ import firrtl._
import firrtl.ir._
import firrtl.testutils._
import FirrtlCheckers._
+import firrtl.Parser.AppendInfo
-class InfoSpec extends FirrtlFlatSpec {
+class InfoSpec extends FirrtlFlatSpec with FirrtlMatchers {
def compile(input: String): CircuitState =
(new VerilogCompiler).compileAndEmit(CircuitState(parse(input), ChirrtlForm), List.empty)
def compileBody(body: String) = {
@@ -158,4 +159,18 @@ class InfoSpec extends FirrtlFlatSpec {
result should containLine ("x <= _GEN_2 @[GCD.scala 17:22 GCD.scala 19:19]")
result should containLine ("y <= _GEN_3 @[GCD.scala 18:22 GCD.scala 19:30]")
}
+
+ "source locators for append option" should "use multiinfo" in {
+ val input = """circuit Top :
+ | module Top :
+ | input clock : Clock
+ | input in: UInt<32>
+ | output out: UInt<32>
+ | out <= in @[Top.scala 15:14]
+ |""".stripMargin
+ val circuit = firrtl.Parser.parse(input.split("\n").toIterator, AppendInfo("myfile.fir"))
+ val circuitState = CircuitState(circuit, UnknownForm)
+ val expectedInfos = Seq(FileInfo(StringLit("Top.scala 15:14")), FileInfo(StringLit("myfile.fir 6:4")))
+ circuitState should containTree { case MultiInfo(`expectedInfos`) => true }
+ }
}