diff options
author | Jesse Luehrs <doy@tozt.net> | 2013-02-23 14:56:12 -0600 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2013-02-23 14:56:12 -0600 |
commit | 6d4f400455f40561c853393249cda97f832ce61f (patch) | |
tree | f7933ff6e2fbf9d5bde9e00544e75702c70e1d64 /src/main/scala/org/perl8/test/TestMore.scala | |
parent | 987ecfb806b140afd955a58d1834bade02c0ca2c (diff) | |
download | scala-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.scala | 27 |
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 = _ |