mirror of
https://github.com/bitcoin-s/bitcoin-s.git
synced 2025-01-19 05:43:51 +01:00
Make PeerMessageSender.reconnect()
return a Future
that is completed when the connection is established (#5155)
* Make PeerMessageSender.reconnect() return a Future that is completed when the connection is established * Replace hard require() with AsyncUtil.retryUntilSatisfiedF()
This commit is contained in:
parent
44190a535c
commit
e08469901b
@ -36,7 +36,7 @@ import scodec.bits.ByteVector
|
||||
import java.net.InetSocketAddress
|
||||
import java.time.Instant
|
||||
import java.time.temporal.ChronoUnit
|
||||
import scala.concurrent.Future
|
||||
import scala.concurrent.{Future, Promise}
|
||||
import scala.concurrent.duration.{DurationInt, FiniteDuration}
|
||||
|
||||
case class PeerMessageSender(
|
||||
@ -299,14 +299,20 @@ case class PeerMessageSender(
|
||||
curReconnectionTry += 1
|
||||
reconnectionTry = reconnectionTry + 1
|
||||
|
||||
val reconnectP = Promise[Unit]()
|
||||
val cancellable = system.scheduler.scheduleOnce(delay) {
|
||||
val connF = connect()
|
||||
connF.failed.foreach(err =>
|
||||
logger.error(s"Failed to reconnect with peer=$peer", err))
|
||||
()
|
||||
connF.onComplete {
|
||||
case scala.util.Success(_) =>
|
||||
resetReconnect()
|
||||
reconnectP.success(())
|
||||
case scala.util.Failure(exception) =>
|
||||
logger.error(s"Failed to reconnect with peer=$peer", exception)
|
||||
reconnectP.failure(exception)
|
||||
}
|
||||
}
|
||||
reconnectionCancellableOpt = Some(cancellable)
|
||||
Future.unit
|
||||
reconnectP.future
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -482,8 +482,8 @@ object NodeUnitTest extends P2PLogger {
|
||||
//see: https://github.com/bitcoin-s/bitcoin-s/issues/4976
|
||||
_ <- bitcoind.syncWithValidationInterfaceQueue()
|
||||
_ <- node.sync()
|
||||
syncing <- node.chainApiFromDb().flatMap(_.isSyncing())
|
||||
_ = require(syncing)
|
||||
_ <- AsyncUtil.retryUntilSatisfiedF(() =>
|
||||
node.chainApiFromDb().flatMap(_.isSyncing()))
|
||||
} yield node
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user