zebra-scan 0.1.0-alpha.15

Shielded transaction scanner for the Zcash blockchain
Documentation
//! Fixed test vectors for the scanner Storage.

use zebra_chain::{block::Height, parameters::Network};
use zebra_state::TransactionIndex;

use crate::{
    storage::db::tests::{fake_sapling_results, new_test_storage},
    tests::ZECPAGES_SAPLING_VIEWING_KEY,
};

/// Tests that keys are deleted correctly
#[test]
pub fn deletes_keys_and_results_correctly() {
    let mut db = new_test_storage(&Network::Mainnet);

    let zec_pages_sapling_efvk = ZECPAGES_SAPLING_VIEWING_KEY.to_string();

    // Replace the last letter of the zec_pages efvk
    let fake_efvk = format!(
        "{}t",
        &ZECPAGES_SAPLING_VIEWING_KEY[..ZECPAGES_SAPLING_VIEWING_KEY.len() - 1]
    );

    let efvks = [&zec_pages_sapling_efvk, &fake_efvk];
    let fake_heights = [Height::MIN, Height(1), Height::MAX];
    let fake_transaction_indexes = [
        TransactionIndex::MIN,
        TransactionIndex::from_index(40),
        TransactionIndex::MAX,
    ];

    for efvk in efvks {
        for fake_result_height in fake_heights {
            db.insert_sapling_results(
                efvk,
                fake_result_height,
                fake_sapling_results(fake_transaction_indexes),
            );
        }
    }

    let expected_num_entries = fake_heights.len();
    let expected_num_results_per_entry = fake_transaction_indexes.len();

    for efvk in efvks {
        assert_eq!(
            db.sapling_results(efvk).len(),
            expected_num_entries,
            "there should be {expected_num_entries} entries for this key in the db"
        );

        for (_, result) in db.sapling_results(efvk) {
            assert_eq!(
                result.len(),
                expected_num_results_per_entry,
                "there should be {expected_num_results_per_entry} results for this entry in the db"
            );
        }

        db.delete_sapling_keys(vec![efvk.clone()]);

        assert!(
            db.sapling_results(efvk).is_empty(),
            "all results for this key should have been deleted"
        );
    }
}

/// Tests that keys are deleted correctly
#[test]
pub fn clears_results_correctly() {
    let mut db = new_test_storage(&Network::Mainnet);

    let zec_pages_sapling_efvk = ZECPAGES_SAPLING_VIEWING_KEY.to_string();

    // Replace the last letter of the zec_pages efvk
    let fake_efvk = format!(
        "{}t",
        &ZECPAGES_SAPLING_VIEWING_KEY[..ZECPAGES_SAPLING_VIEWING_KEY.len() - 1]
    );

    let efvks = [&zec_pages_sapling_efvk, &fake_efvk];
    let fake_heights = [Height::MIN, Height(1), Height::MAX];
    let fake_transaction_indexes = [
        TransactionIndex::MIN,
        TransactionIndex::from_index(40),
        TransactionIndex::MAX,
    ];

    for efvk in efvks {
        for fake_result_height in fake_heights {
            db.insert_sapling_results(
                efvk,
                fake_result_height,
                fake_sapling_results(fake_transaction_indexes),
            );
        }
    }

    let expected_num_entries = fake_heights.len();
    let expected_num_results_per_entry = fake_transaction_indexes.len();

    for efvk in efvks {
        assert_eq!(
            db.sapling_results(efvk).len(),
            expected_num_entries,
            "there should be {expected_num_entries} entries for this key in the db"
        );

        for (_, result) in db.sapling_results(efvk) {
            assert_eq!(
                result.len(),
                expected_num_results_per_entry,
                "there should be {expected_num_results_per_entry} results for this entry in the db"
            );
        }

        db.delete_sapling_results(vec![efvk.clone()]);

        assert_eq!(
            db.sapling_results(efvk).len(),
            1,
            "all results for this key should have been deleted, one empty entry should remain"
        );

        for (_, result) in db.sapling_results(efvk) {
            assert!(
                result.is_empty(),
                "there should be no results for this entry in the db"
            );
        }
    }
}