integration tests for scripthash transcations
This commit is contained in:
parent
953223c818
commit
fe4332bfbd
2 changed files with 81 additions and 1 deletions
|
@ -21,7 +21,8 @@
|
|||
"node-browserify": "https://github.com/substack/node-browserify/tarball/master",
|
||||
"sinon": "1.9.0",
|
||||
"coveralls": "~2.10.0",
|
||||
"mocha-lcov-reporter": "0.0.1"
|
||||
"mocha-lcov-reporter": "0.0.1",
|
||||
"helloblock-js": "^0.2.1"
|
||||
},
|
||||
"testling": {
|
||||
"browsers": [
|
||||
|
|
79
test/integration.js
Normal file
79
test/integration.js
Normal file
|
@ -0,0 +1,79 @@
|
|||
var assert = require('assert');
|
||||
|
||||
var Address = require('../src/address');
|
||||
var ECKey = require('../src/eckey').ECKey;
|
||||
var T = require('../src/transaction');
|
||||
var Transaction = T.Transaction;
|
||||
var Script = require('../src/script');
|
||||
var network = require('../src/network');
|
||||
var crypto = require('../src/crypto');
|
||||
|
||||
var helloblock = require('helloblock-js')({
|
||||
network: 'testnet'
|
||||
});
|
||||
|
||||
describe('integration', function() {
|
||||
this.timeout(10000);
|
||||
|
||||
it('scripthash transactions', function(done) {
|
||||
// 2-of-2 scripthash
|
||||
var privKeys = [
|
||||
'91avARGdfge8E4tZfYLoxeJ5sGBdNJQH4kvjJoQFacbgwmaKkrx',
|
||||
'91avARGdfge8E4tZfYLoxeJ5sGBdNJQH4kvjJoQFacbgww7vXtT'
|
||||
].map(function(wif) {
|
||||
return ECKey.fromWIF(wif)
|
||||
})
|
||||
|
||||
var pubKeys = privKeys.map(function(eck) {
|
||||
return eck.pub
|
||||
})
|
||||
var pubKeyBuffers = pubKeys.map(function(q) {
|
||||
return q.toBuffer()
|
||||
})
|
||||
var redeemScript = Script.createMultisigOutputScript(2, pubKeyBuffers)
|
||||
var hash160 = crypto.hash160(redeemScript.buffer)
|
||||
var multisigAddress = new Address(hash160, network.testnet.scriptHash)
|
||||
|
||||
// Check what our target address's starting value is
|
||||
var targetAddress = 'mrCDrCybB6J1vRfbwM5hemdJz73FwDBC8r';
|
||||
helloblock.addresses.get(targetAddress, function(err, resp, resource) {
|
||||
if (err) done(err);
|
||||
var startingBalance = resource.balance
|
||||
|
||||
// Send some testnet coins to the multisig address so we ensure it has some unspents
|
||||
helloblock.faucet.withdraw(multisigAddress.toString(), 100000, function(err, resp, resource) {
|
||||
if (err) done(err);
|
||||
|
||||
// Get latest unspents from the mutlsigAddress
|
||||
helloblock.addresses.getUnspents(multisigAddress.toString(), function(err, resp, resource) {
|
||||
if (err) done(err);
|
||||
|
||||
var tx = new Transaction()
|
||||
var unspent = resource[0];
|
||||
tx.addInput(unspent.txHash, unspent.index)
|
||||
tx.addOutput(targetAddress, 100000, network.testnet)
|
||||
|
||||
var signatures = privKeys.map(function(privKey) {
|
||||
return tx.signScriptSig(0, redeemScript, privKey)
|
||||
})
|
||||
|
||||
var scriptSig = Script.createP2SHMultisigScriptSig(signatures, redeemScript)
|
||||
tx.setScriptSig(0, scriptSig)
|
||||
|
||||
// Send from mutlsigAddress to targetAddress
|
||||
helloblock.transactions.propagate(tx.serializeHex(), function(err, resp, resource) {
|
||||
// no err means that transaction has been successfully propagated
|
||||
if (err) done(err);
|
||||
|
||||
// Check that the funds (100000) indeed arrived at the intended target address
|
||||
helloblock.addresses.get(targetAddress, function(err, resp, resource) {
|
||||
if (err) done(err);
|
||||
assert.equal(resource.balance, startingBalance + 100000)
|
||||
done()
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
Loading…
Reference in a new issue