首页 > 其他 > 详细

Scala编程思想测试类AtomicTest.scala

时间:2017-11-16 23:23:24      阅读:724      评论:0      收藏:0      [点我收藏+]

Scala编程思想附录1的测试类。

package com.atomicscala
import language.implicitConversions
import java.io.FileWriter

class AtomicTest[T](val target:T) {
  val errorLog = "_AtomicTestErrors.txt"
  def tst[E](expected:E)(test: => Boolean){
    println(target)
    if(test == false) {
      val msg = "[Error] expected:\n" +
        expected
      println(msg)
      val el = new FileWriter(errorLog,true)
      el.write(target + msg + "\n")
      el.close()
  }
}
def str = // Safely convert to a string
  Option(target).getOrElse("").toString
def is(expected:String) = tst(expected) {
  expected.replaceAll("\r\n","\n") == str
}
def is[E](expected:E) = tst(expected) {
  expected == target
}
def beginsWith(exp:String) = tst(exp) {
  str.startsWith(
    exp.replaceAll("\r\n","\n"))
  }
}

object AtomicTest {
  implicit def any2Atomic[T](target:T) =
    new AtomicTest(target)
}

Scala编程思想测试类AtomicTest.scala

原文:http://www.cnblogs.com/flymercurial/p/7846689.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!