mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Squashed 'libjsqrc/ethereumjs/' changes from c74c854..3b799d1
3b799d1 fixed typos c5f6379 version 0.3.3 d795d36 fixed trimming call output prefix a2f561f fixed calling contract only with array param 4912ec6 tests for decoding solidity params 2b4fd21 solidity param encoding tests git-subtree-dir: libjsqrc/ethereumjs git-subtree-split: 3b799d128452639463424c657956ee90a28daec6
This commit is contained in:
parent
1a137629e3
commit
572d268f28
@ -1,23 +1,68 @@
|
|||||||
var chai = require('chai');
|
var chai = require('chai');
|
||||||
var assert = chai.assert;
|
var assert = chai.assert;
|
||||||
var coder = require('../lib/solidity/coder');
|
var coder = require('../lib/solidity/coder');
|
||||||
|
var BigNumber = require('bignumber.js');
|
||||||
|
var bn = BigNumber;
|
||||||
|
|
||||||
var tests = [
|
|
||||||
{ type: 'int', value: '0000000000000000000000000000000000000000000000000000000000000001', expected: 1},
|
|
||||||
{ type: 'int', value: '0000000000000000000000000000000000000000000000000000000000000010', expected: 16},
|
|
||||||
{ type: 'int', value: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff', expected: -1},
|
|
||||||
{ type: 'bytes32', value: '6761766f66796f726b0000000000000000000000000000000000000000000000', expected: 'gavofyork'},
|
|
||||||
{ type: 'bytes', value: '0000000000000000000000000000000000000000000000000000000000000009' +
|
|
||||||
'6761766f66796f726b0000000000000000000000000000000000000000000000', expected: 'gavofyork'}
|
|
||||||
];
|
|
||||||
|
|
||||||
describe('lib/solidity/coder', function () {
|
describe('lib/solidity/coder', function () {
|
||||||
describe('decodeParam', function () {
|
describe('decodeParam', function () {
|
||||||
tests.forEach(function (test) {
|
var test = function (t) {
|
||||||
it('should turn ' + test.value + ' to ' + test.expected, function () {
|
it('should turn ' + t.value + ' to ' + t.expected, function () {
|
||||||
assert.equal(coder.decodeParam(test.type, test.value), test.expected);
|
assert.deepEqual(coder.decodeParam(t.type, t.value), t.expected);
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
test({ type: 'int', expected: new bn(1), value: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ type: 'int', expected: new bn(16), value: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ type: 'int', expected: new bn(-1), value: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ type: 'int256', expected: new bn(1), value: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ type: 'int256', expected: new bn(16), value: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ type: 'int256', expected: new bn(-1), value: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ type: 'bytes32', expected: 'gavofyork', value: '6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ type: 'bytes', expected: 'gavofyork', value: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ type: 'int[]', expected: [new bn(3)], value: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ type: 'int256[]', expected: [new bn(3)], value: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ type: 'int[]', expected: [new bn(1), new bn(2), new bn(3)],
|
||||||
|
value: '0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000002' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('lib/solidity/coder', function () {
|
||||||
|
describe('decodeParams', function () {
|
||||||
|
var test = function (t) {
|
||||||
|
it('should turn ' + t.values + ' to ' + t.expected, function () {
|
||||||
|
assert.deepEqual(coder.decodeParams(t.types, t.values), t.expected);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
test({ types: ['int'], expected: [new bn(1)], values: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ types: ['bytes32', 'int'], expected: ['gavofyork', new bn(5)],
|
||||||
|
values: '6761766f66796f726b0000000000000000000000000000000000000000000000' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005'});
|
||||||
|
test({ types: ['int', 'bytes32'], expected: [new bn(5), 'gavofyork'],
|
||||||
|
values: '0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['int', 'bytes', 'int', 'int', 'int', 'int[]'], expected: [new bn(1), 'gavofyork', new bn(2), new bn(3), new bn(4),
|
||||||
|
[new bn(5), new bn(6), new bn(7)]],
|
||||||
|
values: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000002' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000004' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000006' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000007'});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -2,22 +2,90 @@ var chai = require('chai');
|
|||||||
var assert = chai.assert;
|
var assert = chai.assert;
|
||||||
var coder = require('../lib/solidity/coder');
|
var coder = require('../lib/solidity/coder');
|
||||||
|
|
||||||
var tests = [
|
|
||||||
{ type: 'int', value: 1, expected: '0000000000000000000000000000000000000000000000000000000000000001'},
|
|
||||||
{ type: 'int', value: 16, expected: '0000000000000000000000000000000000000000000000000000000000000010'},
|
|
||||||
{ type: 'int', value: -1, expected: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'},
|
|
||||||
{ type: 'bytes32', value: 'gavofyork', expected: '6761766f66796f726b0000000000000000000000000000000000000000000000'},
|
|
||||||
{ type: 'bytes', value: 'gavofyork', expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
|
||||||
'6761766f66796f726b0000000000000000000000000000000000000000000000'}
|
|
||||||
];
|
|
||||||
|
|
||||||
describe('lib/solidity/coder', function () {
|
describe('lib/solidity/coder', function () {
|
||||||
describe('encodeParam', function () {
|
describe('encodeParam', function () {
|
||||||
tests.forEach(function (test) {
|
var test = function (t) {
|
||||||
it('should turn ' + test.value + ' to ' + test.expected, function () {
|
it('should turn ' + t.value + ' to ' + t.expected, function () {
|
||||||
assert.equal(coder.encodeParam(test.type, test.value), test.expected);
|
assert.equal(coder.encodeParam(t.type, t.value), t.expected);
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
test({ type: 'int', value: 1, expected: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ type: 'int', value: 16, expected: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ type: 'int', value: -1, expected: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ type: 'int256', value: 1, expected: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ type: 'int256', value: 16, expected: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ type: 'int256', value: -1, expected: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ type: 'bytes32', value: 'gavofyork', expected: '6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ type: 'bytes', value: 'gavofyork', expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ type: 'int[]', value: [3], expected: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ type: 'int256[]', value: [3], expected: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ type: 'int[]', value: [1,2,3], expected: '0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000002' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
describe('lib/solidity/coder', function () {
|
||||||
|
describe('encodeParams', function () {
|
||||||
|
var test = function (t) {
|
||||||
|
it('should turn ' + t.values + ' to ' + t.expected, function () {
|
||||||
|
assert.equal(coder.encodeParams(t.types, t.values), t.expected);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
test({ types: ['int'], values: [1], expected: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ types: ['int'], values: [16], expected: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ types: ['int'], values: [-1], expected: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ types: ['int256'], values: [1], expected: '0000000000000000000000000000000000000000000000000000000000000001'});
|
||||||
|
test({ types: ['int256'], values: [16], expected: '0000000000000000000000000000000000000000000000000000000000000010'});
|
||||||
|
test({ types: ['int256'], values: [-1], expected: 'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff'});
|
||||||
|
test({ types: ['bytes32'], values: ['gavofyork'], expected: '6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['bytes'], values: ['gavofyork'], expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['int[]'], values: [[3]], expected: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ types: ['int256[]'], values: [[3]], expected: '0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ types: ['int256[]'], values: [[1,2,3]], expected: '0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000002' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003'});
|
||||||
|
test({ types: ['bytes32', 'int'], values: ['gavofyork', 5],
|
||||||
|
expected: '6761766f66796f726b0000000000000000000000000000000000000000000000' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005'});
|
||||||
|
test({ types: ['int', 'bytes32'], values: [5, 'gavofyork'],
|
||||||
|
expected: '0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['bytes', 'int'], values: ['gavofyork', 5],
|
||||||
|
expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['int', 'bytes'], values: [5, 'gavofyork'],
|
||||||
|
expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000'});
|
||||||
|
test({ types: ['int', 'bytes', 'int', 'int', 'int', 'int[]'], values: [1, 'gavofyork', 2, 3, 4, [5, 6, 7]],
|
||||||
|
expected: '0000000000000000000000000000000000000000000000000000000000000009' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000002' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000004' +
|
||||||
|
'6761766f66796f726b0000000000000000000000000000000000000000000000' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000005' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000006' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000007'});
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
49
contract.js
49
contract.js
@ -2,7 +2,9 @@ var chai = require('chai');
|
|||||||
var assert = chai.assert;
|
var assert = chai.assert;
|
||||||
var web3 = require('../index');
|
var web3 = require('../index');
|
||||||
var FakeHttpProvider = require('./helpers/FakeHttpProvider');
|
var FakeHttpProvider = require('./helpers/FakeHttpProvider');
|
||||||
|
var FakeHttpProvider2 = require('./helpers/FakeHttpProvider2');
|
||||||
var utils = require('../lib/utils/utils');
|
var utils = require('../lib/utils/utils');
|
||||||
|
var BigNumber = require('bignumber.js');
|
||||||
|
|
||||||
var desc = [{
|
var desc = [{
|
||||||
"name": "balance(address)",
|
"name": "balance(address)",
|
||||||
@ -27,6 +29,18 @@ var desc = [{
|
|||||||
"type": "uint256"
|
"type": "uint256"
|
||||||
}],
|
}],
|
||||||
"outputs": []
|
"outputs": []
|
||||||
|
}, {
|
||||||
|
"name": "testArr(int[])",
|
||||||
|
"type": "function",
|
||||||
|
"inputs": [{
|
||||||
|
"name": "value",
|
||||||
|
"type": "int[]"
|
||||||
|
}],
|
||||||
|
"constant": true,
|
||||||
|
"outputs": [{
|
||||||
|
"name": "d",
|
||||||
|
"type": "int"
|
||||||
|
}]
|
||||||
}, {
|
}, {
|
||||||
"name":"Changed",
|
"name":"Changed",
|
||||||
"type":"event",
|
"type":"event",
|
||||||
@ -313,5 +327,40 @@ describe('web3.eth.contract', function () {
|
|||||||
|
|
||||||
contract.send.sendTransaction(address, 17, {from: address, gas: 50000, gasPrice: 3000, value: 10000});
|
contract.send.sendTransaction(address, 17, {from: address, gas: 50000, gasPrice: 3000, value: 10000});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should call testArr method and properly parse result', function () {
|
||||||
|
var provider = new FakeHttpProvider2();
|
||||||
|
web3.setProvider(provider);
|
||||||
|
web3.reset();
|
||||||
|
var sha3 = '0x5131231231231231231231';
|
||||||
|
var address = '0x1234567890123456789012345678901234567890';
|
||||||
|
provider.injectResultList([{
|
||||||
|
result: sha3
|
||||||
|
}, {
|
||||||
|
result: '0x0000000000000000000000000000000000000000000000000000000000000005'
|
||||||
|
}]);
|
||||||
|
var step = 0;
|
||||||
|
provider.injectValidation(function (payload) {
|
||||||
|
if (step === 1) { // getting sha3 is first
|
||||||
|
assert.equal(payload.method, 'eth_call');
|
||||||
|
assert.deepEqual(payload.params, [{
|
||||||
|
data: sha3.slice(0, 10) +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000001' +
|
||||||
|
'0000000000000000000000000000000000000000000000000000000000000003',
|
||||||
|
to: address
|
||||||
|
},
|
||||||
|
'latest'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
step++;
|
||||||
|
});
|
||||||
|
|
||||||
|
var Contract = web3.eth.contract(desc);
|
||||||
|
var contract = new Contract(address);
|
||||||
|
|
||||||
|
var result = contract.testArr([3]);
|
||||||
|
|
||||||
|
assert.deepEqual(new BigNumber(5), result);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -26,7 +26,7 @@ FakeHttpProvider.prototype.send = function (payload) {
|
|||||||
// imitate plain json object
|
// imitate plain json object
|
||||||
this.validation(JSON.parse(JSON.stringify(payload)));
|
this.validation(JSON.parse(JSON.stringify(payload)));
|
||||||
}
|
}
|
||||||
return this.response;
|
return this.getResponse();
|
||||||
};
|
};
|
||||||
|
|
||||||
FakeHttpProvider.prototype.sendAsync = function (payload, callback) {
|
FakeHttpProvider.prototype.sendAsync = function (payload, callback) {
|
||||||
@ -36,7 +36,7 @@ FakeHttpProvider.prototype.sendAsync = function (payload, callback) {
|
|||||||
// imitate plain json object
|
// imitate plain json object
|
||||||
this.validation(JSON.parse(JSON.stringify(payload)), callback);
|
this.validation(JSON.parse(JSON.stringify(payload)), callback);
|
||||||
}
|
}
|
||||||
callback(this.error, this.response);
|
callback(this.error, this.getResponse());
|
||||||
};
|
};
|
||||||
|
|
||||||
FakeHttpProvider.prototype.injectResponse = function (response) {
|
FakeHttpProvider.prototype.injectResponse = function (response) {
|
||||||
@ -56,6 +56,10 @@ FakeHttpProvider.prototype.injectBatchResults = function (results) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
FakeHttpProvider.prototype.getResponse = function () {
|
||||||
|
return this.response;
|
||||||
|
};
|
||||||
|
|
||||||
FakeHttpProvider.prototype.injectError = function (error) {
|
FakeHttpProvider.prototype.injectError = function (error) {
|
||||||
this.error = error;
|
this.error = error;
|
||||||
};
|
};
|
||||||
|
27
helpers/FakeHttpProvider2.js
Normal file
27
helpers/FakeHttpProvider2.js
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
var FakeHttpProvider = require('./FakeHttpProvider');
|
||||||
|
|
||||||
|
var FakeHttpProvider2 = function () {
|
||||||
|
this.counter = 0;
|
||||||
|
this.resultList = [];
|
||||||
|
};
|
||||||
|
|
||||||
|
FakeHttpProvider2.prototype = new FakeHttpProvider();
|
||||||
|
FakeHttpProvider2.prototype.constructor = FakeHttpProvider2;
|
||||||
|
|
||||||
|
FakeHttpProvider2.prototype.injectResultList = function (list) {
|
||||||
|
this.resultList = list;
|
||||||
|
};
|
||||||
|
|
||||||
|
FakeHttpProvider2.prototype.getResponse = function () {
|
||||||
|
var result = this.resultList[this.counter];
|
||||||
|
this.counter++;
|
||||||
|
if (result.type === 'batch') {
|
||||||
|
this.injectBatchResults(result.result);
|
||||||
|
} else {
|
||||||
|
this.injectResult(result.result);
|
||||||
|
}
|
||||||
|
return this.response;
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = FakeHttpProvider2;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user