123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- const shouldFail = require('../../helpers/shouldFail');
- const { ZERO_ADDRESS } = require('../../helpers/constants');
- const expectEvent = require('../../helpers/expectEvent');
- require('../../helpers/setup');
- function capitalize (str) {
- return str.replace(/\b\w/g, l => l.toUpperCase());
- }
- function shouldBehaveLikePublicRole (authorized, otherAuthorized, [anyone], rolename) {
- rolename = capitalize(rolename);
- describe('should behave like public role', function () {
- beforeEach('check preconditions', async function () {
- (await this.contract[`is${rolename}`](authorized)).should.equal(true);
- (await this.contract[`is${rolename}`](otherAuthorized)).should.equal(true);
- (await this.contract[`is${rolename}`](anyone)).should.equal(false);
- });
- it('emits events during construction', async function () {
- await expectEvent.inConstruction(this.contract, `${rolename}Added`, {
- account: authorized,
- });
- });
- it('reverts when querying roles for the null account', async function () {
- await shouldFail.reverting(this.contract[`is${rolename}`](ZERO_ADDRESS));
- });
- describe('access control', function () {
- context('from authorized account', function () {
- const from = authorized;
- it('allows access', async function () {
- await this.contract[`only${rolename}Mock`]({ from });
- });
- });
- context('from unauthorized account', function () {
- const from = anyone;
- it('reverts', async function () {
- await shouldFail.reverting(this.contract[`only${rolename}Mock`]({ from }));
- });
- });
- });
- describe('add', function () {
- it('adds role to a new account', async function () {
- await this.contract[`add${rolename}`](anyone, { from: authorized });
- (await this.contract[`is${rolename}`](anyone)).should.equal(true);
- });
- it(`emits a ${rolename}Added event`, async function () {
- const { logs } = await this.contract[`add${rolename}`](anyone, { from: authorized });
- expectEvent.inLogs(logs, `${rolename}Added`, { account: anyone });
- });
- it('reverts when adding role to an already assigned account', async function () {
- await shouldFail.reverting(this.contract[`add${rolename}`](authorized, { from: authorized }));
- });
- it('reverts when adding role to the null account', async function () {
- await shouldFail.reverting(this.contract[`add${rolename}`](ZERO_ADDRESS, { from: authorized }));
- });
- });
- describe('remove', function () {
- it('removes role from an already assigned account', async function () {
- await this.contract[`remove${rolename}`](authorized);
- (await this.contract[`is${rolename}`](authorized)).should.equal(false);
- (await this.contract[`is${rolename}`](otherAuthorized)).should.equal(true);
- });
- it(`emits a ${rolename}Removed event`, async function () {
- const { logs } = await this.contract[`remove${rolename}`](authorized);
- expectEvent.inLogs(logs, `${rolename}Removed`, { account: authorized });
- });
- it('reverts when removing from an unassigned account', async function () {
- await shouldFail.reverting(this.contract[`remove${rolename}`](anyone));
- });
- it('reverts when removing role from the null account', async function () {
- await shouldFail.reverting(this.contract[`remove${rolename}`](ZERO_ADDRESS));
- });
- });
- describe('renouncing roles', function () {
- it('renounces an assigned role', async function () {
- await this.contract[`renounce${rolename}`]({ from: authorized });
- (await this.contract[`is${rolename}`](authorized)).should.equal(false);
- });
- it(`emits a ${rolename}Removed event`, async function () {
- const { logs } = await this.contract[`renounce${rolename}`]({ from: authorized });
- expectEvent.inLogs(logs, `${rolename}Removed`, { account: authorized });
- });
- it('reverts when renouncing unassigned role', async function () {
- await shouldFail.reverting(this.contract[`renounce${rolename}`]({ from: anyone }));
- });
- });
- });
- }
- module.exports = {
- shouldBehaveLikePublicRole,
- };
|