io.mockk.GatewayAPI.kt Maven / Gradle / Ivy
package io.mockk
import kotlin.reflect.KClass
/**
* Mediates mocking implementation
*/
interface MockKGateway {
val mockFactory: MockFactory
val staticMockFactory: StaticMockFactory
val objectMockFactory: ObjectMockFactory
val stubber: Stubber
val verifier: Verifier
val callRecorder: CallRecorder
val instanceFactoryRegistry: InstanceFactoryRegistry
val clearer: Clearer
val mockInitializer: MockInitializer
fun verifier(ordering: Ordering): CallVerifier
companion object {
lateinit var implementation: () -> MockKGateway
}
/**
* Create new mocks or spies
*/
interface MockFactory {
fun mockk(
mockType: KClass,
name: String?,
relaxed: Boolean,
moreInterfaces: Array>
): T
fun spyk(
mockType: KClass?,
objToCopy: T?,
name: String?,
moreInterfaces: Array>,
recordPrivateCalls: Boolean
): T
fun temporaryMock(mockType: KClass<*>): Any
fun isMock(value: Any): Boolean
}
/**
* Binds static mocks
*/
interface StaticMockFactory {
fun staticMockk(cls: KClass<*>)
fun staticUnMockk(cls: KClass<*>)
}
/**
* Binds object mocks
*/
interface ObjectMockFactory {
fun objectMockk(obj: Any, recordPrivateCalls: Boolean)
fun objectUnMockk(obj: Any)
}
/**
* Clears mocks
*/
interface Clearer {
fun clear(
mocks: Array,
answers: Boolean,
recordedCalls: Boolean,
childMocks: Boolean
)
}
/**
* Stub calls
*/
interface Stubber {
fun every(
mockBlock: (MockKMatcherScope.() -> T)?,
coMockBlock: (suspend MockKMatcherScope.() -> T)?
): MockKStubScope
}
/**
* Verify calls
*/
interface Verifier {
fun verify(
params: VerificationParameters,
mockBlock: (MockKVerificationScope.() -> Unit)?,
coMockBlock: (suspend MockKVerificationScope.() -> Unit)?
)
}
/**
* Parameters of verification
*/
data class VerificationParameters(
val ordering: Ordering,
val min: Int,
val max: Int,
val inverse: Boolean
)
/**
* Builds a list of calls
*/
interface CallRecorder {
val calls: List
fun startStubbing()
fun startVerification(params: VerificationParameters)
fun round(n: Int, total: Int = 64)
fun matcher(matcher: Matcher<*>, cls: KClass): T
fun call(invocation: Invocation): Any?
fun answer(answer: Answer<*>)
fun done()
fun hintNextReturnType(cls: KClass<*>, n: Int)
fun reset()
fun estimateCallRounds(): Int
fun nCalls(): Int
fun wasNotCalled(list: List)
fun discardLastCallRound()
}
/**
* Verifier takes the list of calls and checks what invocations happened to the mocks
*/
interface CallVerifier {
fun verify(verificationSequence: List, min: Int, max: Int): VerificationResult
fun captureArguments()
}
/**
* Result of verification
*/
data class VerificationResult(val matches: Boolean, val message: String? = null)
interface InstanceFactoryRegistry {
fun registerFactory(factory: InstanceFactory)
fun deregisterFactory(factory: InstanceFactory)
}
/**
* Factory of dummy objects
*/
interface InstanceFactory {
fun instantiate(cls: KClass<*>): Any?
}
interface MockInitializer {
fun initAnnotatedMocks(targets: List)
}
}
interface Ref {
val value: Any
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy