Skip to content

Commit 7a0c224

Browse files
committed
Suppress output in test_bitcoin for expected errors
1 parent c8fee67 commit 7a0c224

File tree

3 files changed

+54
-3
lines changed

3 files changed

+54
-3
lines changed

src/noui.cpp

Lines changed: 41 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,12 @@
1313
#include <string>
1414

1515
#include <boost/signals2/connection.hpp>
16+
#include <boost/signals2/signal.hpp>
17+
18+
/** Store connections so we can disconnect them when suppressing output */
19+
boost::signals2::connection noui_ThreadSafeMessageBoxConn;
20+
boost::signals2::connection noui_ThreadSafeQuestionConn;
21+
boost::signals2::connection noui_InitMessageConn;
1622

1723
bool noui_ThreadSafeMessageBox(const std::string& message, const std::string& caption, unsigned int style)
1824
{
@@ -53,7 +59,39 @@ void noui_InitMessage(const std::string& message)
5359

5460
void noui_connect()
5561
{
56-
uiInterface.ThreadSafeMessageBox_connect(noui_ThreadSafeMessageBox);
57-
uiInterface.ThreadSafeQuestion_connect(noui_ThreadSafeQuestion);
58-
uiInterface.InitMessage_connect(noui_InitMessage);
62+
noui_ThreadSafeMessageBoxConn = uiInterface.ThreadSafeMessageBox_connect(noui_ThreadSafeMessageBox);
63+
noui_ThreadSafeQuestionConn = uiInterface.ThreadSafeQuestion_connect(noui_ThreadSafeQuestion);
64+
noui_InitMessageConn = uiInterface.InitMessage_connect(noui_InitMessage);
65+
}
66+
67+
bool noui_ThreadSafeMessageBoxSuppressed(const std::string& message, const std::string& caption, unsigned int style)
68+
{
69+
return false;
70+
}
71+
72+
bool noui_ThreadSafeQuestionSuppressed(const std::string& /* ignored interactive message */, const std::string& message, const std::string& caption, unsigned int style)
73+
{
74+
return false;
5975
}
76+
77+
void noui_InitMessageSuppressed(const std::string& message)
78+
{
79+
}
80+
81+
void noui_suppress()
82+
{
83+
noui_ThreadSafeMessageBoxConn.disconnect();
84+
noui_ThreadSafeQuestionConn.disconnect();
85+
noui_InitMessageConn.disconnect();
86+
noui_ThreadSafeMessageBoxConn = uiInterface.ThreadSafeMessageBox_connect(noui_ThreadSafeMessageBoxSuppressed);
87+
noui_ThreadSafeQuestionConn = uiInterface.ThreadSafeQuestion_connect(noui_ThreadSafeQuestionSuppressed);
88+
noui_InitMessageConn = uiInterface.InitMessage_connect(noui_InitMessageSuppressed);
89+
}
90+
91+
void noui_reconnect()
92+
{
93+
noui_ThreadSafeMessageBoxConn.disconnect();
94+
noui_ThreadSafeQuestionConn.disconnect();
95+
noui_InitMessageConn.disconnect();
96+
noui_connect();
97+
}

src/noui.h

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -17,4 +17,10 @@ void noui_InitMessage(const std::string& message);
1717
/** Connect all bitcoind signal handlers */
1818
void noui_connect();
1919

20+
/** Suppress all bitcoind signal handlers. Used to suppress output during test runs that produce expected errors */
21+
void noui_suppress();
22+
23+
/** Reconnects the regular Non-GUI handlers after having used noui_suppress */
24+
void noui_reconnect();
25+
2026
#endif // BITCOIN_NOUI_H

src/wallet/test/init_tests.cpp

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44

55
#include <boost/test/unit_test.hpp>
66

7+
#include <noui.h>
78
#include <test/setup_common.h>
89
#include <wallet/test/init_test_fixture.h>
910

@@ -32,21 +33,27 @@ BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_custom)
3233
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_does_not_exist)
3334
{
3435
SetWalletDir(m_walletdir_path_cases["nonexistent"]);
36+
noui_suppress();
3537
bool result = m_chain_client->verify();
38+
noui_reconnect();
3639
BOOST_CHECK(result == false);
3740
}
3841

3942
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_is_not_directory)
4043
{
4144
SetWalletDir(m_walletdir_path_cases["file"]);
45+
noui_suppress();
4246
bool result = m_chain_client->verify();
47+
noui_reconnect();
4348
BOOST_CHECK(result == false);
4449
}
4550

4651
BOOST_AUTO_TEST_CASE(walletinit_verify_walletdir_is_not_relative)
4752
{
4853
SetWalletDir(m_walletdir_path_cases["relative"]);
54+
noui_suppress();
4955
bool result = m_chain_client->verify();
56+
noui_reconnect();
5057
BOOST_CHECK(result == false);
5158
}
5259

0 commit comments

Comments
 (0)