2018-10-08 00:24:20 +08:00
#!/usr/bin/env python3
2022-12-24 23:49:50 +00:00
# Copyright (c) 2018-2022 The Bitcoin Core developers
2018-10-08 00:24:20 +08:00
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
""" Check that it ' s not possible to start a second bitcoind instance using the same datadir or wallet. """
2020-10-29 15:55:37 -04:00
import random
import string
2018-10-08 00:24:20 +08:00
from test_framework . test_framework import BitcoinTestFramework
2024-08-28 07:57:59 -04:00
from test_framework . test_node import (
BITCOIN_PID_FILENAME_DEFAULT ,
ErrorMatch ,
)
2018-10-08 00:24:20 +08:00
class FilelockTest ( BitcoinTestFramework ) :
2022-11-09 12:53:13 +01:00
def add_options ( self , parser ) :
self . add_wallet_options ( parser )
2018-10-08 00:24:20 +08:00
def set_test_params ( self ) :
self . setup_clean_chain = True
self . num_nodes = 2
def setup_network ( self ) :
self . add_nodes ( self . num_nodes , extra_args = None )
2020-09-28 20:24:06 -04:00
self . nodes [ 0 ] . start ( )
2018-10-08 00:24:20 +08:00
self . nodes [ 0 ] . wait_for_rpc_connection ( )
def run_test ( self ) :
2023-06-14 13:00:11 +02:00
datadir = self . nodes [ 0 ] . chain_path
2025-01-16 15:29:13 +00:00
blocksdir = self . nodes [ 0 ] . blocks_path
2021-06-11 14:13:45 +08:00
self . log . info ( f " Using datadir { datadir } " )
2025-01-16 15:29:13 +00:00
self . log . info ( f " Using blocksdir { blocksdir } " )
2018-10-08 00:24:20 +08:00
self . log . info ( " Check that we can ' t start a second bitcoind instance using the same datadir " )
2025-01-15 18:03:43 +00:00
expected_msg = f " Error: Cannot obtain a lock on directory { datadir } . { self . config [ ' environment ' ] [ ' CLIENT_NAME ' ] } is probably already running. "
2023-09-02 01:09:43 -04:00
self . nodes [ 1 ] . assert_start_raises_init_error ( extra_args = [ f ' -datadir= { self . nodes [ 0 ] . datadir_path } ' , ' -noserver ' ] , expected_msg = expected_msg )
2018-10-08 00:24:20 +08:00
2025-01-16 15:29:13 +00:00
self . log . info ( " Check that we can ' t start a second bitcoind instance using the same blocksdir " )
expected_msg = f " Error: Cannot obtain a lock on directory { blocksdir } . { self . config [ ' environment ' ] [ ' CLIENT_NAME ' ] } is probably already running. "
self . nodes [ 1 ] . assert_start_raises_init_error ( extra_args = [ f ' -blocksdir= { self . nodes [ 0 ] . datadir_path } ' , ' -noserver ' ] , expected_msg = expected_msg )
self . log . info ( " Check that cookie and PID file are not deleted when attempting to start a second bitcoind using the same datadir/blocksdir " )
2023-11-03 16:34:42 +02:00
cookie_file = datadir / " .cookie "
assert cookie_file . exists ( ) # should not be deleted during the second bitcoind instance shutdown
2024-08-28 07:57:59 -04:00
pid_file = datadir / BITCOIN_PID_FILENAME_DEFAULT
2023-11-27 10:29:02 +00:00
assert pid_file . exists ( )
2023-11-03 16:34:42 +02:00
2018-10-08 00:24:20 +08:00
if self . is_wallet_compiled ( ) :
2020-10-29 15:55:37 -04:00
def check_wallet_filelock ( descriptors ) :
wallet_name = ' ' . join ( [ random . choice ( string . ascii_lowercase ) for _ in range ( 6 ) ] )
self . nodes [ 0 ] . createwallet ( wallet_name = wallet_name , descriptors = descriptors )
2023-06-14 13:00:11 +02:00
wallet_dir = self . nodes [ 0 ] . wallets_path
2020-10-29 15:55:37 -04:00
self . log . info ( " Check that we can ' t start a second bitcoind instance using the same wallet " )
if descriptors :
2024-10-26 13:27:25 +01:00
expected_msg = f " Error: SQLiteDatabase: Unable to obtain an exclusive lock on the database, is it being used by another instance of { self . config [ ' environment ' ] [ ' CLIENT_NAME ' ] } ? "
2020-10-29 15:55:37 -04:00
else :
expected_msg = " Error: Error initializing wallet database environment "
2021-06-11 14:13:45 +08:00
self . nodes [ 1 ] . assert_start_raises_init_error ( extra_args = [ f ' -walletdir= { wallet_dir } ' , f ' -wallet= { wallet_name } ' , ' -noserver ' ] , expected_msg = expected_msg , match = ErrorMatch . PARTIAL_REGEX )
2020-10-29 15:55:37 -04:00
if self . is_bdb_compiled ( ) :
check_wallet_filelock ( False )
if self . is_sqlite_compiled ( ) :
check_wallet_filelock ( True )
2018-10-08 00:24:20 +08:00
if __name__ == ' __main__ ' :
2024-07-16 22:05:14 +01:00
FilelockTest ( __file__ ) . main ( )