Migrate AccessControl tests (#4694)

Co-authored-by: Hadrien Croubois <hadrien.croubois@gmail.com>
This commit is contained in:
Ernesto García
2023-10-25 20:52:09 -06:00
committed by GitHub
parent 7c8b7a2728
commit 2ec2ed9695
6 changed files with 491 additions and 491 deletions

File diff suppressed because it is too large Load Diff

View File

@ -1,12 +1,19 @@
const { ethers } = require('hardhat');
const { loadFixture } = require('@nomicfoundation/hardhat-network-helpers');
const { DEFAULT_ADMIN_ROLE, shouldBehaveLikeAccessControl } = require('./AccessControl.behavior.js');
const AccessControl = artifacts.require('$AccessControl');
async function fixture() {
const [defaultAdmin, ...accounts] = await ethers.getSigners();
const mock = await ethers.deployContract('$AccessControl');
await mock.$_grantRole(DEFAULT_ADMIN_ROLE, defaultAdmin);
return { mock, defaultAdmin, accounts };
}
contract('AccessControl', function (accounts) {
describe('AccessControl', function () {
beforeEach(async function () {
this.accessControl = await AccessControl.new({ from: accounts[0] });
await this.accessControl.$_grantRole(DEFAULT_ADMIN_ROLE, accounts[0]);
Object.assign(this, await loadFixture(fixture));
});
shouldBehaveLikeAccessControl(...accounts);
shouldBehaveLikeAccessControl();
});

View File

@ -1,26 +1,30 @@
const { time, constants, expectRevert } = require('@openzeppelin/test-helpers');
const { ethers } = require('hardhat');
const { loadFixture } = require('@nomicfoundation/hardhat-network-helpers');
const { bigint: time } = require('../../helpers/time');
const {
shouldBehaveLikeAccessControl,
shouldBehaveLikeAccessControlDefaultAdminRules,
} = require('../AccessControl.behavior.js');
const AccessControlDefaultAdminRules = artifacts.require('$AccessControlDefaultAdminRules');
contract('AccessControlDefaultAdminRules', function (accounts) {
const delay = web3.utils.toBN(time.duration.hours(10));
async function fixture() {
const delay = time.duration.hours(10);
const [defaultAdmin, ...accounts] = await ethers.getSigners();
const mock = await ethers.deployContract('$AccessControlDefaultAdminRules', [delay, defaultAdmin]);
return { mock, defaultAdmin, delay, accounts };
}
describe('AccessControlDefaultAdminRules', function () {
beforeEach(async function () {
this.accessControl = await AccessControlDefaultAdminRules.new(delay, accounts[0], { from: accounts[0] });
Object.assign(this, await loadFixture(fixture));
});
it('initial admin not zero', async function () {
await expectRevert(
AccessControlDefaultAdminRules.new(delay, constants.ZERO_ADDRESS),
'AccessControlInvalidDefaultAdmin',
[constants.ZERO_ADDRESS],
);
await expect(ethers.deployContract('$AccessControlDefaultAdminRules', [this.delay, ethers.ZeroAddress]))
.to.be.revertedWithCustomError(this.mock, 'AccessControlInvalidDefaultAdmin')
.withArgs(ethers.ZeroAddress);
});
shouldBehaveLikeAccessControl(...accounts);
shouldBehaveLikeAccessControlDefaultAdminRules(delay, ...accounts);
shouldBehaveLikeAccessControl();
shouldBehaveLikeAccessControlDefaultAdminRules();
});

View File

@ -1,17 +1,24 @@
const { ethers } = require('hardhat');
const { loadFixture } = require('@nomicfoundation/hardhat-network-helpers');
const {
DEFAULT_ADMIN_ROLE,
shouldBehaveLikeAccessControl,
shouldBehaveLikeAccessControlEnumerable,
} = require('../AccessControl.behavior.js');
const AccessControlEnumerable = artifacts.require('$AccessControlEnumerable');
async function fixture() {
const [defaultAdmin, ...accounts] = await ethers.getSigners();
const mock = await ethers.deployContract('$AccessControlEnumerable');
await mock.$_grantRole(DEFAULT_ADMIN_ROLE, defaultAdmin);
return { mock, defaultAdmin, accounts };
}
contract('AccessControlEnumerable', function (accounts) {
describe('AccessControlEnumerable', function () {
beforeEach(async function () {
this.accessControl = await AccessControlEnumerable.new({ from: accounts[0] });
await this.accessControl.$_grantRole(DEFAULT_ADMIN_ROLE, accounts[0]);
Object.assign(this, await loadFixture(fixture));
});
shouldBehaveLikeAccessControl(...accounts);
shouldBehaveLikeAccessControlEnumerable(...accounts);
shouldBehaveLikeAccessControl();
shouldBehaveLikeAccessControlEnumerable();
});