utils: Fix broken Windows filelock
This commit is contained in:
parent
fe23553edd
commit
369244f654
3 changed files with 39 additions and 1 deletions
|
@ -3,6 +3,7 @@
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#else
|
#else
|
||||||
|
#define NOMINMAX
|
||||||
#include <codecvt>
|
#include <codecvt>
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#endif
|
#endif
|
||||||
|
@ -89,7 +90,7 @@ bool FileLock::TryLock()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
_OVERLAPPED overlapped = {0};
|
_OVERLAPPED overlapped = {0};
|
||||||
if (!LockFileEx(hFile, LOCKFILE_EXCLUSIVE_LOCK | LOCKFILE_FAIL_IMMEDIATELY, 0, 0, 0, &overlapped)) {
|
if (!LockFileEx(hFile, LOCKFILE_EXCLUSIVE_LOCK | LOCKFILE_FAIL_IMMEDIATELY, 0, std::numeric_limits<DWORD>::max(), std::numeric_limits<DWORD>::max(), &overlapped)) {
|
||||||
reason = GetErrorReason();
|
reason = GetErrorReason();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
36
test/functional/feature_filelock.py
Executable file
36
test/functional/feature_filelock.py
Executable file
|
@ -0,0 +1,36 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
# Copyright (c) 2018 The Bitcoin Core developers
|
||||||
|
# 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."""
|
||||||
|
import os
|
||||||
|
|
||||||
|
from test_framework.test_framework import BitcoinTestFramework
|
||||||
|
from test_framework.test_node import ErrorMatch
|
||||||
|
|
||||||
|
class FilelockTest(BitcoinTestFramework):
|
||||||
|
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)
|
||||||
|
self.nodes[0].start([])
|
||||||
|
self.nodes[0].wait_for_rpc_connection()
|
||||||
|
|
||||||
|
def run_test(self):
|
||||||
|
datadir = os.path.join(self.nodes[0].datadir, 'regtest')
|
||||||
|
self.log.info("Using datadir {}".format(datadir))
|
||||||
|
|
||||||
|
self.log.info("Check that we can't start a second bitcoind instance using the same datadir")
|
||||||
|
expected_msg = "Error: Cannot obtain a lock on data directory {}. Bitcoin Core is probably already running.".format(datadir)
|
||||||
|
self.nodes[1].assert_start_raises_init_error(extra_args=['-datadir={}'.format(self.nodes[0].datadir), '-noserver'], expected_msg=expected_msg)
|
||||||
|
|
||||||
|
if self.is_wallet_compiled():
|
||||||
|
wallet_dir = os.path.join(datadir, 'wallets')
|
||||||
|
self.log.info("Check that we can't start a second bitcoind instance using the same wallet")
|
||||||
|
expected_msg = "Error: Error initializing wallet database environment"
|
||||||
|
self.nodes[1].assert_start_raises_init_error(extra_args=['-walletdir={}'.format(wallet_dir), '-noserver'], expected_msg=expected_msg, match=ErrorMatch.PARTIAL_REGEX)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
FilelockTest().main()
|
|
@ -174,6 +174,7 @@ BASE_SCRIPTS = [
|
||||||
'rpc_getblockstats.py',
|
'rpc_getblockstats.py',
|
||||||
'p2p_fingerprint.py',
|
'p2p_fingerprint.py',
|
||||||
'feature_uacomment.py',
|
'feature_uacomment.py',
|
||||||
|
'feature_filelock.py',
|
||||||
'p2p_unrequested_blocks.py',
|
'p2p_unrequested_blocks.py',
|
||||||
'feature_includeconf.py',
|
'feature_includeconf.py',
|
||||||
'rpc_scantxoutset.py',
|
'rpc_scantxoutset.py',
|
||||||
|
|
Loading…
Reference in a new issue