1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- const { assertRevert } = require('./helpers/assertRevert');
- const { ethGetBalance } = require('./helpers/web3');
- const LimitBalanceMock = artifacts.require('LimitBalanceMock');
- contract('LimitBalance', function (accounts) {
- let limitBalance;
- beforeEach(async function () {
- limitBalance = await LimitBalanceMock.new();
- });
- const LIMIT = 1000;
- it('should expose limit', async function () {
- const limit = await limitBalance.limit();
- assert.equal(limit, LIMIT);
- });
- it('should allow sending below limit', async function () {
- const amount = 1;
- await limitBalance.limitedDeposit({ value: amount });
- const balance = await ethGetBalance(limitBalance.address);
- assert.equal(balance, amount);
- });
- it('shouldnt allow sending above limit', async function () {
- const amount = 1110;
- await assertRevert(limitBalance.limitedDeposit({ value: amount }));
- });
- it('should allow multiple sends below limit', async function () {
- const amount = 500;
- await limitBalance.limitedDeposit({ value: amount });
- const balance = await ethGetBalance(limitBalance.address);
- assert.equal(balance, amount);
- await limitBalance.limitedDeposit({ value: amount });
- const updatedBalance = await ethGetBalance(limitBalance.address);
- assert.equal(updatedBalance, amount * 2);
- });
- it('shouldnt allow multiple sends above limit', async function () {
- const amount = 500;
- await limitBalance.limitedDeposit({ value: amount });
- const balance = await ethGetBalance(limitBalance.address);
- assert.equal(balance, amount);
- await assertRevert(limitBalance.limitedDeposit({ value: amount + 1 }));
- });
- });
|