Scala的“规范”BDD框架如何工作?

时间:2009-02-26 10:39:09

标签: scala bdd specs

我刚开始使用Scala,我想知道哪种语言功能允许你这样做:

"PersistentQueue" should {
  "add and remove one item" in {
    withTempFolder {
      val q = new PersistentQueue(folderName, "work", Config.fromMap(Map.empty))
      q.setup

      q.length mustEqual 0
      q.totalItems mustEqual 0
      q.bytes mustEqual 0
      q.journalSize mustEqual 0

      q.add("hello kitty".getBytes)

      q.length mustEqual 1
      q.totalItems mustEqual 1
      q.bytes mustEqual 11
      q.journalSize mustEqual 32

      new String(q.remove.get.data) mustEqual "hello kitty"

      q.length mustEqual 0
      q.totalItems mustEqual 1
      q.bytes mustEqual 0
      q.journalSize mustEqual 33

      q.close
      dumpJournal("work") mustEqual "add(11:0:hello kitty), remove"
    }
  }
}

那来自unit tests for Kestrel

这里发生了什么? "PersistentQueue" should是否意味着Scala字符串类已使用“should”方法进行了扩展,或者是否在此处发生了其他事情?我快速浏览了Scala文档,但无法查看此代码示例使用的语言功能。

1 个答案:

答案 0 :(得分:6)

看起来像向我添加String类的隐式方法。 This post有一个演示。

相关问题