2020-01-09 04:34:58 +01:00
|
|
|
import assert from 'assert'
|
|
|
|
import ethUtil from 'ethereumjs-util'
|
2020-01-13 15:11:41 +01:00
|
|
|
import * as util from './util'
|
2016-04-14 00:28:44 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('util', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
let ethInWei = '1'
|
|
|
|
for (let i = 0; i < 18; i++) {
|
2019-11-20 01:03:20 +01:00
|
|
|
ethInWei += '0'
|
|
|
|
}
|
2016-04-14 00:28:44 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#parseBalance', function () {
|
|
|
|
it('should render 0.01 eth correctly', function () {
|
2016-05-26 03:29:03 +02:00
|
|
|
const input = '0x2386F26FC10000'
|
|
|
|
const output = util.parseBalance(input)
|
|
|
|
assert.deepEqual(output, ['0', '01'])
|
|
|
|
})
|
2016-07-11 22:57:47 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should render 12.023 eth correctly', function () {
|
2016-05-26 03:29:03 +02:00
|
|
|
const input = 'A6DA46CCA6858000'
|
|
|
|
const output = util.parseBalance(input)
|
|
|
|
assert.deepEqual(output, ['12', '023'])
|
|
|
|
})
|
2016-07-11 22:57:47 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should render 0.0000000342422 eth correctly', function () {
|
2016-06-21 00:46:29 +02:00
|
|
|
const input = '0x7F8FE81C0'
|
|
|
|
const output = util.parseBalance(input)
|
|
|
|
assert.deepEqual(output, ['0', '0000000342422'])
|
|
|
|
})
|
2016-07-11 22:57:47 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should render 0 eth correctly', function () {
|
2016-06-21 00:46:29 +02:00
|
|
|
const input = '0x0'
|
|
|
|
const output = util.parseBalance(input)
|
|
|
|
assert.deepEqual(output, ['0', '0'])
|
|
|
|
})
|
|
|
|
})
|
2016-05-26 03:29:03 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#addressSummary', function () {
|
|
|
|
it('should add case-sensitive checksum', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xfdea65c8e26263f6d9a1b5de9555d2931a33b825'
|
|
|
|
const result = util.addressSummary(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.equal(result, '0xFDEa65C8...b825')
|
|
|
|
})
|
2016-07-07 02:58:46 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should accept arguments for firstseg, lastseg, and keepPrefix', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xfdea65c8e26263f6d9a1b5de9555d2931a33b825'
|
|
|
|
const result = util.addressSummary(address, 4, 4, false)
|
2016-07-07 02:58:46 +02:00
|
|
|
assert.equal(result, 'FDEa...b825')
|
|
|
|
})
|
2016-05-19 21:06:45 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#isValidAddress', function () {
|
|
|
|
it('should allow 40-char non-prefixed hex', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = 'fdea65c8e26263f6d9a1b5de9555d2931a33b825'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(result)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should allow 42-char non-prefixed hex', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xfdea65c8e26263f6d9a1b5de9555d2931a33b825'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(result)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should not allow less non hex-prefixed', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = 'fdea65c8e26263f6d9a1b5de9555d2931a33b85'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(!result)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should not allow less hex-prefixed', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xfdea65ce26263f6d9a1b5de9555d2931a33b85'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(!result)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should recognize correct capitalized checksum', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xFDEa65C8e26263F6d9A1B5de9555D2931A33b825'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(result)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should recognize incorrect capitalized checksum', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const address = '0xFDea65C8e26263F6d9A1B5de9555D2931A33b825'
|
|
|
|
const result = util.isValidAddress(address)
|
2016-05-19 21:06:45 +02:00
|
|
|
assert.ok(!result)
|
|
|
|
})
|
2016-05-19 23:21:35 +02:00
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should recognize this sample hashed address', function () {
|
2016-06-03 03:42:09 +02:00
|
|
|
const address = '0x5Fda30Bb72B8Dfe20e48A00dFc108d0915BE9Bb0'
|
2016-06-02 01:14:49 +02:00
|
|
|
const result = util.isValidAddress(address)
|
2016-06-03 03:42:09 +02:00
|
|
|
const hashed = ethUtil.toChecksumAddress(address.toLowerCase())
|
2016-06-02 01:14:49 +02:00
|
|
|
assert.equal(hashed, address, 'example is hashed correctly')
|
2016-06-03 03:42:09 +02:00
|
|
|
assert.ok(result, 'is valid by our check')
|
2016-06-02 01:14:49 +02:00
|
|
|
})
|
2016-05-19 21:06:45 +02:00
|
|
|
})
|
|
|
|
|
2020-02-18 02:20:01 +01:00
|
|
|
describe('isValidDomainName', function () {
|
|
|
|
it('should return true when given a valid domain name', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo.bar'), true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when given a valid subdomain', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo.foo.bar'), true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when given a single-character domain', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('f.bar'), true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when given a unicode TLD', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('台灣.中国'), true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a domain with unacceptable ASCII characters', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('$.bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a TLD that starts with a dash', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo.-bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a TLD that ends with a dash', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo.bar-'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a domain name with a chunk that starts with a dash', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('-foo.bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a domain name with a chunk that ends with a dash', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo-.bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a bare TLD', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a domain that starts with a period', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('.bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a subdomain that starts with a period', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('.foo.bar'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a domain that ends with a period', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('bar.'), false)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when given a 1-character TLD', function () {
|
|
|
|
assert.strictEqual(util.isValidDomainName('foo.b'), false)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#numericBalance', function () {
|
|
|
|
it('should return a BN 0 if given nothing', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.numericBalance()
|
2016-04-14 00:28:44 +02:00
|
|
|
assert.equal(result.toString(10), 0)
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should work with hex prefix', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.numericBalance('0x012')
|
2016-04-14 00:28:44 +02:00
|
|
|
assert.equal(result.toString(10), '18')
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should work with no hex prefix', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.numericBalance('012')
|
2016-04-14 00:28:44 +02:00
|
|
|
assert.equal(result.toString(10), '18')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#formatBalance', function () {
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should return None when given nothing', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.formatBalance()
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, 'None', 'should return "None"')
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should return 1.0000 ETH', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = new ethUtil.BN(ethInWei, 10).toJSON()
|
|
|
|
const result = util.formatBalance(input, 4)
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, '1.0000 ETH')
|
|
|
|
})
|
|
|
|
|
2020-02-11 17:51:13 +01:00
|
|
|
it('should return 0.500 ETH', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = new ethUtil.BN(ethInWei, 10).div(new ethUtil.BN('2', 10)).toJSON()
|
|
|
|
const result = util.formatBalance(input, 3)
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, '0.500 ETH')
|
2016-04-14 22:20:19 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should display specified decimal points', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '0x128dfa6a90b28000'
|
|
|
|
const result = util.formatBalance(input, 2)
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, '1.33 ETH')
|
2016-05-26 03:29:03 +02:00
|
|
|
})
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should default to 3 decimal points', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '0x128dfa6a90b28000'
|
|
|
|
const result = util.formatBalance(input)
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, '1.337 ETH')
|
2016-05-26 03:29:03 +02:00
|
|
|
})
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should show 2 significant digits for tiny balances', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '0x1230fa6a90b28'
|
|
|
|
const result = util.formatBalance(input)
|
2016-07-07 20:20:02 +02:00
|
|
|
assert.equal(result, '0.00032 ETH')
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should not parse the balance and return value with 2 decimal points with ETH at the end', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const value = '1.2456789'
|
|
|
|
const needsParse = false
|
|
|
|
const result = util.formatBalance(value, 2, needsParse)
|
2016-08-20 02:30:19 +02:00
|
|
|
assert.equal(result, '1.24 ETH')
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('normalizing values', function () {
|
|
|
|
describe('#normalizeToWei', function () {
|
|
|
|
it('should convert an eth to the appropriate equivalent values', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const valueTable = {
|
2017-05-04 23:35:10 +02:00
|
|
|
wei: '1000000000000000000',
|
|
|
|
kwei: '1000000000000000',
|
|
|
|
mwei: '1000000000000',
|
|
|
|
gwei: '1000000000',
|
2016-04-20 03:56:22 +02:00
|
|
|
szabo: '1000000',
|
2017-05-04 23:35:10 +02:00
|
|
|
finney: '1000',
|
2016-04-20 03:56:22 +02:00
|
|
|
ether: '1',
|
|
|
|
// kether:'0.001',
|
|
|
|
// mether:'0.000001',
|
|
|
|
// AUDIT: We're getting BN numbers on these ones.
|
|
|
|
// I think they're big enough to ignore for now.
|
|
|
|
// gether:'0.000000001',
|
|
|
|
// tether:'0.000000000001',
|
|
|
|
}
|
2019-12-03 15:52:01 +01:00
|
|
|
const oneEthBn = new ethUtil.BN(ethInWei, 10)
|
2016-04-20 03:56:22 +02:00
|
|
|
|
2020-07-21 23:10:45 +02:00
|
|
|
Object.keys(valueTable).forEach((currency) => {
|
2019-12-03 15:52:01 +01:00
|
|
|
const value = new ethUtil.BN(valueTable[currency], 10)
|
|
|
|
const output = util.normalizeToWei(value, currency)
|
2016-04-20 03:56:22 +02:00
|
|
|
assert.equal(output.toString(10), valueTable.wei, `value of ${output.toString(10)} ${currency} should convert to ${oneEthBn}`)
|
2020-07-21 23:10:45 +02:00
|
|
|
})
|
2016-04-20 03:56:22 +02:00
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#normalizeEthStringToWei', function () {
|
|
|
|
it('should convert decimal eth to pure wei BN', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '1.23456789'
|
|
|
|
const output = util.normalizeEthStringToWei(input)
|
2016-05-19 23:46:50 +02:00
|
|
|
assert.equal(output.toString(10), '1234567890000000000')
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should convert 1 to expected wei', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '1'
|
|
|
|
const output = util.normalizeEthStringToWei(input)
|
2016-05-19 23:46:50 +02:00
|
|
|
assert.equal(output.toString(10), ethInWei)
|
|
|
|
})
|
2017-12-28 02:26:38 +01:00
|
|
|
|
|
|
|
it('should account for overflow numbers gracefully by dropping extra precision.', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '1.11111111111111111111'
|
|
|
|
const output = util.normalizeEthStringToWei(input)
|
2017-12-28 02:26:38 +01:00
|
|
|
assert.equal(output.toString(10), '1111111111111111111')
|
|
|
|
})
|
2017-12-28 02:33:28 +01:00
|
|
|
|
|
|
|
it('should not truncate very exact wei values that do not have extra precision.', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = '1.100000000000000001'
|
|
|
|
const output = util.normalizeEthStringToWei(input)
|
2017-12-28 02:33:28 +01:00
|
|
|
assert.equal(output.toString(10), '1100000000000000001')
|
|
|
|
})
|
2016-05-19 23:46:50 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#normalizeNumberToWei', function () {
|
|
|
|
it('should handle a simple use case', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const input = 0.0002
|
|
|
|
const output = util.normalizeNumberToWei(input, 'ether')
|
|
|
|
const str = output.toString(10)
|
2016-05-19 23:21:35 +02:00
|
|
|
assert.equal(str, '200000000000000')
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should convert a kwei number to the appropriate equivalent wei', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.normalizeNumberToWei(1.111, 'kwei')
|
2016-04-20 03:56:22 +02:00
|
|
|
assert.equal(result.toString(10), '1111', 'accepts decimals')
|
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should convert a ether number to the appropriate equivalent wei', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.normalizeNumberToWei(1.111, 'ether')
|
2016-04-20 03:56:22 +02:00
|
|
|
assert.equal(result.toString(10), '1111000000000000000', 'accepts decimals')
|
|
|
|
})
|
|
|
|
})
|
2017-05-04 23:35:10 +02:00
|
|
|
describe('#isHex', function () {
|
|
|
|
it('should return true when given a hex string', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.isHex('c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2')
|
2016-10-20 21:26:35 +02:00
|
|
|
assert(result)
|
2016-10-20 00:22:56 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should return false when given a non-hex string', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.isHex('c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714imnotreal')
|
2016-10-20 21:26:35 +02:00
|
|
|
assert(!result)
|
2016-10-20 00:22:56 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should return false when given a string containing a non letter/number character', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.isHex('c3ab8ff13720!8ad9047dd39466b3c%8974e592c2fa383d4a396071imnotreal')
|
2016-10-20 21:26:35 +02:00
|
|
|
assert(!result)
|
2016-10-20 00:22:56 +02:00
|
|
|
})
|
|
|
|
|
2017-05-04 23:35:10 +02:00
|
|
|
it('should return true when given a hex string with hex-prefix', function () {
|
2019-12-03 15:52:01 +01:00
|
|
|
const result = util.isHex('0xc3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2')
|
2016-10-20 21:26:35 +02:00
|
|
|
assert(result)
|
2016-10-20 04:35:44 +02:00
|
|
|
})
|
2016-10-20 00:22:56 +02:00
|
|
|
})
|
2020-01-22 02:22:55 +01:00
|
|
|
|
|
|
|
describe('#getRandomFileName', function () {
|
|
|
|
it('should only return a string containing alphanumeric characters', function () {
|
|
|
|
const result = util.getRandomFileName()
|
|
|
|
assert(result.match(/^[a-zA-Z0-9]*$/g))
|
|
|
|
})
|
|
|
|
|
|
|
|
// 50 samples
|
|
|
|
it('should return a string that is between 6 and 12 characters in length', function () {
|
|
|
|
for (let i = 0; i < 50; i++) {
|
|
|
|
const result = util.getRandomFileName()
|
|
|
|
assert(result.length >= 6 && result.length <= 12)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
2016-04-20 03:56:22 +02:00
|
|
|
})
|
2020-07-08 00:18:18 +02:00
|
|
|
|
|
|
|
describe('checkExistingAddresses', function () {
|
|
|
|
const tokenList = [
|
|
|
|
{ address: 'A' },
|
|
|
|
{ address: 'n' },
|
|
|
|
{ address: 'Q' },
|
|
|
|
{ address: 'z' },
|
|
|
|
]
|
|
|
|
|
|
|
|
it('should return true when a lowercase address matches an uppercase address in the passed list', function () {
|
|
|
|
assert(util.checkExistingAddresses('q', tokenList) === true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when an uppercase address matches a lowercase address in the passed list', function () {
|
|
|
|
assert(util.checkExistingAddresses('N', tokenList) === true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when a lowercase address matches a lowercase address in the passed list', function () {
|
|
|
|
assert(util.checkExistingAddresses('z', tokenList) === true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return true when an uppercase address matches an uppercase address in the passed list', function () {
|
|
|
|
assert(util.checkExistingAddresses('Q', tokenList) === true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should return false when the passed address is not in the passed list', function () {
|
|
|
|
assert(util.checkExistingAddresses('b', tokenList) === false)
|
|
|
|
})
|
|
|
|
})
|
2016-04-14 00:28:44 +02:00
|
|
|
})
|