Bitcoin Core 29.99.0
P2P Digital Currency
scriptpubkeyman_tests.cpp
Go to the documentation of this file.
1// Copyright (c) 2020-2021 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#include <key.h>
6#include <key_io.h>
8#include <script/solver.h>
10#include <wallet/wallet.h>
11#include <wallet/test/util.h>
12
13#include <boost/test/unit_test.hpp>
14
15namespace wallet {
16BOOST_FIXTURE_TEST_SUITE(scriptpubkeyman_tests, BasicTestingSetup)
17
18BOOST_AUTO_TEST_CASE(DescriptorScriptPubKeyManTests)
19{
20 std::unique_ptr<interfaces::Chain>& chain = m_node.chain;
21
22 CWallet keystore(chain.get(), "", CreateMockableWalletDatabase());
23 auto key_scriptpath = GenerateRandomKey();
24
25 // Verify that a SigningProvider for a pubkey is only returned if its corresponding private key is available
26 auto key_internal = GenerateRandomKey();
27 std::string desc_str = "tr(" + EncodeSecret(key_internal) + ",pk(" + HexStr(key_scriptpath.GetPubKey()) + "))";
28 auto spk_man1 = dynamic_cast<DescriptorScriptPubKeyMan*>(CreateDescriptor(keystore, desc_str, true));
29 BOOST_CHECK(spk_man1 != nullptr);
30 auto signprov_keypath_spendable = spk_man1->GetSigningProvider(key_internal.GetPubKey());
31 BOOST_CHECK(signprov_keypath_spendable != nullptr);
32
33 desc_str = "tr(" + HexStr(XOnlyPubKey::NUMS_H) + ",pk(" + HexStr(key_scriptpath.GetPubKey()) + "))";
34 auto spk_man2 = dynamic_cast<DescriptorScriptPubKeyMan*>(CreateDescriptor(keystore, desc_str, true));
35 BOOST_CHECK(spk_man2 != nullptr);
36 auto signprov_keypath_nums_h = spk_man2->GetSigningProvider(XOnlyPubKey::NUMS_H.GetEvenCorrespondingCPubKey());
37 BOOST_CHECK(signprov_keypath_nums_h == nullptr);
38}
39
41} // namespace wallet
node::NodeContext m_node
Definition: bitcoin-gui.cpp:42
static const XOnlyPubKey NUMS_H
Nothing Up My Sleeve point H Used as an internal key for provably disabling the key path spend see BI...
Definition: pubkey.h:239
A CWallet maintains a set of transactions and balances, and provides the ability to create new transa...
Definition: wallet.h:300
BOOST_FIXTURE_TEST_SUITE(cuckoocache_tests, BasicTestingSetup)
Test Suite for CuckooCache.
BOOST_AUTO_TEST_SUITE_END()
std::string HexStr(const std::span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Definition: hex_base.cpp:29
CKey GenerateRandomKey(bool compressed) noexcept
Definition: key.cpp:352
std::string EncodeSecret(const CKey &key)
Definition: key_io.cpp:231
wallet::ScriptPubKeyMan * CreateDescriptor(CWallet &keystore, const std::string &desc_str, const bool success)
Definition: util.cpp:197
std::unique_ptr< WalletDatabase > CreateMockableWalletDatabase(MockableData records)
Definition: util.cpp:187
BOOST_AUTO_TEST_CASE(bnb_test)
#define BOOST_CHECK(expr)
Definition: object.cpp:17
Basic testing setup.
Definition: setup_common.h:64
std::unique_ptr< interfaces::Chain > chain
Definition: context.h:76