枚举
enum Exhaustiveness
public enum Exhaustiveness {
Exhaustive | Partial
}
功能:此枚举类型用于指定 unordered 函数的验证模式,包含两种模式。
Exhaustive 模式要求对于验证范围内的所有桩签名,均需在验证动作中定义。
Partial 模式的要求较松,可以忽略“桩签名”在验证范围内未被验证动作定义的执行行为。
举例来说:
for (i in 0..6) {
foo.bar(i % 3)
}
// 此处验证动作将抛出异常,因为 foo.bar()在验证范围内一共执行了 6 次,而此处的验证动作仅指定了 4 次执行行为。
Verify.unordered(
@Called(foo.bar(1)).times(2),
@Called(foo.bar(2)).times(2)
)
// 此处验证动作可以成功,指定了 Partial 模式后,2 次未在验证动作中定义的执行行为将被忽略。
Verify.unordered(Partial,
@Called(foo.bar(1)).times(2),
@Called(foo.bar(2)).times(2)
)
示例:
import std.unittest.mock.*
import std.unittest.mock.mockmacro.*
class Printer {
func print(message: String): Bool { return true }
}
@Test
func test() {
let printer = mock<Printer>()
@On(printer.print(_)).returns(true)
printer.print("abc")
printer.print("xyz")
Verify.unordered(@Called(printer.print("abc")), @Called(printer.print("xyz")))
@ExpectThrows[VerificationFailedException](Verify.unordered(@Called(printer.print("abc"))))
Verify.unordered(Partial, @Called(printer.print("xyz")))
}
Exhaustive
Exhaustive
功能:要求在验证范围内的每一次“桩签名”的调用均需在验证动作中被定义。
Partial
Partial
功能:允许验证范围内存在未在验证动作中被定义的“桩签名”的调用行为。
enum MockSessionKind
public enum MockSessionKind {
| Forbidden
| Stateless
| Verifiable
}
功能:控制允许在 MockSession 使用的桩的类型。
只能验证在 Verifiable 的 Session 中创建的桩的期望。
Forbidden
Forbidden
功能:不允许使用桩。
Stateless
Stateless
功能:只允许无状态的桩。 不允许本质上有状态的操作,例如 returnsConsequively 和基数说明符( cardinality specifier, 指定预期执行次数的表达式)。
Verifiable
Verifiable
功能:允许任意桩。
enum StubMode
public enum StubMode {
| ReturnsDefaults
| SyntheticFields
}
示例:
import std.unittest.mock.*
import std.unittest.mock.mockmacro.*
import std.collection.*
class EntityGenerator {
var array: ArrayList<Int>
mut prop str: String {
get() { "generator" }
set(x) {}
}
init() {
this.array = ArrayList<Int>()
}
func getNumber(): Int { 42 }
func getOption(): Option<Int> { Some(42) }
func getHashMap(): HashMap<String, String> { HashMap() }
}
@Test
func test() {
let generator = mock<EntityGenerator>(ReturnsDefaults, SyntheticFields)
@Assert(generator.array, ArrayList<Int>())
@Assert(generator.str, "")
@Assert(generator.getNumber(), 0)
@Assert(generator.getOption(), None)
@Assert(generator.getHashMap(), HashMap<String, String>())
let list = ArrayList<Int>()
list.add(1)
list.add(2)
list.add(3)
generator.array = list
@Assert(generator.array, list)
generator.str = "unknown"
@Assert(generator.str, "unknown")
}
功能:控制桩的模式。
ReturnsDefaults
ReturnsDefaults
功能:Mock object 将为基础类型返回默认的值。用于简化 mock object 的配置步骤。
这些默认值一般为空或 0 。
支持的基础类型为:Unit, 数值类型( 如 Int64 ), option 类型, Bool, String, Array, ArrayList, HashSet, HashMap 。
SyntheticFields
SyntheticFields
功能:Mock object 会将其可变属性和字段视为可变字段。
与直接使用 SyntheticField 类似,但更简洁。
读取未初始化的字段将导致错误。