]> Dogcows Code - chaz/sbt-tap/commitdiff
print stack trace
authorManish Khettry <manish@ooyala.com>
Thu, 26 Apr 2012 00:39:53 +0000 (17:39 -0700)
committerManish Khettry <manish@ooyala.com>
Thu, 26 Apr 2012 00:39:53 +0000 (17:39 -0700)
src/main/scala/SbtTapReporting.scala

index c6e0068738448572f84d65eb177139faf199e7ab..45510ac640ab887139f7d1c9b8f8919a648e4995 100644 (file)
@@ -1,8 +1,8 @@
+import java.io.{PrintWriter, StringWriter, File, FileWriter}
 import sbt._
 import org.scalatools.testing.{Event => TEvent, Result => TResult}
 
 import java.util.concurrent.atomic.AtomicInteger
-import java.io.{File, FileWriter}
 
 object SbtTapReporting extends Plugin {
   lazy val tapListener = new SbtTapListener
@@ -34,10 +34,10 @@ class SbtTapListener extends TestsListener {
         case TResult.Success => writeTapFields("ok", testId.incrementAndGet(), "-", e.testName())
         case TResult.Error | TResult.Failure =>
           writeTapFields("not ok", testId.incrementAndGet(), "-", e.testName())
-          // TODO: for exceptions, write stack trace to tap file.
+          writeTapFields(stackTraceForError(e.error()))
         case TResult.Skipped =>
           // it doesn't look like this framework distinguishes between pending and ignored.
-          writeTapFields("ok", testId.incrementAndGet(), "#", "skip", e.testName())
+          writeTapFields("ok", testId.incrementAndGet(), e.testName(), "#", "skip")
       }
     }
   }
@@ -49,6 +49,12 @@ class SbtTapListener extends TestsListener {
 
   private def writeTapFields(s: Any*) { fileWriter.write(s.mkString("",  " ", "\n")) }
 
+  private def stackTraceForError(t: Throwable): String = {
+    val sw = new StringWriter()
+    val printWriter = new PrintWriter(sw)
+    t.printStackTrace(printWriter)
+    sw.toString
+  }
   def endGroup(name: String, t: Throwable) { }
 
   def endGroup(name: String, result: TestResult.Value) { }
This page took 0.022547 seconds and 4 git commands to generate.