Browse Source

integration: stop async tests causing wrong balance

hk-custom-address
Daniel Cousens 11 years ago
parent
commit
c9f9d86cb4
  1. 98
      test/integration/p2sh.js

98
test/integration/p2sh.js

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

Loading…
Cancel
Save