/ src / wallet / test / scriptpubkeyman_tests.cpp
scriptpubkeyman_tests.cpp
 1  // Copyright (c) 2020-present 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>
 7  #include <test/util/setup_common.h>
 8  #include <script/solver.h>
 9  #include <wallet/scriptpubkeyman.h>
10  #include <wallet/wallet.h>
11  #include <wallet/test/util.h>
12  
13  #include <boost/test/unit_test.hpp>
14  
15  namespace wallet {
16  BOOST_FIXTURE_TEST_SUITE(scriptpubkeyman_tests, BasicTestingSetup)
17  
18  BOOST_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 = 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 = 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  
40  BOOST_AUTO_TEST_SUITE_END()
41  } // namespace wallet