3
0
mirror of https://github.com/Qortal/altcoinj.git synced 2025-02-13 02:35:52 +00:00

TransactionInput.disconnect() - make it work for UTXO based wallet

This commit is contained in:
Oscar Guindzberg 2016-08-25 18:43:58 -03:00 committed by Andreas Schildbach
parent 0566917a8f
commit 00c03e1c05
3 changed files with 114 additions and 5 deletions

View File

@ -359,11 +359,23 @@ public class TransactionInput extends ChildMessage {
* @return true if the disconnection took place, false if it was not connected.
*/
public boolean disconnect() {
if (outpoint.fromTx == null) return false;
TransactionOutput output = outpoint.fromTx.getOutput((int) outpoint.getIndex());
if (output.getSpentBy() == this) {
output.markAsUnspent();
TransactionOutput connectedOutput;
if (outpoint.fromTx != null) {
// The outpoint is connected using a "standard" wallet, disconnect it.
connectedOutput = outpoint.fromTx.getOutput((int) outpoint.getIndex());
outpoint.fromTx = null;
} else if (outpoint.connectedOutput != null) {
// The outpoint is connected using a UTXO based wallet, disconnect it.
connectedOutput = outpoint.connectedOutput;
outpoint.connectedOutput = null;
} else {
// The outpoint is not connected, do nothing.
return false;
}
if (connectedOutput != null && connectedOutput.getSpentBy() == this) {
// The outpoint was connected to an output, disconnect the output.
connectedOutput.markAsUnspent();
return true;
} else {
return false;

View File

@ -44,7 +44,7 @@ public class TransactionOutPoint extends ChildMessage {
Transaction fromTx;
// The connected output.
private TransactionOutput connectedOutput;
TransactionOutput connectedOutput;
public TransactionOutPoint(NetworkParameters params, long index, @Nullable Transaction fromTx) {
super(params);

View File

@ -0,0 +1,97 @@
/*
* Copyright by the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.bitcoinj.core;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNull;
import java.util.List;
import org.bitcoinj.params.UnitTestParams;
import org.bitcoinj.script.ScriptBuilder;
import org.bitcoinj.testing.FakeTxBuilder;
import org.bitcoinj.wallet.AllowUnconfirmedCoinSelector;
import org.bitcoinj.wallet.SendRequest;
import org.bitcoinj.wallet.Wallet;
import org.junit.Test;
import com.google.common.collect.Lists;
public class TransactionInputTest {
@Test
public void testStandardWalletDisconnect() throws Exception {
NetworkParameters params = UnitTestParams.get();
Wallet w = new Wallet(new Context(params));
w.setCoinSelector(new AllowUnconfirmedCoinSelector());
Address a = w.currentReceiveAddress();
Transaction tx1 = FakeTxBuilder.createFakeTxWithoutChangeAddress(params, Coin.COIN, a);
w.receivePending(tx1, null);
Transaction tx2 = new Transaction(params);
tx2.addOutput(Coin.valueOf(99000000), new ECKey());
w.completeTx(SendRequest.forTx(tx2));
TransactionInput txInToDisconnect = tx2.getInput(0);
assertEquals(tx1, txInToDisconnect.getOutpoint().fromTx);
assertNull(txInToDisconnect.getOutpoint().connectedOutput);
txInToDisconnect.disconnect();
assertNull(txInToDisconnect.getOutpoint().fromTx);
assertNull(txInToDisconnect.getOutpoint().connectedOutput);
}
@Test
public void testUTXOWalletDisconnect() throws Exception {
final NetworkParameters params = UnitTestParams.get();
Wallet w = new Wallet(new Context(params));
Address a = w.currentReceiveAddress();
final UTXO utxo = new UTXO(Sha256Hash.of(new byte[] { 1, 2, 3 }), 1, Coin.COIN, 0, false,
ScriptBuilder.createOutputScript(a));
w.setUTXOProvider(new UTXOProvider() {
@Override
public NetworkParameters getParams() {
return params;
}
@Override
public List<UTXO> getOpenTransactionOutputs(List<Address> addresses) throws UTXOProviderException {
return Lists.newArrayList(utxo);
}
@Override
public int getChainHeadHeight() throws UTXOProviderException {
return Integer.MAX_VALUE;
}
});
Transaction tx2 = new Transaction(params);
tx2.addOutput(Coin.valueOf(99000000), new ECKey());
w.completeTx(SendRequest.forTx(tx2));
TransactionInput txInToDisconnect = tx2.getInput(0);
assertNull(txInToDisconnect.getOutpoint().fromTx);
assertEquals(utxo.getHash(), txInToDisconnect.getOutpoint().connectedOutput.getParentTransactionHash());
txInToDisconnect.disconnect();
assertNull(txInToDisconnect.getOutpoint().fromTx);
assertNull(txInToDisconnect.getOutpoint().connectedOutput);
}
}