2016-07-07 23 views
0

我試圖實現DRY的測試中,我得到了標題隱含的錯誤時使用ScalaCheck庫和ScalaTest爲scala檢查中的運行時類型啓用隱式導入。 「找不到參數內含價值」

測試我自己的家中自釀Monoid班階:

Error:(16, 12) could not find implicit value for parameter arbA: org.scalacheck.Arbitrary[A] 
    forAll { (a: A) => 
    ^

這裏是intAddition含半幺羣的實現:

trait Monoid[A] { 
    def op(a1: A, a2: A): A 
    def zero: A 
} 

object Monoid { 
... 
    val intAddition: Monoid[Int] = new Monoid[Int] { 
    override def op(a1: Int, a2: Int): Int = a1 + a2 
    override def zero: Int = 0 
    } 
... 
} 

而且測試套件:

import org.fpinscala.monoids.Monoid._ 
import org.fpinscala.testutils.UnitSpec 
import org.scalatest.prop.PropertyChecks 
import org.scalacheck.Arbitrary._ 

import scala.language.implicitConversions 

class MonoidSpec extends UnitSpec with PropertyChecks { 

    def assertIdentityBehaviour[A](M: Monoid[A]): Unit = { 
    import M._ 
    forAll { (a: A) => 
     op(zero, a) should be(a) 
     op(a, zero) should be(a) 
    } 
    } 

    behavior of "intAdditionMonoid" 

    it should "obey identity laws" in { 
    assertIdentityBehaviour(intAddition) 
    } 
} 

此代碼編譯但在運行時失敗(運行時類型擦除?)。 是我想在Scala中實現的可能性嗎?

回答

1

此代碼編譯

,沒有關係。你給出的錯誤是編譯錯誤。它應該是固定的,加入的隱含參數,報告說:

def assertIdentityBehaviour[A](M: Monoid[A])(implicit arbA: Arbitrary[A]) = ... 
// or equivalently, def assertIdentityBehaviour[A: Arbitrary](M: Monoid[A]) = ... 

調用assertIdentityBehaviourA用於該參數是可用的,但錯誤是在其定義

+0

我很抱歉,錯誤沒有出現在IDE中,但確實出現在sbt輸出中。一般來說我是新來的scala:P – coderatchet

相關問題