|
|
|
@ -378,10 +378,19 @@ UniValue setmocktime(const UniValue& params, bool fHelp)
@@ -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; |
|
|
|
|
} |
|
|
|
|