2019-04-28 19:08:26 -04:00
#!/usr/bin/env python3
2021-07-28 13:57:16 +02:00
# Copyright (c) 2017-2021 The Bitcoin Core developers
2019-04-28 19:08:26 -04:00
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
""" Test various command line arguments and configuration file parameters. """
import json
from test_framework . test_framework import BitcoinTestFramework
from test_framework . test_node import ErrorMatch
from test_framework . util import assert_equal
class SettingsTest ( BitcoinTestFramework ) :
def set_test_params ( self ) :
self . setup_clean_chain = True
self . num_nodes = 1
2020-09-28 20:24:06 -04:00
self . wallet_names = [ ]
2019-04-28 19:08:26 -04:00
def run_test ( self ) :
node , = self . nodes
2023-09-02 01:09:43 -04:00
settings = node . chain_path / " settings.json "
conf = node . datadir_path / " bitcoin.conf "
2019-04-28 19:08:26 -04:00
2024-01-09 10:25:08 -03:00
# Assert default settings file was created
2019-04-28 19:08:26 -04:00
self . stop_node ( 0 )
2024-01-09 10:25:08 -03:00
default_settings = { " _warning_ " : " This file is automatically generated and updated by Bitcoin Core. Please do not edit this file while the node is running, as any changes might be ignored or overwritten. " }
2019-04-28 19:08:26 -04:00
with settings . open ( ) as fp :
2024-01-09 10:25:08 -03:00
assert_equal ( json . load ( fp ) , default_settings )
2019-04-28 19:08:26 -04:00
# Assert settings are parsed and logged
with settings . open ( " w " ) as fp :
2020-07-30 10:50:54 +02:00
json . dump ( { " string " : " string " , " num " : 5 , " bool " : True , " null " : None , " list " : [ 6 , 7 ] } , fp )
2019-04-28 19:08:26 -04:00
with node . assert_debug_log ( expected_msgs = [
2020-07-30 10:50:54 +02:00
' Ignoring unknown rw_settings value bool ' ,
' Ignoring unknown rw_settings value list ' ,
' Ignoring unknown rw_settings value null ' ,
' Ignoring unknown rw_settings value num ' ,
' Ignoring unknown rw_settings value string ' ,
2019-04-28 19:08:26 -04:00
' Setting file arg: string = " string " ' ,
' Setting file arg: num = 5 ' ,
' Setting file arg: bool = true ' ,
' Setting file arg: null = null ' ,
2020-07-30 10:50:54 +02:00
' Setting file arg: list = [6,7] ' ,
] ) :
2019-04-28 19:08:26 -04:00
self . start_node ( 0 )
self . stop_node ( 0 )
# Assert settings are unchanged after shutdown
with settings . open ( ) as fp :
2024-01-09 10:25:08 -03:00
assert_equal ( json . load ( fp ) , { * * default_settings , * * { " string " : " string " , " num " : 5 , " bool " : True , " null " : None , " list " : [ 6 , 7 ] } } )
2019-04-28 19:08:26 -04:00
# Test invalid json
with settings . open ( " w " ) as fp :
fp . write ( " invalid json " )
2024-01-09 09:54:49 -03:00
node . assert_start_raises_init_error ( expected_msg = ' does not contain valid JSON. This is probably caused by disk corruption or a crash ' , match = ErrorMatch . PARTIAL_REGEX )
2019-04-28 19:08:26 -04:00
# Test invalid json object
with settings . open ( " w " ) as fp :
fp . write ( ' " string " ' )
node . assert_start_raises_init_error ( expected_msg = ' Found non-object value " string " in settings file ' , match = ErrorMatch . PARTIAL_REGEX )
# Test invalid settings file containing duplicate keys
with settings . open ( " w " ) as fp :
fp . write ( ' { " key " : 1, " key " : 2} ' )
node . assert_start_raises_init_error ( expected_msg = ' Found duplicate key key in settings file ' , match = ErrorMatch . PARTIAL_REGEX )
# Test invalid settings file is ignored with command line -nosettings
with node . assert_debug_log ( expected_msgs = [ ' Command-line arg: settings=false ' ] ) :
self . start_node ( 0 , extra_args = [ " -nosettings " ] )
self . stop_node ( 0 )
# Test invalid settings file is ignored with config file -nosettings
with conf . open ( ' a ' ) as conf :
conf . write ( ' nosettings=1 \n ' )
with node . assert_debug_log ( expected_msgs = [ ' Config file arg: [regtest] settings=false ' ] ) :
self . start_node ( 0 )
self . stop_node ( 0 )
# Test alternate settings path
2023-09-02 01:09:43 -04:00
altsettings = node . datadir_path / " altsettings.json "
2019-04-28 19:08:26 -04:00
with altsettings . open ( " w " ) as fp :
fp . write ( ' { " key " : " value " } ' )
with node . assert_debug_log ( expected_msgs = [ ' Setting file arg: key = " value " ' ] ) :
2021-06-11 15:26:49 +08:00
self . start_node ( 0 , extra_args = [ f " -settings= { altsettings } " ] )
2019-04-28 19:08:26 -04:00
self . stop_node ( 0 )
if __name__ == ' __main__ ' :
SettingsTest ( ) . main ( )