diff --git a/src/index.ts b/src/index.ts index 16f7356..1c9e484 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,5 +1,6 @@ export { MockReadCallExpectation, + MockWriteCallExpectation, MockRevertExpectation, MockCallExpectation, MockContractController, diff --git a/src/mock-contract.ts b/src/mock-contract.ts index 34d2670..098e6cc 100644 --- a/src/mock-contract.ts +++ b/src/mock-contract.ts @@ -17,6 +17,11 @@ export type MockReadCallExpectation = { inputs: AbiParametersToPrimitiveTypes; outputs: AbiParametersToPrimitiveTypes; }; +export type MockWriteCallExpectation = { + kind: "write"; + abi: T; + inputs: AbiParametersToPrimitiveTypes; +}; export type MockRevertExpectation = { kind: "revert"; abi: T; @@ -25,6 +30,7 @@ export type MockRevertExpectation = { }; export type MockCallExpectation = | MockReadCallExpectation + | MockWriteCallExpectation | MockRevertExpectation; export type MockContractController = { @@ -97,6 +103,35 @@ export const deployMock = async ( } break; } + case "write": { + const fnSigHash = encodeFunctionData({ + abi: [call.abi as AbiFunction], + args: call.inputs, + functionName: call.abi.name, + }); + // Use a mock function to return the expected return value + if (firstCall) { + await signer.writeContract({ + address, + chain: signer.chain, + account: signer.account, + abi: abi, + functionName: "__doppelganger__mockReturns", + args: [fnSigHash, "0x"], + }); + firstCall = false; + } else { + await signer.writeContract({ + address, + chain: signer.chain, + account: signer.account, + abi: abi, + functionName: "__doppelganger__queueReturn", + args: [fnSigHash, "0x"], + }); + } + break; + } case "revert": { const fnSigHash = encodeFunctionData({ abi: [call.abi as AbiFunction],