Skip to content

Commit

Permalink
Merge pull request #1318 from privacy-scaling-explorations/fix/user-s…
Browse files Browse the repository at this point in the history
…ignup-tests

fix(contracts): use for-loop instead of async promise
  • Loading branch information
0xmad authored Mar 20, 2024
2 parents 413ac50 + ccb2c14 commit 1ad9dd8
Showing 1 changed file with 29 additions and 27 deletions.
56 changes: 29 additions & 27 deletions contracts/tests/MACI.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,36 +80,38 @@ describe("MACI", () => {
it("should sign up multiple users", async () => {
const iface = maciContract.interface;

await Promise.all(
users.map(async (user, index) => {
const tx = await maciContract.signUp(
user.pubKey.asContractParam(),
AbiCoder.defaultAbiCoder().encode(["uint256"], [1]),
AbiCoder.defaultAbiCoder().encode(["uint256"], [0]),
signUpTxOpts,
);
const receipt = await tx.wait();
expect(receipt?.status).to.eq(1);

// Store the state index
const log = receipt!.logs[receipt!.logs.length - 1];
const event = iface.parseLog(log as unknown as { topics: string[]; data: string }) as unknown as {
args: {
_stateIndex: BigNumberish;
_voiceCreditBalance: BigNumberish;
_timestamp: BigNumberish;
};
for (let index = 0; index < users.length; index += 1) {
const user = users[index];

// eslint-disable-next-line no-await-in-loop
const tx = await maciContract.signUp(
user.pubKey.asContractParam(),
AbiCoder.defaultAbiCoder().encode(["uint256"], [1]),
AbiCoder.defaultAbiCoder().encode(["uint256"], [0]),
signUpTxOpts,
);
// eslint-disable-next-line no-await-in-loop
const receipt = await tx.wait();
expect(receipt?.status).to.eq(1);

// Store the state index
const log = receipt!.logs[receipt!.logs.length - 1];
const event = iface.parseLog(log as unknown as { topics: string[]; data: string }) as unknown as {
args: {
_stateIndex: BigNumberish;
_voiceCreditBalance: BigNumberish;
_timestamp: BigNumberish;
};
};

expect(event.args._stateIndex.toString()).to.eq((index + 1).toString());
expect(event.args._stateIndex.toString()).to.eq((index + 1).toString());

maciState.signUp(
user.pubKey,
BigInt(event.args._voiceCreditBalance.toString()),
BigInt(event.args._timestamp.toString()),
);
}),
);
maciState.signUp(
user.pubKey,
BigInt(event.args._voiceCreditBalance.toString()),
BigInt(event.args._timestamp.toString()),
);
}
});

it("should fail when given an invalid pubkey", async () => {
Expand Down

0 comments on commit 1ad9dd8

Please sign in to comment.