Add Governor contracts (#2672)
Co-authored-by: Francisco Giordano <frangio.1@gmail.com>
This commit is contained in:
55
test/utils/TimersBlockNumberImpl.test.js
Normal file
55
test/utils/TimersBlockNumberImpl.test.js
Normal file
@ -0,0 +1,55 @@
|
||||
const { BN, time } = require('@openzeppelin/test-helpers');
|
||||
const { expect } = require('chai');
|
||||
|
||||
const TimersBlockNumberImpl = artifacts.require('TimersBlockNumberImpl');
|
||||
|
||||
contract('TimersBlockNumber', function (accounts) {
|
||||
beforeEach(async function () {
|
||||
this.instance = await TimersBlockNumberImpl.new();
|
||||
this.now = await web3.eth.getBlock('latest').then(({ number }) => number);
|
||||
});
|
||||
|
||||
it('unset', async function () {
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal('0');
|
||||
expect(await this.instance.isUnset()).to.be.equal(true);
|
||||
expect(await this.instance.isStarted()).to.be.equal(false);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('pending', async function () {
|
||||
await this.instance.setDeadline(this.now + 3);
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(this.now + 3));
|
||||
expect(await this.instance.isUnset()).to.be.equal(false);
|
||||
expect(await this.instance.isStarted()).to.be.equal(true);
|
||||
expect(await this.instance.isPending()).to.be.equal(true);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('expired', async function () {
|
||||
await this.instance.setDeadline(this.now - 3);
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(this.now - 3));
|
||||
expect(await this.instance.isUnset()).to.be.equal(false);
|
||||
expect(await this.instance.isStarted()).to.be.equal(true);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(true);
|
||||
});
|
||||
|
||||
it('reset', async function () {
|
||||
await this.instance.reset();
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(0));
|
||||
expect(await this.instance.isUnset()).to.be.equal(true);
|
||||
expect(await this.instance.isStarted()).to.be.equal(false);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('fast forward', async function () {
|
||||
await this.instance.setDeadline(this.now + 3);
|
||||
expect(await this.instance.isPending()).to.be.equal(true);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
await time.advanceBlockTo(this.now + 3);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(true);
|
||||
});
|
||||
});
|
||||
55
test/utils/TimersTimestamp.test.js
Normal file
55
test/utils/TimersTimestamp.test.js
Normal file
@ -0,0 +1,55 @@
|
||||
const { BN, time } = require('@openzeppelin/test-helpers');
|
||||
const { expect } = require('chai');
|
||||
|
||||
const TimersTimestampImpl = artifacts.require('TimersTimestampImpl');
|
||||
|
||||
contract('TimersTimestamp', function (accounts) {
|
||||
beforeEach(async function () {
|
||||
this.instance = await TimersTimestampImpl.new();
|
||||
this.now = await web3.eth.getBlock('latest').then(({ timestamp }) => timestamp);
|
||||
});
|
||||
|
||||
it('unset', async function () {
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal('0');
|
||||
expect(await this.instance.isUnset()).to.be.equal(true);
|
||||
expect(await this.instance.isStarted()).to.be.equal(false);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('pending', async function () {
|
||||
await this.instance.setDeadline(this.now + 100);
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(this.now + 100));
|
||||
expect(await this.instance.isUnset()).to.be.equal(false);
|
||||
expect(await this.instance.isStarted()).to.be.equal(true);
|
||||
expect(await this.instance.isPending()).to.be.equal(true);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('expired', async function () {
|
||||
await this.instance.setDeadline(this.now - 100);
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(this.now - 100));
|
||||
expect(await this.instance.isUnset()).to.be.equal(false);
|
||||
expect(await this.instance.isStarted()).to.be.equal(true);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(true);
|
||||
});
|
||||
|
||||
it('reset', async function () {
|
||||
await this.instance.reset();
|
||||
expect(await this.instance.getDeadline()).to.be.bignumber.equal(new BN(0));
|
||||
expect(await this.instance.isUnset()).to.be.equal(true);
|
||||
expect(await this.instance.isStarted()).to.be.equal(false);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
});
|
||||
|
||||
it('fast forward', async function () {
|
||||
await this.instance.setDeadline(this.now + 100);
|
||||
expect(await this.instance.isPending()).to.be.equal(true);
|
||||
expect(await this.instance.isExpired()).to.be.equal(false);
|
||||
await time.increaseTo(this.now + 100);
|
||||
expect(await this.instance.isPending()).to.be.equal(false);
|
||||
expect(await this.instance.isExpired()).to.be.equal(true);
|
||||
});
|
||||
});
|
||||
@ -50,6 +50,30 @@ const INTERFACES = {
|
||||
'getRoleMember(bytes32,uint256)',
|
||||
'getRoleMemberCount(bytes32)',
|
||||
],
|
||||
Governor: [
|
||||
'name()',
|
||||
'version()',
|
||||
'COUNTING_MODE()',
|
||||
'hashProposal(address[],uint256[],bytes[],bytes32)',
|
||||
'state(uint256)',
|
||||
'proposalSnapshot(uint256)',
|
||||
'proposalDeadline(uint256)',
|
||||
'votingDelay()',
|
||||
'votingPeriod()',
|
||||
'quorum(uint256)',
|
||||
'getVotes(address,uint256)',
|
||||
'hasVoted(uint256,address)',
|
||||
'propose(address[],uint256[],bytes[],string)',
|
||||
'execute(address[],uint256[],bytes[],bytes32)',
|
||||
'castVote(uint256,uint8)',
|
||||
'castVoteWithReason(uint256,uint8,string)',
|
||||
'castVoteBySig(uint256,uint8,uint8,bytes32,bytes32)',
|
||||
],
|
||||
GovernorTimelock: [
|
||||
'timelock()',
|
||||
'proposalEta(uint256)',
|
||||
'queue(address[],uint256[],bytes[],bytes32)',
|
||||
],
|
||||
};
|
||||
|
||||
const INTERFACE_IDS = {};
|
||||
|
||||
Reference in New Issue
Block a user