Skip to content

Commit

Permalink
test: Add addrman peers.dat test
Browse files Browse the repository at this point in the history
  • Loading branch information
MarcoFalke committed Sep 3, 2021
1 parent facce4c commit fac6844
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 0 deletions.
82 changes: 82 additions & 0 deletions test/functional/feature_addrman.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
#!/usr/bin/env python3
# Copyright (c) 2021 The Bitcoin Core developers
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
"""Test addrman functionality"""

import os
import struct

from test_framework.messages import ser_uint256, hash256
from test_framework.p2p import MAGIC_BYTES
from test_framework.test_framework import BitcoinTestFramework


def serialize_addrman(*, format=1, lowest_compatible=3):
new = []
tried = []
INCOMPATIBILITY_BASE = 32
r = MAGIC_BYTES['regtest']
r += struct.pack("B", format)
r += struct.pack("B", INCOMPATIBILITY_BASE + lowest_compatible)
r += ser_uint256(1)
r += struct.pack("i", len(new))
r += struct.pack("i", len(tried))
ADDRMAN_NEW_BUCKET_COUNT = 1 << 10
r += struct.pack("i", ADDRMAN_NEW_BUCKET_COUNT ^ (1 << 30))
for _ in range(ADDRMAN_NEW_BUCKET_COUNT):
r += struct.pack("i", 0)
checksum = hash256(r)
r += checksum
return r


def write_addrman(peers_dat, **kwargs):
with open(peers_dat, 'wb') as f:
f.write(serialize_addrman(**kwargs))


class AddrmanTest(BitcoinTestFramework):
def set_test_params(self):
self.num_nodes = 1

def run_test(self):
peers_dat = os.path.join(self.nodes[0].datadir, self.chain, "peers.dat")

self.log.info("Check that mocked addrman is valid")
self.stop_node(0)
write_addrman(peers_dat)
with self.nodes[0].assert_debug_log(['Loaded 0 addresses from peers.dat']):
self.start_node(0)

self.log.info("Check that addrman from future can not be read")
self.stop_node(0)
write_addrman(peers_dat, lowest_compatible=111)
with self.nodes[0].assert_debug_log([
f'ERROR: DeserializeDB: Deserialize or I/O error - Unsupported format of addrman database: \\x01. It is compatible with formats >=111, but the maximum supported by this version of {self.config["environment"]["PACKAGE_NAME"]} is 3.: iostream error',
'Recreating peers.dat',
]):
self.start_node(0)

self.log.info("Check that corrupt addrman can not be read")
self.stop_node(0)
with open(peers_dat, 'wb') as f:
f.write(serialize_addrman()[:-1])
with self.nodes[0].assert_debug_log([
'ERROR: DeserializeDB: Deserialize or I/O error - CAutoFile::read: end of file: iostream error',
'Recreating peers.dat',
]):
self.start_node(0)

self.log.info("Check that missing addrman is recreated")
self.stop_node(0)
os.remove(peers_dat)
with self.nodes[0].assert_debug_log([
f'Missing or invalid file {peers_dat}',
'Recreating peers.dat',
]):
self.start_node(0)


if __name__ == "__main__":
AddrmanTest().main()
1 change: 1 addition & 0 deletions test/functional/test_runner.py
Original file line number Diff line number Diff line change
Expand Up @@ -282,6 +282,7 @@
'p2p_blockfilters.py',
'p2p_message_capture.py',
'feature_includeconf.py',
'feature_addrman.py',
'feature_asmap.py',
'mempool_unbroadcast.py',
'mempool_compatibility.py',
Expand Down

0 comments on commit fac6844

Please sign in to comment.