aboutsummaryrefslogtreecommitdiff
path: root/test/functional/feature_port.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/feature_port.py')
-rwxr-xr-xtest/functional/feature_port.py60
1 files changed, 60 insertions, 0 deletions
diff --git a/test/functional/feature_port.py b/test/functional/feature_port.py
new file mode 100755
index 0000000000..2746d7d79c
--- /dev/null
+++ b/test/functional/feature_port.py
@@ -0,0 +1,60 @@
+#!/usr/bin/env python3
+# Copyright (c) 2024-present 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 the -port option and its interactions with
+-bind.
+"""
+
+from test_framework.test_framework import (
+ BitcoinTestFramework,
+)
+from test_framework.util import (
+ p2p_port,
+)
+
+
+class PortTest(BitcoinTestFramework):
+ def set_test_params(self):
+ self.setup_clean_chain = True
+ # Avoid any -bind= on the command line.
+ self.bind_to_localhost_only = False
+ self.num_nodes = 1
+
+ def run_test(self):
+ node = self.nodes[0]
+ node.has_explicit_bind = True
+ port1 = p2p_port(self.num_nodes)
+ port2 = p2p_port(self.num_nodes + 5)
+
+ self.log.info("When starting with -port, bitcoind binds to it and uses port + 1 for an onion bind")
+ with node.assert_debug_log(expected_msgs=[f'Bound to 0.0.0.0:{port1}', f'Bound to 127.0.0.1:{port1 + 1}']):
+ self.restart_node(0, extra_args=["-listen", f"-port={port1}"])
+
+ self.log.info("When specifying -port multiple times, only the last one is taken")
+ with node.assert_debug_log(expected_msgs=[f'Bound to 0.0.0.0:{port2}', f'Bound to 127.0.0.1:{port2 + 1}'], unexpected_msgs=[f'Bound to 0.0.0.0:{port1}']):
+ self.restart_node(0, extra_args=["-listen", f"-port={port1}", f"-port={port2}"])
+
+ self.log.info("When specifying ports with both -port and -bind, the one from -port is ignored")
+ with node.assert_debug_log(expected_msgs=[f'Bound to 0.0.0.0:{port2}'], unexpected_msgs=[f'Bound to 0.0.0.0:{port1}']):
+ self.restart_node(0, extra_args=["-listen", f"-port={port1}", f"-bind=0.0.0.0:{port2}"])
+
+ self.log.info("When -bind specifies no port, the values from -port and -bind are combined")
+ with self.nodes[0].assert_debug_log(expected_msgs=[f'Bound to 0.0.0.0:{port1}']):
+ self.restart_node(0, extra_args=["-listen", f"-port={port1}", "-bind=0.0.0.0"])
+
+ self.log.info("When an onion bind specifies no port, the value from -port, incremented by 1, is taken")
+ with self.nodes[0].assert_debug_log(expected_msgs=[f'Bound to 127.0.0.1:{port1 + 1}']):
+ self.restart_node(0, extra_args=["-listen", f"-port={port1}", "-bind=127.0.0.1=onion"])
+
+ self.log.info("Invalid values for -port raise errors")
+ self.stop_node(0)
+ node.extra_args = ["-listen", "-port=65536"]
+ node.assert_start_raises_init_error(expected_msg="Error: Invalid port specified in -port: '65536'")
+ node.extra_args = ["-listen", "-port=0"]
+ node.assert_start_raises_init_error(expected_msg="Error: Invalid port specified in -port: '0'")
+
+
+if __name__ == '__main__':
+ PortTest(__file__).main()