#[macro_export]
macro_rules! testutils {
( @external $descriptors:expr, $child:expr ) => ({
- use bitcoin::secp256k1::Secp256k1;
- use miniscript::descriptor::{Descriptor, DescriptorPublicKey, DescriptorTrait};
+ use $crate::bitcoin::secp256k1::Secp256k1;
+ use $crate::miniscript::descriptor::{Descriptor, DescriptorPublicKey, DescriptorTrait};
use $crate::testutils::TranslateDescriptor;
parsed.derive_translated(&secp, $child).address(bitcoin::Network::Regtest).expect("No address form")
});
( @internal $descriptors:expr, $child:expr ) => ({
- use bitcoin::secp256k1::Secp256k1;
- use miniscript::descriptor::{Descriptor, DescriptorPublicKey, DescriptorTrait};
+ use $crate::bitcoin::secp256k1::Secp256k1;
+ use $crate::miniscript::descriptor::{Descriptor, DescriptorPublicKey, DescriptorTrait};
use $crate::testutils::TranslateDescriptor;
let secp = Secp256k1::new();
let parsed = Descriptor::<DescriptorPublicKey>::parse_descriptor(&secp, &$descriptors.1.expect("Missing internal descriptor")).expect("Failed to parse descriptor in `testutils!(@internal)`").0;
- parsed.derive_translated(&secp, $child).address(bitcoin::Network::Regtest).expect("No address form")
+ parsed.derive_translated(&secp, $child).address($crate::bitcoin::Network::Regtest).expect("No address form")
});
( @e $descriptors:expr, $child:expr ) => ({ testutils!(@external $descriptors, $child) });
( @i $descriptors:expr, $child:expr ) => ({ testutils!(@internal $descriptors, $child) });
let mut seed = [0u8; 32];
rand::thread_rng().fill(&mut seed[..]);
- let key = bitcoin::util::bip32::ExtendedPrivKey::new_master(
- bitcoin::Network::Testnet,
+ let key = $crate::bitcoin::util::bip32::ExtendedPrivKey::new_master(
+ $crate::bitcoin::Network::Testnet,
&seed,
);
( @generate_wif ) => ({
use rand::Rng;
- let mut key = [0u8; bitcoin::secp256k1::constants::SECRET_KEY_SIZE];
+ let mut key = [0u8; $crate::bitcoin::secp256k1::constants::SECRET_KEY_SIZE];
rand::thread_rng().fill(&mut key[..]);
- (bitcoin::PrivateKey {
+ ($crate::bitcoin::PrivateKey {
compressed: true,
- network: bitcoin::Network::Testnet,
- key: bitcoin::secp256k1::SecretKey::from_slice(&key).unwrap(),
+ network: $crate::bitcoin::Network::Testnet,
+ key: $crate::bitcoin::secp256k1::SecretKey::from_slice(&key).unwrap(),
}.to_string(), None::<String>, None::<String>)
});
( @descriptors ( $external_descriptor:expr ) $( ( $internal_descriptor:expr ) )? $( ( @keys $( $keys:tt )* ) )* ) => ({
use std::str::FromStr;
use std::collections::HashMap;
- use miniscript::descriptor::Descriptor;
- use miniscript::TranslatePk;
+ use $crate::miniscript::descriptor::Descriptor;
+ use $crate::miniscript::TranslatePk;
#[allow(unused_assignments, unused_mut)]
let mut keys: HashMap<&'static str, (String, Option<String>, Option<String>)> = HashMap::new();