Skip to content

Commit

Permalink
Set the db sync height
Browse files Browse the repository at this point in the history
Previously we weren't setting the db sync height in populate_test_db
macro even when current height is provided.. This creates a bug that
get_funded_wallet will return 0 balance.

This PR fixes the populate_test_db macro and updates tests which were
previously dependent on the unsynced wallet behavior.
  • Loading branch information
rajarshimaitra committed Aug 25, 2022
1 parent 588c17f commit fdf1f5c
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 7 deletions.
30 changes: 26 additions & 4 deletions src/database/memory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -486,7 +486,8 @@ macro_rules! populate_test_db {
}};
($db:expr, $tx_meta:expr, $current_height:expr, (@coinbase $is_coinbase:expr)$(,)?) => {{
use std::str::FromStr;
use $crate::database::BatchOperations;
use $crate::database::SyncTime;
use $crate::database::{BatchOperations, Database};
let mut db = $db;
let tx_meta = $tx_meta;
let current_height: Option<u32> = $current_height;
Expand All @@ -512,13 +513,34 @@ macro_rules! populate_test_db {
};

let txid = tx.txid();
let confirmation_time = tx_meta
// Set Confirmation time only if current height is provided. Else None.
let confirmation_time = if let Some(height) = current_height {
tx_meta
.min_confirmations
.and_then(|v| if v == 0 { None } else { Some(v) })
.map(|conf| $crate::BlockTime {
height: current_height.unwrap().checked_sub(conf as u32).unwrap() + 1,
height: height.checked_sub(conf as u32).unwrap() + 1,
timestamp: 0,
});
})
} else {
None
};

// Set the database sync_time.
// Check if the current_height is less than already known sync height, apply the max
// If any of them is None, the other will be applied instead.
// If both are None, this will not be set.
if let Some(height) = db.get_sync_time().unwrap()
.and_then(|sync_time| Some(sync_time.block_time.height))
.max(current_height) {
let sync_time = SyncTime {
block_time: BlockTime {
height,
timestamp: 0
}
};
db.set_sync_time(sync_time).unwrap();
}

let tx_details = $crate::TransactionDetails {
transaction: Some(tx.clone()),
Expand Down
58 changes: 55 additions & 3 deletions src/wallet/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1926,6 +1926,12 @@ pub(crate) mod test {
// OP_PUSH.
const P2WPKH_FAKE_WITNESS_SIZE: usize = 106;

#[test]
fn test_get_funded_wallet_balance() {
let (wallet, _, _) = get_funded_wallet(get_test_wpkh());
assert_eq!(wallet.get_balance().unwrap().confirmed, 50000);
}

#[test]
fn test_cache_addresses_fixed() {
let db = MemoryDatabase::new();
Expand Down Expand Up @@ -2173,7 +2179,22 @@ pub(crate) mod test {

#[test]
fn test_create_tx_default_locktime() {
let (wallet, _, _) = get_funded_wallet(get_test_wpkh());
let descriptors = testutils!(@descriptors (get_test_wpkh()));
let wallet = Wallet::new(
&descriptors.0,
None,
Network::Regtest,
AnyDatabase::Memory(MemoryDatabase::new()),
)
.unwrap();

let tx_meta = testutils! {
@tx ( (@external descriptors, 0) => 50_000 ) (@confirmations 1)
};

// Add the transaction to our db, but do not sync the db.
crate::populate_test_db!(wallet.database.borrow_mut(), tx_meta, None);

let addr = wallet.get_address(New).unwrap();
let mut builder = wallet.build_tx();
builder.add_recipient(addr.script_pubkey(), 25_000);
Expand Down Expand Up @@ -2364,7 +2385,23 @@ pub(crate) mod test {

#[test]
fn test_create_tx_default_sequence() {
let (wallet, _, _) = get_funded_wallet(get_test_wpkh());
let descriptors = testutils!(@descriptors (get_test_wpkh()));
let wallet = Wallet::new(
&descriptors.0,
None,
Network::Regtest,
AnyDatabase::Memory(MemoryDatabase::new()),
)
.unwrap();

let tx_meta = testutils! {
@tx ( (@external descriptors, 0) => 50_000 ) (@confirmations 1)
};

// Add the transaction to our db, but do not sync the db. Unsynced db
// should trigger the default sequence value for a new transaction as 0xFFFFFFFF
crate::populate_test_db!(wallet.database.borrow_mut(), tx_meta, None);

let addr = wallet.get_address(New).unwrap();
let mut builder = wallet.build_tx();
builder.add_recipient(addr.script_pubkey(), 25_000);
Expand Down Expand Up @@ -2862,7 +2899,22 @@ pub(crate) mod test {

#[test]
fn test_create_tx_policy_path_no_csv() {
let (wallet, _, _) = get_funded_wallet(get_test_a_or_b_plus_csv());
let descriptors = testutils!(@descriptors (get_test_wpkh()));
let wallet = Wallet::new(
&descriptors.0,
None,
Network::Regtest,
AnyDatabase::Memory(MemoryDatabase::new()),
)
.unwrap();

let tx_meta = testutils! {
@tx ( (@external descriptors, 0) => 50_000 ) (@confirmations 1)
};

// Add the transaction to our db, but do not sync the db. Unsynced db
// should trigger the default sequence value for a new transaction as 0xFFFFFFFF
crate::populate_test_db!(wallet.database.borrow_mut(), tx_meta, None);

let external_policy = wallet.policies(KeychainKind::External).unwrap().unwrap();
let root_id = external_policy.id;
Expand Down

0 comments on commit fdf1f5c

Please sign in to comment.