aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/scala/org/perl8/test/TestMore.scala
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2013-02-23 14:56:12 -0600
committerJesse Luehrs <doy@tozt.net>2013-02-23 14:56:12 -0600
commit6d4f400455f40561c853393249cda97f832ce61f (patch)
treef7933ff6e2fbf9d5bde9e00544e75702c70e1d64 /src/main/scala/org/perl8/test/TestMore.scala
parent987ecfb806b140afd955a58d1834bade02c0ca2c (diff)
downloadscala-test-more-6d4f400455f40561c853393249cda97f832ce61f.tar.gz
scala-test-more-6d4f400455f40561c853393249cda97f832ce61f.zip
allow extensions to get the correct stack trace
better implementation ideas here would be nice
Diffstat (limited to 'src/main/scala/org/perl8/test/TestMore.scala')
-rw-r--r--src/main/scala/org/perl8/test/TestMore.scala27
1 files changed, 24 insertions, 3 deletions
diff --git a/src/main/scala/org/perl8/test/TestMore.scala b/src/main/scala/org/perl8/test/TestMore.scala
index fa3b6d4..487b023 100644
--- a/src/main/scala/org/perl8/test/TestMore.scala
+++ b/src/main/scala/org/perl8/test/TestMore.scala
@@ -10,6 +10,7 @@ class TestMore (plan: Option[Plan] = None) extends Test with DelayedInit {
this(Some(plan))
def delayedInit (body: => Unit) {
+ level = 0
todo = NoMessage
builder = new TestBuilder(plan, "", NoMessage)
testBody = () => body
@@ -133,9 +134,16 @@ class TestMore (plan: Option[Plan] = None) extends Test with DelayedInit {
}
private def failed (desc: Message) {
- val caller = Thread.currentThread.getStackTrace.drop(1).find(frame => {
- frame.getFileName != "TestMore.scala"
- })
+ val stack = Thread.currentThread.getStackTrace.drop(1)
+ def findIdx (level: Int, start: Int): Int = {
+ val idx = stack.indexWhere({ frame =>
+ frame.getFileName != "TestMore.scala"
+ }, start)
+
+ if (level == 0) { idx } else { findIdx(level - 1, idx + 1) }
+ }
+ val idx = findIdx(level, 0)
+ val caller = stack.drop(idx).headOption
val (file, line) = caller match {
case Some(frame) => (frame.getFileName, frame.getLineNumber)
case None => ("<unknown file>", "<unknown line>")
@@ -151,6 +159,19 @@ class TestMore (plan: Option[Plan] = None) extends Test with DelayedInit {
builder.diag(message + trace)
}
+ def withLevel[T] (newLevel: Int)(body: => T): T = {
+ val oldLevel = level
+ try {
+ // XXX "+4" is something of a hack, not sure how stable it will be
+ level += newLevel + 4
+ body
+ }
+ finally {
+ level = oldLevel
+ }
+ }
+
+ private var level: Int = _
private var todo: Message = _
private var builder: TestBuilder = _
private var testBody: () => Unit = _