Optimize toString (#3573)
Co-authored-by: Hadrien Croubois <hadrien.croubois@gmail.com> Co-authored-by: Francisco Giordano <frangio.1@gmail.com>pull/3620/head^2
parent
1eb55e2864
commit
160bf1a6eb
@ -1,71 +1,86 @@ |
|||||||
const { constants, expectRevert } = require('@openzeppelin/test-helpers'); |
const { BN, constants, expectRevert } = require('@openzeppelin/test-helpers'); |
||||||
|
|
||||||
const { expect } = require('chai'); |
const { expect } = require('chai'); |
||||||
|
|
||||||
const StringsMock = artifacts.require('StringsMock'); |
const StringsMock = artifacts.require('StringsMock'); |
||||||
|
|
||||||
contract('Strings', function (accounts) { |
contract('Strings', function (accounts) { |
||||||
beforeEach(async function () { |
before(async function () { |
||||||
this.strings = await StringsMock.new(); |
this.strings = await StringsMock.new(); |
||||||
}); |
}); |
||||||
|
|
||||||
describe('from uint256 - decimal format', function () { |
describe('toString', function () { |
||||||
it('converts 0', async function () { |
for (const [ key, value ] of Object.entries([ |
||||||
expect(await this.strings.fromUint256(0)).to.equal('0'); |
'0', |
||||||
}); |
'7', |
||||||
|
'10', |
||||||
it('converts a positive number', async function () { |
'99', |
||||||
expect(await this.strings.fromUint256(4132)).to.equal('4132'); |
'100', |
||||||
}); |
'101', |
||||||
|
'123', |
||||||
it('converts MAX_UINT256', async function () { |
'4132', |
||||||
expect(await this.strings.fromUint256(constants.MAX_UINT256)).to.equal(constants.MAX_UINT256.toString()); |
'12345', |
||||||
}); |
'1234567', |
||||||
|
'1234567890', |
||||||
|
'123456789012345', |
||||||
|
'12345678901234567890', |
||||||
|
'123456789012345678901234567890', |
||||||
|
'1234567890123456789012345678901234567890', |
||||||
|
'12345678901234567890123456789012345678901234567890', |
||||||
|
'123456789012345678901234567890123456789012345678901234567890', |
||||||
|
'1234567890123456789012345678901234567890123456789012345678901234567890', |
||||||
|
].reduce((acc, value) => Object.assign(acc, { [value]: new BN(value) }), { |
||||||
|
MAX_UINT256: constants.MAX_UINT256.toString(), |
||||||
|
}))) { |
||||||
|
it(`converts ${key}`, async function () { |
||||||
|
expect(await this.strings.methods['toString(uint256)'](value)).to.equal(value.toString(10)); |
||||||
|
}); |
||||||
|
} |
||||||
}); |
}); |
||||||
|
|
||||||
describe('from uint256 - hex format', function () { |
describe('toHexString', function () { |
||||||
it('converts 0', async function () { |
it('converts 0', async function () { |
||||||
expect(await this.strings.fromUint256Hex(0)).to.equal('0x00'); |
expect(await this.strings.methods['toHexString(uint256)'](0)).to.equal('0x00'); |
||||||
}); |
}); |
||||||
|
|
||||||
it('converts a positive number', async function () { |
it('converts a positive number', async function () { |
||||||
expect(await this.strings.fromUint256Hex(0x4132)).to.equal('0x4132'); |
expect(await this.strings.methods['toHexString(uint256)'](0x4132)).to.equal('0x4132'); |
||||||
}); |
}); |
||||||
|
|
||||||
it('converts MAX_UINT256', async function () { |
it('converts MAX_UINT256', async function () { |
||||||
expect(await this.strings.fromUint256Hex(constants.MAX_UINT256)) |
expect(await this.strings.methods['toHexString(uint256)'](constants.MAX_UINT256)) |
||||||
.to.equal(web3.utils.toHex(constants.MAX_UINT256)); |
.to.equal(web3.utils.toHex(constants.MAX_UINT256)); |
||||||
}); |
}); |
||||||
}); |
}); |
||||||
|
|
||||||
describe('from uint256 - fixed hex format', function () { |
describe('toHexString fixed', function () { |
||||||
it('converts a positive number (long)', async function () { |
it('converts a positive number (long)', async function () { |
||||||
expect(await this.strings.fromUint256HexFixed(0x4132, 32)) |
expect(await this.strings.methods['toHexString(uint256,uint256)'](0x4132, 32)) |
||||||
.to.equal('0x0000000000000000000000000000000000000000000000000000000000004132'); |
.to.equal('0x0000000000000000000000000000000000000000000000000000000000004132'); |
||||||
}); |
}); |
||||||
|
|
||||||
it('converts a positive number (short)', async function () { |
it('converts a positive number (short)', async function () { |
||||||
await expectRevert( |
await expectRevert( |
||||||
this.strings.fromUint256HexFixed(0x4132, 1), |
this.strings.methods['toHexString(uint256,uint256)'](0x4132, 1), |
||||||
'Strings: hex length insufficient', |
'Strings: hex length insufficient', |
||||||
); |
); |
||||||
}); |
}); |
||||||
|
|
||||||
it('converts MAX_UINT256', async function () { |
it('converts MAX_UINT256', async function () { |
||||||
expect(await this.strings.fromUint256HexFixed(constants.MAX_UINT256, 32)) |
expect(await this.strings.methods['toHexString(uint256,uint256)'](constants.MAX_UINT256, 32)) |
||||||
.to.equal(web3.utils.toHex(constants.MAX_UINT256)); |
.to.equal(web3.utils.toHex(constants.MAX_UINT256)); |
||||||
}); |
}); |
||||||
}); |
}); |
||||||
|
|
||||||
describe('from address - fixed hex format', function () { |
describe('toHexString address', function () { |
||||||
it('converts a random address', async function () { |
it('converts a random address', async function () { |
||||||
const addr = '0xa9036907dccae6a1e0033479b12e837e5cf5a02f'; |
const addr = '0xa9036907dccae6a1e0033479b12e837e5cf5a02f'; |
||||||
expect(await this.strings.fromAddressHexFixed(addr)).to.equal(addr); |
expect(await this.strings.methods['toHexString(address)'](addr)).to.equal(addr); |
||||||
}); |
}); |
||||||
|
|
||||||
it('converts an address with leading zeros', async function () { |
it('converts an address with leading zeros', async function () { |
||||||
const addr = '0x0000e0ca771e21bd00057f54a68c30d400000000'; |
const addr = '0x0000e0ca771e21bd00057f54a68c30d400000000'; |
||||||
expect(await this.strings.fromAddressHexFixed(addr)).to.equal(addr); |
expect(await this.strings.methods['toHexString(address)'](addr)).to.equal(addr); |
||||||
}); |
}); |
||||||
}); |
}); |
||||||
}); |
}); |
||||||
|
Loading…
Reference in new issue