1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- 'use strict';
- const assertJump = require('./helpers/assertJump');
- var Claimable = artifacts.require('../contracts/ownership/Claimable.sol');
- contract('Claimable', function(accounts) {
- let claimable;
- beforeEach(async function() {
- claimable = await Claimable.new();
- });
- it('should have an owner', async function() {
- let owner = await claimable.owner();
- assert.isTrue(owner !== 0);
- });
- it('changes pendingOwner after transfer', async function() {
- let newOwner = accounts[1];
- await claimable.transferOwnership(newOwner);
- let pendingOwner = await claimable.pendingOwner();
- assert.isTrue(pendingOwner === newOwner);
- });
- it('should prevent to claimOwnership from no pendingOwner', async function() {
- try {
- await claimable.claimOwnership({from: accounts[2]});
- assert.fail('should have thrown before');
- } catch(error) {
- assertJump(error);
- }
- });
- it('should prevent non-owners from transfering', async function() {
- const other = accounts[2];
- const owner = await claimable.owner.call();
- assert.isTrue(owner !== other);
- try {
- await claimable.transferOwnership(other, {from: other});
- assert.fail('should have thrown before');
- } catch(error) {
- assertJump(error);
- }
- });
- describe('after initiating a transfer', function () {
- let newOwner;
- beforeEach(async function () {
- newOwner = accounts[1];
- await claimable.transferOwnership(newOwner);
- });
- it('changes allow pending owner to claim ownership', async function() {
- await claimable.claimOwnership({from: newOwner});
- let owner = await claimable.owner();
- assert.isTrue(owner === newOwner);
- });
- });
- });
|