小智 10
是的,这可以做到,虽然语法有点不直观:
trait Foo { def getInt: Int }
val fooStub = stub[Foo]
(fooStub.getInt _).when().returns(1).noMoreThanOnce()
(fooStub.getInt _).when().returns(2).noMoreThanOnce()
(fooStub.getInt _).when().returns(3)
(fooStub.getInt _).when().returns(4)
assert(fooStub.getInt == 1)
assert(fooStub.getInt == 2)
assert(fooStub.getInt == 3)
// Note that it's fine that we don't call it a fourth time - calls are not verified.
Run Code Online (Sandbox Code Playgroud)
使用.noMoreThanOnce()而不是.once()很重要,否则会导致调用被验证.还有一个.noMoreThanTwice()方法,但我认为没有.noMoreThanNTimes()或任何等价物.
这里是如何做"第一次返回X,然后总是返回Y"的模拟和存根:
trait Bar { def getString: String }
val barMock = mock[Bar]
(barMock.getString _).expects().returning("X")
(barMock.getString _).expects().returning("Y").anyNumberOfTimes()
assert(barMock.getString == "X")
assert(barMock.getString == "Y")
assert(barMock.getString == "Y")
val barStub = stub[Bar]
(barStub.getString _).when().returns("x").noMoreThanOnce()
(barStub.getString _).when().returns("y")
assert(barStub.getString == "x")
assert(barStub.getString == "y")
assert(barStub.getString == "y")
Run Code Online (Sandbox Code Playgroud)
对我来说,编写不验证调用且返回值取决于输入的模拟的最佳方法是使用onCall方法 - 它需要关闭函数。默认情况下,它将仅服务第一个调用,因此请确保添加anyNumberOfTimes或一些repreted(...).
import org.scalamock.scalatest.MockFactory
trait Foo {
def getSomeValue(param1: Any, param2: Any): String
}
class Test extends MockFactory {
val fooMock = stub[Foo]
val it = Iterator.single("X") ++ Iterator.continually("Y")
(fooMock.getSomeValue _)
.expects(*, *)
.onCall((p1, p2) => it.next())
.anyNumberOfTimes
}
Run Code Online (Sandbox Code Playgroud)
现在,第一次调用fooMock.someValue(...)将返回X并且每个连续的Y.
| 归档时间: |
|
| 查看次数: |
9295 次 |
| 最近记录: |