Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
O
openzeppelin-contracts-upgradeable
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
俞永鹏
openzeppelin-contracts-upgradeable
Commits
713b4722
Commit
713b4722
authored
May 21, 2017
by
Jorge Izquierdo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add tests for non-revokable and revokable/burnable cases
parent
a1d2b673
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
57 additions
and
0 deletions
+57
-0
VestedToken.js
test/VestedToken.js
+57
-0
No files found.
test/VestedToken.js
View file @
713b4722
...
...
@@ -96,4 +96,61 @@ contract('VestedToken', function(accounts) {
assert
.
equal
(
await
token
.
balanceOf
(
accounts
[
7
]),
tokenAmount
);
})
})
describe
(
'getting a non-revokable token grant'
,
async
()
=>
{
const
cliff
=
10000
const
vesting
=
20000
// seconds
beforeEach
(
async
()
=>
{
await
token
.
grantVestedTokens
(
receiver
,
tokenAmount
,
now
,
now
+
cliff
,
now
+
vesting
,
false
,
false
,
{
from
:
granter
})
})
it
(
'tokens are received'
,
async
()
=>
{
assert
.
equal
(
await
token
.
balanceOf
(
receiver
),
tokenAmount
);
})
it
(
'throws when granter attempts to revoke'
,
async
()
=>
{
try
{
await
token
.
revokeTokenGrant
(
receiver
,
0
,
{
from
:
granter
});
}
catch
(
error
)
{
return
assertJump
(
error
);
}
assert
.
fail
(
'should have thrown before'
);
})
})
describe
(
'getting a revokable/burnable token grant'
,
async
()
=>
{
const
cliff
=
100000
const
vesting
=
200000
// seconds
const
burnAddress
=
'0x000000000000000000000000000000000000dead'
beforeEach
(
async
()
=>
{
await
token
.
grantVestedTokens
(
receiver
,
tokenAmount
,
now
,
now
+
cliff
,
now
+
vesting
,
true
,
true
,
{
from
:
granter
})
})
it
(
'tokens are received'
,
async
()
=>
{
assert
.
equal
(
await
token
.
balanceOf
(
receiver
),
tokenAmount
);
})
it
(
'can be revoked by granter and tokens are burned'
,
async
()
=>
{
await
token
.
revokeTokenGrant
(
receiver
,
0
,
{
from
:
granter
});
assert
.
equal
(
await
token
.
balanceOf
(
receiver
),
0
);
assert
.
equal
(
await
token
.
balanceOf
(
burnAddress
),
tokenAmount
);
})
it
(
'cannot be revoked by non granter'
,
async
()
=>
{
try
{
await
token
.
revokeTokenGrant
(
receiver
,
0
,
{
from
:
accounts
[
3
]
});
}
catch
(
error
)
{
return
assertJump
(
error
);
}
assert
.
fail
(
'should have thrown before'
);
})
it
(
'can be revoked by granter and non vested tokens are returned'
,
async
()
=>
{
await
timer
(
cliff
);
await
token
.
revokeTokenGrant
(
receiver
,
0
,
{
from
:
granter
});
assert
.
equal
(
await
token
.
balanceOf
(
burnAddress
),
tokenAmount
*
cliff
/
vesting
);
})
})
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment