empty data is allowed
This commit is contained in:
parent
c312f4fb92
commit
8a60ed1315
@ -42,14 +42,14 @@ export function decodeCallData (data) {
|
||||
export function decodeMethodInput (methodAbi, paramdata) {
|
||||
if (!methodAbi) {
|
||||
throw new Error('decodeMethodInput should receive valid method-specific ABI');
|
||||
} else if (!paramdata) {
|
||||
throw new Error('decodeMethodInput should receive valid parameter input data');
|
||||
} else if (!isHex(paramdata)) {
|
||||
throw new Error('Input to decodeMethodInput should be a hex value');
|
||||
} else if (paramdata.substr(0, 2) === '0x') {
|
||||
return decodeMethodInput(methodAbi, paramdata.slice(2));
|
||||
} else if (paramdata.length % 64 !== 0) {
|
||||
throw new Error('Parameter length in decodeMethodInput not a multiple of 64 characters');
|
||||
} else if (paramdata && paramdata.length) {
|
||||
if (!isHex(paramdata)) {
|
||||
throw new Error('Input to decodeMethodInput should be a hex value');
|
||||
} else if (paramdata.substr(0, 2) === '0x') {
|
||||
return decodeMethodInput(methodAbi, paramdata.slice(2));
|
||||
} else if (paramdata.length % 64 !== 0) {
|
||||
throw new Error('Parameter length in decodeMethodInput not a multiple of 64 characters');
|
||||
}
|
||||
}
|
||||
|
||||
return new Func(methodAbi).decodeInput(paramdata).map((decoded) => decoded.value);
|
||||
|
@ -44,10 +44,6 @@ describe('api/util/decode', () => {
|
||||
expect(() => decodeMethodInput(null, null)).to.throw(/should receive valid method/);
|
||||
});
|
||||
|
||||
it('expects valid parameter data', () => {
|
||||
expect(() => decodeMethodInput({}, null)).to.throw(/should receive valid parameter/);
|
||||
});
|
||||
|
||||
it('expect valid hex parameter data', () => {
|
||||
expect(() => decodeMethodInput({}, 'invalid')).to.throw(/should be a hex value/);
|
||||
});
|
||||
|
Loading…
Reference in New Issue
Block a user