3

为什么这不能用 ScalaTest 2.0.M5b 编译?

import org.scalatest.matchers.MatchResult
import org.scalatest.matchers.BeMatcher
import org.scalatest.matchers.ShouldMatchers._

def sorted[T <% Ordered[T]] = new BeMatcher[Seq[T]] {
  override def apply(s: Seq[T]) =
    MatchResult(
        s match {
          case Seq(h, t@_*) => s.zip(t).forall{ case (x,y) => x < y }
          case _ => true
        },
        s + " was not sorted",
        s + " was sorted")
}

val s = Seq(1, 2, 3)
s should be (sorted[Int])

这是我得到的错误:

overloaded method value should with alternatives: (beWord: NewCollectionsSpec.this.BeWord)NewCollectionsSpec.this.ResultOfBeWordForAnyRef[scala.collection.GenSeq[Int]] <and> (notWord: 
 NewCollectionsSpec.this.NotWord)NewCollectionsSpec.this.ResultOfNotWordForAnyRef[scala.collection.GenSeq[Int]] <and> (haveWord: 
 NewCollectionsSpec.this.HaveWord)NewCollectionsSpec.this.ResultOfHaveWordForSeq[Int] <and> (rightMatcher: org.scalatest.matchers.Matcher[scala.collection.GenSeq[Int]])Unit cannot be applied to 
 (org.scalatest.matchers.Matcher[Seq[Int]])
4

2 回答 2

11

Scalatest 已经提供了这样一个匹配器:

seq shouldBe sorted

请注意,外观相似的代码

seq should be sorted

不编译。

于 2016-02-21T19:09:14.717 回答
1

s: Seq[Int]被隐式转换为SeqShouldWrapper[GenSeq[Int]]. 它没有should兼容的替代方案Matcher[Seq[Int]]。但它有def should(rightMatcher: Matcher[GenSeq[T]])。所以,如果你改变你的匹配器类型约束,一切都会编译:

def sorted[T <% Ordered[T]] = new BeMatcher[GenSeq[T]] {
  def apply(s: GenSeq[T]) =
    MatchResult(
      s match {
        case Seq(h, t@_*) => s.zip(t).forall {
          case (x, y) => x < y
        }
        case _ => true
      },
      s + " was not sorted",
      s + " was sorted")
}
于 2013-07-29T18:52:41.287 回答