diff options
| author | Wladimir J. van der Laan <[email protected]> | 2015-06-29 16:39:58 +0200 |
|---|---|---|
| committer | Wladimir J. van der Laan <[email protected]> | 2015-06-29 16:41:29 +0200 |
| commit | 0564c5b795d1be675a0ac0a2e8038db0970ac376 (patch) | |
| tree | 18ebd1a489a1b5210d193f34ffdd3bfb45ece78f /src | |
| parent | Merge pull request #6299 (diff) | |
| parent | Testing infrastructure: mocktime fixes (diff) | |
| download | discoin-0564c5b795d1be675a0ac0a2e8038db0970ac376.tar.xz discoin-0564c5b795d1be675a0ac0a2e8038db0970ac376.zip | |
Merge pull request #6337
6a4b97e Testing infrastructure: mocktime fixes (Gavin Andresen)
Diffstat (limited to 'src')
| -rw-r--r-- | src/init.cpp | 3 | ||||
| -rw-r--r-- | src/rpcmisc.cpp | 11 |
2 files changed, 13 insertions, 1 deletions
diff --git a/src/init.cpp b/src/init.cpp index bcdd1f2f3..c4e3573de 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -868,6 +868,9 @@ bool AppInit2(boost::thread_group& threadGroup, CScheduler& scheduler) fAlerts = GetBoolArg("-alerts", DEFAULT_ALERTS); + // Option to startup with mocktime set (used for regression testing): + SetMockTime(GetArg("-mocktime", 0)); // SetMockTime(0) is a no-op + // ********************************************************* Step 4: application initialization: dir lock, daemonize, pidfile, debug log // Initialize elliptic curve code diff --git a/src/rpcmisc.cpp b/src/rpcmisc.cpp index 1d47bc06a..cab57d702 100644 --- a/src/rpcmisc.cpp +++ b/src/rpcmisc.cpp @@ -378,10 +378,19 @@ UniValue setmocktime(const UniValue& params, bool fHelp) if (!Params().MineBlocksOnDemand()) throw runtime_error("setmocktime for regression testing (-regtest mode) only"); - LOCK(cs_main); + // cs_vNodes is locked and node send/receive times are updated + // atomically with the time change to prevent peers from being + // disconnected because we think we haven't communicated with them + // in a long time. + LOCK2(cs_main, cs_vNodes); RPCTypeCheck(params, boost::assign::list_of(UniValue::VNUM)); SetMockTime(params[0].get_int64()); + uint64_t t = GetTime(); + BOOST_FOREACH(CNode* pnode, vNodes) { + pnode->nLastSend = pnode->nLastRecv = t; + } + return NullUniValue; } |