Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature branch for SDK 2.2.0 #1512

Merged
merged 35 commits into from
Aug 21, 2024
Merged

Feature branch for SDK 2.2.0 #1512

merged 35 commits into from
Aug 21, 2024

Conversation

str4d
Copy link
Contributor

@str4d str4d commented Jul 2, 2024

Note
This code review checklist is intended to serve as a starting point for the author and reviewer, although it may not be appropriate for all types of changes (e.g. fixing a spelling typo in documentation). For more in-depth discussion of how we think about code review, please see Code Review Guidelines.

Author

  • Self-review your own code in GitHub's web interface1
  • Add automated tests as appropriate
  • Update the manual tests2 as appropriate
  • Check the code coverage3 report for the automated tests
  • Update documentation as appropriate (e.g README.md, Architecture.md, etc.)
  • Run the demo app and try the changes
  • Pull in the latest changes from the main branch and squash your commits before assigning a reviewer4

Reviewer

  • Check the code with the Code Review Guidelines checklist
  • Perform an ad hoc review5
  • Review the automated tests
  • Review the manual tests
  • Review the documentation, README.md, Architecture.md, etc. as appropriate
  • Run the demo app and try the changes6

Footnotes

  1. Code often looks different when reviewing the diff in a browser, making it easier to spot potential bugs.

  2. While we aim for automated testing of the SDK, some aspects require manual testing. If you had to manually test
    something during development of this pull request, write those steps down.

  3. While we are not looking for perfect coverage, the tool can point out potential cases that have been missed. Code coverage can be generated with: ./gradlew check for Kotlin modules and ./gradlew connectedCheck -PIS_ANDROID_INSTRUMENTATION_TEST_COVERAGE_ENABLED=true for Android modules.

  4. Having your code up to date and squashed will make it easier for others to review. Use best judgement when squashing commits, as some changes (such as refactoring) might be easier to review as a separate commit.

  5. In addition to a first pass using the code review guidelines, do a second pass using your best judgement and experience which may identify additional questions or comments. Research shows that code review is most effective when done in multiple passes, where reviewers look for different things through each pass.

  6. While the CI server runs the demo app to look for build failures or crashes, humans running the demo app are
    more likely to notice unexpected log messages, UI inconsistencies, or bad output data. Perform this step last, after verifying the code changes are safe to run locally.

str4d and others added 14 commits July 2, 2024 14:29
This includes support for creating transaction proposals that send to
TEX addresses.
This fixes several existing issues:
- The Rust backend's `proposeTransfer` expected to receive `null` for no
  memo, but was instead receiving an empty array. `proposeShielding`
  meanwhile was always expecting a memo.
- The Kotlin side had nullable byte arrays, but then always converted an
  empty string to an empty byte array instead of `null`.
Filed a follow-up issue #1534
@HonzaR
Copy link
Contributor

HonzaR commented Jul 25, 2024

I tested this branch behavior to check if the Unable to compute root error while sending funds is resolved. I couldn't reproduce it, but I observed the same bug I reported on the branch zip-320: sending/sent funds is represented as receiving/received now, and the balance of such a trx is also different than it was submitted (i.e., the v_transactions problem, as we discussed internally). That is expected, I suppose.

@HonzaR
Copy link
Contributor

HonzaR commented Aug 5, 2024

@str4d I can still observe the same behavior as described in my comment above, even after some changes have been made before the zip-320 branch has been updated and merged into this one. What are our next steps here?

@HonzaR
Copy link
Contributor

HonzaR commented Aug 5, 2024

Conflicts in the changelog resolved

@str4d
Copy link
Contributor Author

str4d commented Aug 7, 2024

I've restored the previous state of the PR, and fixed the changelog conflict by merging main into the feature branch.

@str4d
Copy link
Contributor Author

str4d commented Aug 10, 2024

Redid the merge from main because the previous changelog resolution was horrible to undo after the 2.1.3 release.

str4d and others added 6 commits August 9, 2024 18:01
HonzaR and others added 6 commits August 9, 2024 18:08
# Conflicts:
#	CHANGELOG.md
#	sdk-lib/src/main/java/cash/z/ecc/android/sdk/SdkSynchronizer.kt
#	sdk-lib/src/main/java/cash/z/ecc/android/sdk/Synchronizer.kt
Add `Synchronizer` APIs for USD/ZEC exchange rate
* Tor initialization and disposal

* Code cleanup
@Milan-Cerovsky Milan-Cerovsky self-requested a review August 20, 2024 09:38
str4d and others added 2 commits August 20, 2024 19:21
* Fix RawTransactionUnsafe to handle height response correctly

* Migrate to latest revision of librustzcash crates

* Expose transaction_data_requests and set_transaction_status across JNI

* New usage of setTransactionStatus

- Distinct between decryptAndStoreTransaction and setTransactionStatus path by minedHeight
- Convert from RawStatusUnsafe to TransactionStatus
- Add RawTransaction object and related functions
- These changes resolve older issue #1254

* New usage of transactionDataRequests

- New backend.transactionDataRequests and related logic is now used within CompactBlockProcessor
- getTAddressTransactions from LightWalletclient module is now newly used
- These also changes remove now unused querying transactions-related functions from  v_transactions

* Decrypt and store all types of transactions

In case of SpendsFromAddress flow

* Fix passing JniTransactionDataRequest to Kotlin

* Fix ktlint and detekt warnings

* Changelog update

* Code cleanup

* Process SpendsFromAddress on stream

Instead of consuming the stream into list and working with list

* Fix ktlint warnings

* Target latest librustzcash commit

* Move to the latest Rust crates commit

* Change setTransactionStatus trigger

Handle setTransactionStatus by TransactionDataRequest rather then minedHeight

* Fix getTAddressTransactions input range

---------

Co-authored-by: Honza <[email protected]>
- `zcash_address 0.4`
- `zcash_client_backend 0.13`
- `zcash_client_sqlite 0.11`
- `zcash_primitives 0.16`
- `zcash_proofs 0.16`
@HonzaR HonzaR marked this pull request as ready for review August 20, 2024 21:04
@HonzaR HonzaR requested review from nuttycom and daira August 20, 2024 21:05
Copy link
Contributor

@HonzaR HonzaR left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sending funds to a TEX address works as expected modulo Status.UNKNOWN instead of Status.NOT_FOUND bug I reported internally and is now filed zcash/lightwalletd#497

@nuttycom nuttycom mentioned this pull request Aug 21, 2024
13 tasks
Copy link
Contributor

@nuttycom nuttycom left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

utACK 449017c

@Milan-Cerovsky Milan-Cerovsky merged commit 618e8eb into main Aug 21, 2024
11 of 12 checks passed
@Milan-Cerovsky Milan-Cerovsky deleted the feature-2.2.0 branch August 21, 2024 15:33
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants