2021-12-02 17:31:51 +00:00
|
|
|
import { ethers, network } from "hardhat";
|
|
|
|
import chai from "chai";
|
|
|
|
import chaiPromise from "chai-as-promised";
|
|
|
|
import { solidity } from "ethereum-waffle";
|
2021-05-09 19:16:11 +00:00
|
|
|
|
|
|
|
chai.use(chaiPromise);
|
|
|
|
chai.use(solidity);
|
|
|
|
|
|
|
|
const { expect } = chai;
|
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
const getMapping = (address, signer) => {
|
|
|
|
return ethers.getContractAt("InstaMappingController", address, signer);
|
2021-05-09 19:16:11 +00:00
|
|
|
};
|
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
describe("Test InstaMapping contract", () => {
|
2021-12-02 17:31:51 +00:00
|
|
|
let account: any, instaMaster: any;
|
|
|
|
let mappingAddress: any;
|
|
|
|
let masterMapping: any;
|
2021-05-09 19:16:11 +00:00
|
|
|
const indexInterfaceAddress = "0x2971AdFa57b20E5a416aE5a708A8655A9c74f723";
|
2021-05-10 08:49:45 +00:00
|
|
|
const testRoleAddress = "0x2971AdFa57b20E5a416aE5a708A8655A9c74f723";
|
2021-05-09 19:16:11 +00:00
|
|
|
|
|
|
|
before("get signers", async () => {
|
2021-09-29 05:19:30 +00:00
|
|
|
await hre.network.provider.request({
|
|
|
|
method: "hardhat_reset",
|
|
|
|
params: [
|
|
|
|
{
|
|
|
|
forking: {
|
|
|
|
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
|
|
|
blockNumber: 12796965,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
2021-05-09 19:16:11 +00:00
|
|
|
[account] = await ethers.getSigners();
|
|
|
|
|
|
|
|
const IndexContract = await ethers.getContractAt(
|
2021-05-10 08:49:45 +00:00
|
|
|
"contracts/mapping/InstaMappingController.sol:IndexInterface",
|
2021-05-09 19:16:11 +00:00
|
|
|
indexInterfaceAddress
|
|
|
|
);
|
|
|
|
const masterAddress = await IndexContract.master();
|
|
|
|
|
|
|
|
await network.provider.request({
|
|
|
|
method: "hardhat_impersonateAccount",
|
|
|
|
params: [masterAddress],
|
|
|
|
});
|
|
|
|
|
2021-09-29 05:19:30 +00:00
|
|
|
await network.provider.send("hardhat_setBalance", [
|
|
|
|
masterAddress,
|
|
|
|
"0x1000000000000000000000000",
|
|
|
|
]);
|
|
|
|
|
2021-05-09 19:16:11 +00:00
|
|
|
instaMaster = await ethers.getSigner(masterAddress);
|
|
|
|
});
|
|
|
|
|
2021-05-09 19:45:42 +00:00
|
|
|
after(async () => {
|
|
|
|
await network.provider.request({
|
|
|
|
method: "hardhat_stopImpersonatingAccount",
|
|
|
|
params: [instaMaster.address],
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-05-09 19:16:11 +00:00
|
|
|
beforeEach("deploy contract", async () => {
|
2021-05-10 08:49:45 +00:00
|
|
|
const mappingFactory = await ethers.getContractFactory(
|
|
|
|
"InstaMappingController"
|
2021-05-09 19:16:11 +00:00
|
|
|
);
|
2021-05-10 08:49:45 +00:00
|
|
|
const mapping = await mappingFactory.deploy();
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await mapping.deployed();
|
|
|
|
mappingAddress = mapping.address;
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
masterMapping = await getMapping(mappingAddress, instaMaster);
|
2021-05-09 19:16:11 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("grant,revoke role should fail with non master signer", async () => {
|
2021-05-10 08:49:45 +00:00
|
|
|
const selfMapping = await getMapping(mappingAddress, account);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
|
|
|
await expect(
|
2021-05-10 08:49:45 +00:00
|
|
|
selfMapping.grantRole(testRoleAddress, account.address)
|
|
|
|
).to.rejectedWith(/MappingController: sender must be master/);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
|
|
|
await expect(
|
2021-05-10 08:49:45 +00:00
|
|
|
selfMapping.revokeRole(testRoleAddress, account.address)
|
|
|
|
).to.rejectedWith(/MappingController: sender must be master/);
|
2021-05-09 19:16:11 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("hasRole should return false for roles not assigned to users", async () => {
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
false
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should grant roles", async () => {
|
2021-05-10 08:49:45 +00:00
|
|
|
await expect(masterMapping.grantRole(testRoleAddress, account.address))
|
|
|
|
.to.emit(masterMapping, "RoleGranted")
|
|
|
|
.withArgs(testRoleAddress, account.address);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
true
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should revoke role", async () => {
|
|
|
|
// add a role first
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, account.address);
|
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
// then remove the role
|
2021-05-10 08:49:45 +00:00
|
|
|
await expect(masterMapping.revokeRole(testRoleAddress, account.address))
|
|
|
|
.to.emit(masterMapping, "RoleRevoked")
|
|
|
|
.withArgs(testRoleAddress, account.address, instaMaster.address);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
false
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should renounce role only with the account not master", async () => {
|
|
|
|
// add a role first
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, account.address);
|
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
// then renounce the the role
|
|
|
|
await expect(
|
2021-05-10 08:49:45 +00:00
|
|
|
masterMapping.renounceRole(testRoleAddress, account.address)
|
|
|
|
).to.rejectedWith(/MappingController: can only renounce roles for self/);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
const selfMapping = await getMapping(mappingAddress, account);
|
|
|
|
expect(await selfMapping.renounceRole(testRoleAddress, account.address))
|
|
|
|
.to.emit(masterMapping, "RoleRevoked")
|
|
|
|
.withArgs(testRoleAddress, account.address, account.address);
|
2021-05-09 19:16:11 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.hasRole(testRoleAddress, account.address)).to.eq(
|
2021-05-09 19:16:11 +00:00
|
|
|
false
|
|
|
|
);
|
|
|
|
});
|
2021-05-09 22:16:55 +00:00
|
|
|
|
|
|
|
it("should do role count properly", async () => {
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMemberCount(testRoleAddress)).to.eq(0);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, account.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMemberCount(testRoleAddress)).to.eq(1);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, instaMaster.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMemberCount(testRoleAddress)).to.eq(2);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.revokeRole(testRoleAddress, instaMaster.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMemberCount(testRoleAddress)).to.eq(1);
|
2021-05-09 22:16:55 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it("should get member correctly by index", async () => {
|
|
|
|
await expect(
|
2021-05-10 08:49:45 +00:00
|
|
|
masterMapping.getRoleMember(testRoleAddress, 0)
|
2021-05-09 22:16:55 +00:00
|
|
|
).to.rejectedWith(/EnumerableSet: index out of bounds/);
|
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, account.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMember(testRoleAddress, 0)).to.eq(
|
2021-05-09 22:16:55 +00:00
|
|
|
account.address
|
|
|
|
);
|
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.grantRole(testRoleAddress, instaMaster.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
expect(await masterMapping.getRoleMember(testRoleAddress, 1)).to.eq(
|
2021-05-09 22:16:55 +00:00
|
|
|
instaMaster.address
|
|
|
|
);
|
|
|
|
|
2021-05-10 08:49:45 +00:00
|
|
|
await masterMapping.revokeRole(testRoleAddress, instaMaster.address);
|
2021-05-09 22:16:55 +00:00
|
|
|
|
|
|
|
await expect(
|
2021-05-10 08:49:45 +00:00
|
|
|
masterMapping.getRoleMember(testRoleAddress, 1)
|
2021-05-09 22:16:55 +00:00
|
|
|
).to.rejectedWith(/EnumerableSet: index out of bounds/);
|
|
|
|
});
|
2021-05-09 19:16:11 +00:00
|
|
|
});
|