-
Notifications
You must be signed in to change notification settings - Fork 11
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
Conversation
Rust updates and cleanups
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
I tested this branch behavior to check if the |
ZIP 320 (TEX address) support
Conflicts in the changelog resolved |
I've restored the previous state of the PR, and fixed the changelog conflict by merging |
Redid the merge from |
* Exchange rates API refactor * Code cleanup * Demo app updates * Exchange rate implementation * Detekt and ktlint checks * Code cleanup
# 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
* 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`
There was a problem hiding this 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
demo-app/src/main/java/cash/z/ecc/android/sdk/demoapp/demos/getbalance/GetBalanceFragment.kt
Show resolved
Hide resolved
sdk-lib/src/main/java/cash/z/ecc/android/sdk/internal/block/CompactBlockDownloader.kt
Show resolved
Hide resolved
sdk-lib/src/main/java/cash/z/ecc/android/sdk/block/processor/CompactBlockProcessor.kt
Show resolved
Hide resolved
sdk-lib/src/main/java/cash/z/ecc/android/sdk/block/processor/CompactBlockProcessor.kt
Show resolved
Hide resolved
sdk-lib/src/main/java/cash/z/ecc/android/sdk/block/processor/CompactBlockProcessor.kt
Outdated
Show resolved
Hide resolved
sdk-lib/src/main/java/cash/z/ecc/android/sdk/internal/model/ext/RawTransactionUnsafeExt.kt
Outdated
Show resolved
Hide resolved
…or-handling Fetch transaction error handling
Co-authored-by: Kris Nuttycombe <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
utACK 449017c
Author
Reviewer
Footnotes
Code often looks different when reviewing the diff in a browser, making it easier to spot potential bugs. ↩
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. ↩
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. ↩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. ↩
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. ↩
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. ↩