Page MenuHomePhabricator

[Cashtab] [Chronik] [Tx Gen] Sign and build Tx
ClosedPublic

Authored by emack on Jul 5 2022, 05:14.

Details

Reviewers
bytesofman
Group Reviewers
Restricted Project
Commits
rABC8dc6cac67987: [Cashtab] [Chronik] [Tx Gen] Sign and build Tx
Summary

As per T2503, this is part of a series of diffs to refactor the transaction generation process within useBCH.

This diff is a standalone utility function which signs the input UTXOs and converts the transaction builder instance into a raw tx hex ready for broadcast to a node.

This function returns a hex string.

Test Plan

npm test
observe successful execution of signAndBuildTx() unit tests

Diff Detail

Repository
rABC Bitcoin ABC
Branch
buildTx
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 19609
Build 38937: Build Diffcashtab-tests
Build 38936: arc lint + arc unit

Event Timeline

emack requested review of this revision.Jul 5 2022, 05:14
bytesofman requested changes to this revision.Jul 5 2022, 18:00
bytesofman added inline comments.
web/cashtab/src/utils/__tests__/cashMethods.test.js
179 ↗(On Diff #34243)
  1. Add a test with multiple input utxos
  2. Add a test with multiple input utxos and multiple output utxos
web/cashtab/src/utils/cashMethods.js
11 ↗(On Diff #34243)

Let's call this signAndBuildTx, just to be more descriptive -- also change references to this function name in comments

This revision now requires changes to proceed.Jul 5 2022, 18:00
emack marked 2 inline comments as done.

Added additional unit test coverage for multiple input and output UTXOs.
Function name change.

emack retitled this revision from [Cashtab] [Chronik] [Tx Gen] Build Tx to [Cashtab] [Chronik] [Tx Gen] Sign and build Tx.Jul 6 2022, 03:51
emack edited the summary of this revision. (Show Details)
emack edited the test plan for this revision. (Show Details)
bytesofman requested changes to this revision.Jul 6 2022, 23:11
bytesofman added inline comments.
web/cashtab/src/utils/__tests__/cashMethods.test.js
244 ↗(On Diff #34268)

I can see what you're up to here, but I don't think we can assume some future dev will. It's confusing that this output is made from mockMultipleInputUtxos

The best way to do all of these tests is to use data from real transactions. I can see some idealized cases being used for these fragment functions. We'll need to test the new combined sendXec function against all of the old txs and unit tests as well, so might as well start now -- there are lots of input utxos and tx hashes in those mocks.

If there is not a good candidate there, at least include a few sentences about what you are doing to build this mocked output.

web/cashtab/src/utils/cashMethods.js
13 ↗(On Diff #34268)

At this point, is it possible to do any kind of validation check on txBuilder? It should have inputs and outputs. I'm not sure what this JS object looks like though.

If this is not practical, use try...catch. in case txBuilder.build() or txBuilder.sign() fails in some way.

This revision now requires changes to proceed.Jul 6 2022, 23:11
emack marked an inline comment as done.

cashMethods.js

  • see https://reviews.bitcoinabc.org/D11719#change-YgPIGHoiluM7 for what the txBuilder object looks like as it is passed into this signAndBuildTx function. The inputs are empty until the inputUtxos are signed with the wif. Therefore the input validation at the start of cashMethods.js is only checking against txBuilder.transaction.tx.outs.length
  • try catch block added around txBuilder.build() and txBuilder.sign()

cashMethods.test.js

  • real data now being used in mockTxBuilderData.js to reflect one to one and one to many send XEC txs. There weren't any existing mock candidates for this because the same inputUtxo object needs to also have the wif when passed into the signAndBuildTx() function to sign the input utxos.
bytesofman requested changes to this revision.Jul 8 2022, 16:43
bytesofman added inline comments.
web/cashtab/src/utils/cashMethods.js
23 ↗(On Diff #34308)

What happens if there is an error in this for loop?

Also needs try...catch wrapper

This revision now requires changes to proceed.Jul 8 2022, 16:43
emack marked an inline comment as done.

Wrapped txBuilder.sign() within a try...catch block and updated function and unit test to check for empty inputUtxos.

This revision is now accepted and ready to land.Jul 11 2022, 23:50