Browse Source

add Transaction#clearOutputs

patch-2
Manuel Araoz 10 years ago
parent
commit
8a13a22baf
  1. 4
      docs/transaction.md
  2. 19
      lib/transaction/transaction.js
  3. 33
      test/transaction/transaction.js

4
docs/transaction.md

@ -129,7 +129,7 @@ The following methods are used to manage signatures for a transaction:
* `clearSignatures`: removes all signatures for this input * `clearSignatures`: removes all signatures for this input
* `isFullySigned`: returns true if the input is fully signed * `isFullySigned`: returns true if the input is fully signed
## Adding outputs ## Handling Outputs
Outputs can be added by: Outputs can be added by:
@ -137,6 +137,8 @@ Outputs can be added by:
* The `to(address, amount)` method, that adds an output with the script that corresponds to the given address. Builds an output and calls the `addOutput` method. * The `to(address, amount)` method, that adds an output with the script that corresponds to the given address. Builds an output and calls the `addOutput` method.
* Specifying a [change address](#Fee_calculation) * Specifying a [change address](#Fee_calculation)
To remove all outputs, you can use `clearOutputs()`, which preserves change output configuration.
## Serialization ## Serialization
There are a series of methods used for serialization: There are a series of methods used for serialization:

19
lib/transaction/transaction.js

@ -639,10 +639,11 @@ Transaction.prototype.fee = function(amount) {
* Beware that this resets all the signatures for inputs (in further versions, * Beware that this resets all the signatures for inputs (in further versions,
* SIGHASH_SINGLE or SIGHASH_NONE signatures will not be reset). * SIGHASH_SINGLE or SIGHASH_NONE signatures will not be reset).
* *
* @param {address} An address for change to be sent to. * @param {Address} address An address for change to be sent to.
* @return {Transaction} this, for chaining * @return {Transaction} this, for chaining
*/ */
Transaction.prototype.change = function(address) { Transaction.prototype.change = function(address) {
$.checkArgument(address, 'address is required');
this._changeScript = Script.fromAddress(address); this._changeScript = Script.fromAddress(address);
this._updateChangeOutput(); this._updateChangeOutput();
return this; return this;
@ -713,6 +714,22 @@ Transaction.prototype.addOutput = function(output) {
return this; return this;
}; };
/**
* Remove all outputs from the transaction.
*
* @return {Transaction} this, for chaining
*/
Transaction.prototype.clearOutputs = function() {
this.outputs = [];
this._clearSignatures();
this._outputAmount = undefined;
this._changeIndex = undefined;
this._updateChangeOutput();
return this;
};
Transaction.prototype._addOutput = function(output) { Transaction.prototype._addOutput = function(output) {
this.outputs.push(output); this.outputs.push(output);
this._outputAmount = undefined; this._outputAmount = undefined;

33
test/transaction/transaction.js

@ -143,6 +143,9 @@ describe('Transaction', function() {
script: Script.buildPublicKeyHashOut(fromAddress).toString(), script: Script.buildPublicKeyHashOut(fromAddress).toString(),
satoshis: 1e8 satoshis: 1e8
}; };
var tenth = 1e7;
var fourth = 25e6;
var half = 5e7;
describe('adding inputs', function() { describe('adding inputs', function() {
@ -499,7 +502,9 @@ describe('Transaction', function() {
'satoshis': testAmount 'satoshis': testAmount
}).to('mrU9pEmAx26HcbKVrABvgL7AwA5fjNFoDc', testAmount - 10000); }).to('mrU9pEmAx26HcbKVrABvgL7AwA5fjNFoDc', testAmount - 10000);
tx.toBuffer = sinon.stub().returns({length: 10000000}); tx.toBuffer = sinon.stub().returns({
length: 10000000
});
var verify = tx.verify(); var verify = tx.verify();
verify.should.equal('transaction over the maximum block size'); verify.should.equal('transaction over the maximum block size');
@ -738,9 +743,6 @@ describe('Transaction', function() {
describe('output ordering', function() { describe('output ordering', function() {
var tenth = 1e7;
var fourth = 25e6;
var half = 5e7;
var transaction, out1, out2, out3, out4; var transaction, out1, out2, out3, out4;
beforeEach(function() { beforeEach(function() {
@ -791,6 +793,29 @@ describe('Transaction', function() {
}).to.throw(errors.Transaction.InvalidSorting); }).to.throw(errors.Transaction.InvalidSorting);
}); });
});
describe('clearOutputs', function() {
it('removes all outputs and maintains the transaction in order', function() {
var tx = new Transaction()
.from(simpleUtxoWith1BTC)
.to(toAddress, tenth)
.to(toAddress, fourth)
.to(toAddress, half)
.change(changeAddress);
tx.clearOutputs();
tx.outputs.length.should.equal(1);
tx.to(toAddress, tenth);
tx.outputs.length.should.equal(2);
tx.outputs[0].satoshis.should.equal(10000000);
tx.outputs[0].script.toAddress().toString().should.equal(toAddress);
tx.outputs[1].satoshis.should.equal(89990000);
tx.outputs[1].script.toAddress().toString().should.equal(changeAddress);
});
}); });
}); });

Loading…
Cancel
Save