Skip to content

Commit 87493e1

Browse files
committed
p2p, test, refactor: Minor code improvements
1 parent 00c5dec commit 87493e1

File tree

3 files changed

+13
-14
lines changed

3 files changed

+13
-14
lines changed

src/init.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -478,6 +478,7 @@ void SetupServerArgs(ArgsManager& argsman)
478478
argsman.AddArg("-onlynet=<net>", "Make automatic outbound connections only to network <net> (" + Join(GetNetworkNames(), ", ") + "). Inbound and manual connections are not affected by this option. It can be specified multiple times to allow multiple networks.", ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
479479
argsman.AddArg("-peerbloomfilters", strprintf("Support filtering of blocks and transaction with bloom filters (default: %u)", DEFAULT_PEERBLOOMFILTERS), ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
480480
argsman.AddArg("-peerblockfilters", strprintf("Serve compact block filters to peers per BIP 157 (default: %u)", DEFAULT_PEERBLOCKFILTERS), ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
481+
argsman.AddArg("-txreconciliation", strprintf("Enable transaction reconciliations per BIP 330 (default: %d)", DEFAULT_TXRECONCILIATION_ENABLE), ArgsManager::ALLOW_ANY | ArgsManager::DEBUG_ONLY, OptionsCategory::CONNECTION);
481482
// TODO: remove the sentence "Nodes not using ... incoming connections." once the changes from
482483
// https://github.com/bitcoin/bitcoin/pull/23542 have become widespread.
483484
argsman.AddArg("-port=<port>", strprintf("Listen for connections on <port>. Nodes not using the default ports (default: %u, testnet: %u, signet: %u, regtest: %u) are unlikely to get incoming connections. Not relevant for I2P (see doc/i2p.md).", defaultChainParams->GetDefaultPort(), testnetChainParams->GetDefaultPort(), signetChainParams->GetDefaultPort(), regtestChainParams->GetDefaultPort()), ArgsManager::ALLOW_ANY | ArgsManager::NETWORK_ONLY, OptionsCategory::CONNECTION);
@@ -486,7 +487,6 @@ void SetupServerArgs(ArgsManager& argsman)
486487
argsman.AddArg("-seednode=<ip>", "Connect to a node to retrieve peer addresses, and disconnect. This option can be specified multiple times to connect to multiple nodes.", ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
487488
argsman.AddArg("-networkactive", "Enable all P2P network activity (default: 1). Can be changed by the setnetworkactive RPC command", ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
488489
argsman.AddArg("-timeout=<n>", strprintf("Specify socket connection timeout in milliseconds. If an initial attempt to connect is unsuccessful after this amount of time, drop it (minimum: 1, default: %d)", DEFAULT_CONNECT_TIMEOUT), ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
489-
argsman.AddArg("-txreconciliation", strprintf("Enable transaction reconciliations per BIP 330 (default: %d)", DEFAULT_TXRECONCILIATION_ENABLE), ArgsManager::ALLOW_ANY | ArgsManager::DEBUG_ONLY, OptionsCategory::CONNECTION);
490490
argsman.AddArg("-peertimeout=<n>", strprintf("Specify a p2p connection timeout delay in seconds. After connecting to a peer, wait this amount of time before considering disconnection based on inactivity (minimum: 1, default: %d)", DEFAULT_PEER_CONNECT_TIMEOUT), ArgsManager::ALLOW_ANY | ArgsManager::DEBUG_ONLY, OptionsCategory::CONNECTION);
491491
argsman.AddArg("-torcontrol=<ip>:<port>", strprintf("Tor control port to use if onion listening enabled (default: %s)", DEFAULT_TOR_CONTROL), ArgsManager::ALLOW_ANY, OptionsCategory::CONNECTION);
492492
argsman.AddArg("-torpassword=<pass>", "Tor control port password (default: empty)", ArgsManager::ALLOW_ANY | ArgsManager::SENSITIVE, OptionsCategory::CONNECTION);

src/node/txreconciliation.cpp

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -82,15 +82,13 @@ class TxReconciliationTracker::Impl
8282
{
8383
AssertLockNotHeld(m_txreconciliation_mutex);
8484
LOCK(m_txreconciliation_mutex);
85-
// We do not support txreconciliation salt/version updates.
86-
assert(m_states.find(peer_id) == m_states.end());
8785

8886
LogPrintLevel(BCLog::TXRECONCILIATION, BCLog::Level::Debug, "Pre-register peer=%d\n", peer_id);
8987
const uint64_t local_salt{GetRand(UINT64_MAX)};
9088

9189
// We do this exactly once per peer (which are unique by NodeId, see GetNewNodeId) so it's
9290
// safe to assume we don't have this record yet.
93-
Assert(m_states.emplace(peer_id, local_salt).second);
91+
Assume(m_states.emplace(peer_id, local_salt).second);
9492
return local_salt;
9593
}
9694

src/test/txreconciliation_tests.cpp

Lines changed: 11 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -12,19 +12,20 @@ BOOST_FIXTURE_TEST_SUITE(txreconciliation_tests, BasicTestingSetup)
1212

1313
BOOST_AUTO_TEST_CASE(RegisterPeerTest)
1414
{
15-
TxReconciliationTracker tracker(1);
15+
TxReconciliationTracker tracker(TXRECONCILIATION_VERSION);
1616
const uint64_t salt = 0;
1717

1818
// Prepare a peer for reconciliation.
1919
tracker.PreRegisterPeer(0);
2020

2121
// Invalid version.
22-
BOOST_CHECK(tracker.RegisterPeer(/*peer_id=*/0, /*is_peer_inbound=*/true,
23-
/*peer_recon_version=*/0, salt) == ReconciliationRegisterResult::PROTOCOL_VIOLATION);
22+
BOOST_CHECK_EQUAL(tracker.RegisterPeer(/*peer_id=*/0, /*is_peer_inbound=*/true,
23+
/*peer_recon_version=*/0, salt),
24+
ReconciliationRegisterResult::PROTOCOL_VIOLATION);
2425

2526
// Valid registration (inbound and outbound peers).
2627
BOOST_REQUIRE(!tracker.IsPeerRegistered(0));
27-
BOOST_REQUIRE(tracker.RegisterPeer(0, true, 1, salt) == ReconciliationRegisterResult::SUCCESS);
28+
BOOST_REQUIRE_EQUAL(tracker.RegisterPeer(0, true, 1, salt), ReconciliationRegisterResult::SUCCESS);
2829
BOOST_CHECK(tracker.IsPeerRegistered(0));
2930
BOOST_REQUIRE(!tracker.IsPeerRegistered(1));
3031
tracker.PreRegisterPeer(1);
@@ -41,39 +42,39 @@ BOOST_AUTO_TEST_CASE(RegisterPeerTest)
4142
BOOST_REQUIRE(tracker.RegisterPeer(1, false, 1, salt) == ReconciliationRegisterResult::ALREADY_REGISTERED);
4243

4344
// Do not register if there were no pre-registration for the peer.
44-
BOOST_REQUIRE(tracker.RegisterPeer(100, true, 1, salt) == ReconciliationRegisterResult::NOT_FOUND);
45+
BOOST_REQUIRE_EQUAL(tracker.RegisterPeer(100, true, 1, salt), ReconciliationRegisterResult::NOT_FOUND);
4546
BOOST_CHECK(!tracker.IsPeerRegistered(100));
4647
}
4748

4849
BOOST_AUTO_TEST_CASE(ForgetPeerTest)
4950
{
50-
TxReconciliationTracker tracker(1);
51+
TxReconciliationTracker tracker(TXRECONCILIATION_VERSION);
5152
NodeId peer_id0 = 0;
5253

5354
// Removing peer after pre-registring works and does not let to register the peer.
5455
tracker.PreRegisterPeer(peer_id0);
5556
tracker.ForgetPeer(peer_id0);
56-
BOOST_CHECK(tracker.RegisterPeer(peer_id0, true, 1, 1) == ReconciliationRegisterResult::NOT_FOUND);
57+
BOOST_CHECK_EQUAL(tracker.RegisterPeer(peer_id0, true, 1, 1), ReconciliationRegisterResult::NOT_FOUND);
5758

5859
// Removing peer after it is registered works.
5960
tracker.PreRegisterPeer(peer_id0);
6061
BOOST_REQUIRE(!tracker.IsPeerRegistered(peer_id0));
61-
BOOST_REQUIRE(tracker.RegisterPeer(peer_id0, true, 1, 1) == ReconciliationRegisterResult::SUCCESS);
62+
BOOST_REQUIRE_EQUAL(tracker.RegisterPeer(peer_id0, true, 1, 1), ReconciliationRegisterResult::SUCCESS);
6263
BOOST_CHECK(tracker.IsPeerRegistered(peer_id0));
6364
tracker.ForgetPeer(peer_id0);
6465
BOOST_CHECK(!tracker.IsPeerRegistered(peer_id0));
6566
}
6667

6768
BOOST_AUTO_TEST_CASE(IsPeerRegisteredTest)
6869
{
69-
TxReconciliationTracker tracker(1);
70+
TxReconciliationTracker tracker(TXRECONCILIATION_VERSION);
7071
NodeId peer_id0 = 0;
7172

7273
BOOST_REQUIRE(!tracker.IsPeerRegistered(peer_id0));
7374
tracker.PreRegisterPeer(peer_id0);
7475
BOOST_REQUIRE(!tracker.IsPeerRegistered(peer_id0));
7576

76-
BOOST_REQUIRE(tracker.RegisterPeer(peer_id0, true, 1, 1) == ReconciliationRegisterResult::SUCCESS);
77+
BOOST_REQUIRE_EQUAL(tracker.RegisterPeer(peer_id0, true, 1, 1), ReconciliationRegisterResult::SUCCESS);
7778
BOOST_CHECK(tracker.IsPeerRegistered(peer_id0));
7879

7980
tracker.ForgetPeer(peer_id0);

0 commit comments

Comments
 (0)