2023-03-29 11:58:09 +05:30
|
|
|
import { expect } from "chai";
|
|
|
|
import { ethers, deployments } from "hardhat";
|
|
|
|
|
2023-07-26 16:12:37 +05:30
|
|
|
describe("Rln", () => {
|
2023-03-29 11:58:09 +05:30
|
|
|
beforeEach(async () => {
|
2023-07-26 16:12:37 +05:30
|
|
|
await deployments.fixture(["Rln"]);
|
2023-03-29 11:58:09 +05:30
|
|
|
});
|
|
|
|
|
|
|
|
it("should register new memberships", async () => {
|
2023-07-26 16:12:37 +05:30
|
|
|
const rln = await ethers.getContract("Rln", ethers.provider.getSigner(0));
|
2023-03-29 11:58:09 +05:30
|
|
|
|
|
|
|
const price = await rln.MEMBERSHIP_DEPOSIT();
|
|
|
|
|
|
|
|
// A valid pair of (id_secret, id_commitment) generated in rust
|
|
|
|
const idCommitment =
|
|
|
|
"0x0c3ac305f6a4fe9bfeb3eba978bc876e2a99208b8b56c80160cfb54ba8f02368";
|
|
|
|
|
|
|
|
const registerTx = await rln["register(uint256)"](idCommitment, {
|
|
|
|
value: price,
|
|
|
|
});
|
|
|
|
const txRegisterReceipt = await registerTx.wait();
|
|
|
|
|
|
|
|
const pubkey = txRegisterReceipt.events[0].args.idCommitment;
|
|
|
|
|
|
|
|
// We ensure the registered id_commitment is the one we passed
|
|
|
|
expect(
|
|
|
|
pubkey.toHexString() === idCommitment,
|
|
|
|
"registered commitment doesn't match passed commitment"
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2023-03-30 20:28:04 +05:30
|
|
|
it("should slash membership", async () => {
|
2023-07-26 16:12:37 +05:30
|
|
|
const rln = await ethers.getContract("Rln", ethers.provider.getSigner(0));
|
2023-03-29 11:58:09 +05:30
|
|
|
|
|
|
|
const price = await rln.MEMBERSHIP_DEPOSIT();
|
|
|
|
|
2023-05-26 13:31:05 +05:30
|
|
|
// A valid id_commitment generated in zerokit
|
2023-03-29 11:58:09 +05:30
|
|
|
const idCommitment =
|
|
|
|
"0x0c3ac305f6a4fe9bfeb3eba978bc876e2a99208b8b56c80160cfb54ba8f02368";
|
|
|
|
|
|
|
|
const registerTx = await rln["register(uint256)"](idCommitment, {
|
|
|
|
value: price,
|
|
|
|
});
|
|
|
|
await registerTx.wait();
|
|
|
|
|
2023-03-30 20:28:04 +05:30
|
|
|
// We slash the id_commitment
|
2023-03-29 11:58:09 +05:30
|
|
|
const receiverAddress = "0x000000000000000000000000000000000000dead";
|
2023-05-26 13:31:05 +05:30
|
|
|
const slashTx = rln["slash(uint256,address,uint256[8])"](
|
|
|
|
idCommitment,
|
|
|
|
receiverAddress,
|
|
|
|
[0, 0, 0, 0, 0, 0, 0, 0]
|
2023-03-29 11:58:09 +05:30
|
|
|
);
|
|
|
|
|
2023-05-26 13:31:05 +05:30
|
|
|
await expect(slashTx).to.be.revertedWith("InvalidProof()");
|
2023-03-29 11:58:09 +05:30
|
|
|
});
|
|
|
|
|
|
|
|
it("should not allow multiple registrations with same pubkey", async () => {
|
2023-07-26 16:12:37 +05:30
|
|
|
const rln = await ethers.getContract("Rln", ethers.provider.getSigner(0));
|
2023-03-29 11:58:09 +05:30
|
|
|
|
|
|
|
const price = await rln.MEMBERSHIP_DEPOSIT();
|
|
|
|
|
|
|
|
// A valid pair of (id_secret, id_commitment) generated in rust
|
|
|
|
const idCommitment =
|
|
|
|
"0x0c3ac305f6a4fe9bfeb3eba978bc876e2a99208b8b56c80160cfb54ba8f02368";
|
|
|
|
|
|
|
|
const registerTx = await rln["register(uint256)"](idCommitment, {
|
|
|
|
value: price,
|
|
|
|
});
|
|
|
|
await registerTx.wait();
|
|
|
|
|
|
|
|
// Send the same tx again
|
|
|
|
const registerTx2 = rln["register(uint256)"](idCommitment, {
|
|
|
|
value: price,
|
|
|
|
});
|
|
|
|
|
2023-03-30 17:30:54 +05:30
|
|
|
await expect(registerTx2).to.be.revertedWith("DuplicateIdCommitment()");
|
2023-03-29 11:58:09 +05:30
|
|
|
});
|
|
|
|
});
|