diff --git a/test/integration/p2sh.js b/test/integration/p2sh.js index b3708ca..4db20af 100644 --- a/test/integration/p2sh.js +++ b/test/integration/p2sh.js @@ -11,12 +11,12 @@ var Script = bitcoin.Script var helloblock = require('helloblock-js')({ network: 'testnet' -}); +}) -describe('p2sh', function() { - this.timeout(10000); +describe('Bitcoin-js', function() { + this.timeout(10000) - it('spends from a 2-of-2 address', function(done) { + it('can spend from a 2-of-2 address', function(done) { var privKeys = [ '91avARGdfge8E4tZfYLoxeJ5sGBdNJQH4kvjJoQFacbgwmaKkrx', '91avARGdfge8E4tZfYLoxeJ5sGBdNJQH4kvjJoQFacbgww7vXtT' @@ -24,52 +24,54 @@ describe('p2sh', function() { return ECKey.fromWIF(wif) }) - var pubKeys = privKeys.map(function(eck) { - return eck.pub - }) + // how much to withdraw if we run dry + var coldAmount = 2e4 + var outputAmount = 1e4 + + var pubKeys = privKeys.map(function(eck) { return eck.pub }) var redeemScript = Script.createMultisigScriptPubKey(2, pubKeys) var hash160 = crypto.hash160(new Buffer(redeemScript.buffer)) - var multisigAddress = new Address(hash160, networks.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, networks.testnet) - - var signatures = privKeys.map(function(privKey) { - return tx.signScriptSig(0, redeemScript, privKey) - }) - - var redeemScriptSig = Script.createMultisigScriptSig(signatures) - var scriptSig = Script.createP2SHScriptSig(redeemScriptSig, redeemScript) - tx.setScriptSig(0, scriptSig) - - // Send from mutlsigAddress to targetAddress - helloblock.transactions.propagate(tx.toHex(), 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() - }) - }) + var multisigAddress = new Address(hash160, networks.testnet.scriptHash).toString() + + // Send some testnet coins to the multisig address to ensure it has some unspents for later + helloblock.faucet.withdraw(multisigAddress, coldAmount, function(err) { + if (err) return done(err) + }) + + // make a random private key + var targetAddress = ECKey.makeRandom().pub.getAddress(networks.testnet.pubKeyHash).toString() + + // get latest unspents from the multisigAddress + helloblock.addresses.getUnspents(multisigAddress, function(err, resp, resource) { + if (err) return done(err) + + // use the oldest unspent + var unspent = resource[resource.length - 1] + var spendAmount = Math.min(unspent.value, outputAmount) + + var tx = new Transaction() + tx.addInput(unspent.txHash, unspent.index) + tx.addOutput(targetAddress, spendAmount) + + var signatures = privKeys.map(function(privKey) { + return tx.signScriptSig(0, redeemScript, privKey) + }) + + var redeemScriptSig = Script.createMultisigScriptSig(signatures) + var scriptSig = Script.createP2SHScriptSig(redeemScriptSig, redeemScript) + tx.setScriptSig(0, scriptSig) + + // broadcast our transaction + helloblock.transactions.propagate(tx.toHex(), function(err, resp, resource) { + // no err means that the transaction has been successfully propagated + if (err) return done(err) + + // Check that the funds (spendAmount Satoshis) indeed arrived at the intended address + helloblock.addresses.get(targetAddress, function(err, resp, resource) { + if (err) return done(err) + + assert.equal(resource.balance, spendAmount) + done() }) }) })