Merged tx decoder into AbiDecoder in utils and merged zeroex tx decoder into ContractWrappers.

This commit is contained in:
Greg Hysen
2019-02-06 23:47:40 -08:00
parent 6bde77bb57
commit 6406126ae3
10 changed files with 145 additions and 339 deletions

View File

@@ -0,0 +1,50 @@
import * as chai from 'chai';
import { MethodAbi } from 'ethereum-types';
import 'mocha';
import { AbiEncoder, AbiDecoder } from '../src';
import { chaiSetup } from './utils/chai_setup';
chaiSetup.configure();
const expect = chai.expect;
describe('AbiDecoder', () => {
it('should successfully add a new ABI and decode calldata for it', async () => {
// Add new ABI
const abi: MethodAbi = {
name: 'foobar',
type: 'function',
inputs: [
{
name: 'testAddress',
type: 'address',
},
],
outputs: [
{
name: 'butter',
type: 'string',
},
],
constant: false,
payable: false,
stateMutability: 'pure',
};
const contractName = 'newContract';
const testAddress = '0x0001020304050607080900010203040506070809';
const abiDecoder = new AbiDecoder([]);
abiDecoder.addABI([abi], contractName);
// Create some tx data
const foobarEncoder = new AbiEncoder.Method(abi);
const foobarSignature = foobarEncoder.getSignature();
const foobarTxData = foobarEncoder.encode([testAddress]);
// Decode tx data using contract name
const decodedTxData = abiDecoder.tryDecodeCalldata(foobarTxData, contractName);
const expectedFunctionName = abi.name;
const expectedFunctionArguments = {testAddress};
expect(decodedTxData.functionName).to.be.equal(expectedFunctionName);
expect(decodedTxData.functionSignature).to.be.equal(foobarSignature);
expect(decodedTxData.functionArguments).to.be.deep.equal(expectedFunctionArguments);
});
});