2018-10-29 17:19:37 +08:00
|
|
|
/*
|
2019-01-02 18:55:26 +08:00
|
|
|
* Copyright (C) 2009-2019 Lightbend Inc. <https://www.lightbend.com>
|
2018-05-31 14:43:53 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package akka.cluster
|
|
|
|
|
|
|
|
|
|
import akka.actor.{ Address, ExtendedActorSystem }
|
|
|
|
|
import akka.testkit.{ AkkaSpec, EventFilter, ImplicitSender }
|
2018-11-15 08:31:59 -08:00
|
|
|
import com.typesafe.config.{ Config, ConfigFactory }
|
2018-05-31 14:43:53 +01:00
|
|
|
|
|
|
|
|
object ClusterLogSpec {
|
|
|
|
|
val config = """
|
|
|
|
|
akka.cluster {
|
|
|
|
|
auto-down-unreachable-after = 0s
|
|
|
|
|
publish-stats-interval = 0 s # always, when it happens
|
|
|
|
|
failure-detector.implementation-class = akka.cluster.FailureDetectorPuppet
|
|
|
|
|
}
|
|
|
|
|
akka.actor.provider = "cluster"
|
|
|
|
|
akka.remote.log-remote-lifecycle-events = off
|
2019-05-01 08:12:09 +01:00
|
|
|
akka.remote.classic.netty.tcp.port = 0
|
2018-05-31 14:43:53 +01:00
|
|
|
akka.remote.artery.canonical.port = 0
|
|
|
|
|
akka.loglevel = "INFO"
|
|
|
|
|
akka.loggers = ["akka.testkit.TestEventListener"]
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2018-11-15 08:31:59 -08:00
|
|
|
abstract class ClusterLogSpec(config: Config) extends AkkaSpec(config) with ImplicitSender {
|
2018-05-31 14:43:53 +01:00
|
|
|
|
2018-11-15 08:31:59 -08:00
|
|
|
def this(s: String) = this(ConfigFactory.parseString(s))
|
2018-05-31 14:43:53 +01:00
|
|
|
|
2018-11-15 08:31:59 -08:00
|
|
|
protected val selfAddress: Address = system.asInstanceOf[ExtendedActorSystem].provider.getDefaultAddress
|
|
|
|
|
|
2019-02-11 14:37:39 +01:00
|
|
|
protected val upLogMessage = "event MemberUp"
|
2018-11-15 08:31:59 -08:00
|
|
|
|
2019-02-11 14:37:39 +01:00
|
|
|
protected val downLogMessage = "event MemberDowned"
|
2018-11-15 08:31:59 -08:00
|
|
|
|
|
|
|
|
protected val cluster = Cluster(system)
|
|
|
|
|
|
|
|
|
|
protected def clusterView: ClusterReadView = cluster.readView
|
|
|
|
|
|
|
|
|
|
protected def awaitUp(): Unit = {
|
|
|
|
|
awaitCond(clusterView.isSingletonCluster)
|
|
|
|
|
clusterView.self.address should ===(selfAddress)
|
|
|
|
|
clusterView.members.map(_.address) should ===(Set(selfAddress))
|
|
|
|
|
awaitAssert(clusterView.status should ===(MemberStatus.Up))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** The expected log info pattern to intercept after a `cluster.join`. */
|
|
|
|
|
protected def join(expected: String): Unit =
|
2019-03-11 10:38:24 +01:00
|
|
|
EventFilter.info(occurrences = 1, pattern = expected).intercept(cluster.join(selfAddress))
|
2018-11-15 08:31:59 -08:00
|
|
|
|
|
|
|
|
/** The expected log info pattern to intercept after a `cluster.down`. */
|
|
|
|
|
protected def down(expected: String): Unit =
|
2019-03-11 10:38:24 +01:00
|
|
|
EventFilter.info(occurrences = 1, pattern = expected).intercept(cluster.down(selfAddress))
|
2018-11-15 08:31:59 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class ClusterLogDefaultSpec extends ClusterLogSpec(ClusterLogSpec.config) {
|
2018-05-31 14:43:53 +01:00
|
|
|
|
|
|
|
|
"A Cluster" must {
|
|
|
|
|
|
|
|
|
|
"Log a message when becoming and stopping being a leader" in {
|
2018-11-15 08:31:59 -08:00
|
|
|
cluster.settings.LogInfo should ===(true)
|
|
|
|
|
cluster.settings.LogInfoVerbose should ===(false)
|
|
|
|
|
join("is the new leader")
|
|
|
|
|
awaitUp()
|
2019-01-07 13:26:36 +01:00
|
|
|
down("is no longer leader")
|
2018-05-31 14:43:53 +01:00
|
|
|
}
|
2018-11-15 08:31:59 -08:00
|
|
|
}
|
|
|
|
|
}
|
2018-05-31 14:43:53 +01:00
|
|
|
|
2019-03-11 10:38:24 +01:00
|
|
|
class ClusterLogVerboseDefaultSpec extends ClusterLogSpec(ConfigFactory.parseString(ClusterLogSpec.config)) {
|
2018-11-15 08:31:59 -08:00
|
|
|
|
|
|
|
|
"A Cluster" must {
|
|
|
|
|
|
|
|
|
|
"not log verbose cluster events by default" in {
|
|
|
|
|
cluster.settings.LogInfoVerbose should ===(false)
|
|
|
|
|
intercept[AssertionError](join(upLogMessage))
|
|
|
|
|
awaitUp()
|
|
|
|
|
intercept[AssertionError](down(downLogMessage))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-11 10:38:24 +01:00
|
|
|
class ClusterLogVerboseEnabledSpec
|
|
|
|
|
extends ClusterLogSpec(
|
|
|
|
|
ConfigFactory
|
|
|
|
|
.parseString("akka.cluster.log-info-verbose = on")
|
|
|
|
|
.withFallback(ConfigFactory.parseString(ClusterLogSpec.config))) {
|
2018-11-15 08:31:59 -08:00
|
|
|
|
|
|
|
|
"A Cluster" must {
|
|
|
|
|
|
|
|
|
|
"log verbose cluster events when 'log-info-verbose = on'" in {
|
|
|
|
|
cluster.settings.LogInfoVerbose should ===(true)
|
|
|
|
|
join(upLogMessage)
|
|
|
|
|
awaitUp()
|
|
|
|
|
down(downLogMessage)
|
|
|
|
|
}
|
2018-05-31 14:43:53 +01:00
|
|
|
}
|
|
|
|
|
}
|