Code rewiew: turn dev mode options into a data class

This commit is contained in:
Christian Sailer 2017-10-27 15:13:00 +01:00
parent 5440594afd
commit 5b5a4bd2e4
3 changed files with 13 additions and 17 deletions

View File

@ -11,6 +11,8 @@ import java.net.URL
import java.nio.file.Path import java.nio.file.Path
import java.util.* import java.util.*
data class DevModeOptions(val disableCheckpointChecker: Boolean?)
interface NodeConfiguration : NodeSSLConfiguration { interface NodeConfiguration : NodeSSLConfiguration {
// myLegalName should be only used in the initial network registration, we should use the name from the certificate instead of this. // myLegalName should be only used in the initial network registration, we should use the name from the certificate instead of this.
// TODO: Remove this so we don't accidentally use this identity in the code? // TODO: Remove this so we don't accidentally use this identity in the code?
@ -28,7 +30,7 @@ interface NodeConfiguration : NodeSSLConfiguration {
val database: Properties? val database: Properties?
val rpcUsers: List<User> val rpcUsers: List<User>
val devMode: Boolean val devMode: Boolean
val devModeOptions: Properties? val devModeOptions: DevModeOptions?
val certificateSigningService: URL val certificateSigningService: URL
val certificateChainCheckPolicies: List<CertChainPolicyConfig> val certificateChainCheckPolicies: List<CertChainPolicyConfig>
val verifierType: VerifierType val verifierType: VerifierType
@ -42,10 +44,6 @@ interface NodeConfiguration : NodeSSLConfiguration {
} }
} }
fun NodeConfiguration.isDevModeOptionsFlagSet(flag: String): Boolean {
return this.devModeOptions?.get(flag).toString().toLowerCase() == "true"
}
data class NotaryConfig(val validating: Boolean, data class NotaryConfig(val validating: Boolean,
val raft: RaftConfig? = null, val raft: RaftConfig? = null,
val bftSMaRt: BFTSMaRtConfiguration? = null, val bftSMaRt: BFTSMaRtConfiguration? = null,
@ -102,7 +100,7 @@ data class FullNodeConfiguration(
override val notary: NotaryConfig?, override val notary: NotaryConfig?,
override val certificateChainCheckPolicies: List<CertChainPolicyConfig>, override val certificateChainCheckPolicies: List<CertChainPolicyConfig>,
override val devMode: Boolean = false, override val devMode: Boolean = false,
override val devModeOptions: Properties? = null, override val devModeOptions: DevModeOptions? = null,
val useTestClock: Boolean = false, val useTestClock: Boolean = false,
val detectPublicIp: Boolean = true, val detectPublicIp: Boolean = true,
override val activeMQServer: ActiveMqServerConfiguration, override val activeMQServer: ActiveMqServerConfiguration,

View File

@ -32,7 +32,6 @@ import net.corda.node.services.api.Checkpoint
import net.corda.node.services.api.CheckpointStorage import net.corda.node.services.api.CheckpointStorage
import net.corda.node.services.api.ServiceHubInternal import net.corda.node.services.api.ServiceHubInternal
import net.corda.node.services.config.NodeConfiguration import net.corda.node.services.config.NodeConfiguration
import net.corda.node.services.config.isDevModeOptionsFlagSet
import net.corda.node.services.messaging.ReceivedMessage import net.corda.node.services.messaging.ReceivedMessage
import net.corda.node.services.messaging.TopicSession import net.corda.node.services.messaging.TopicSession
import net.corda.node.utilities.* import net.corda.node.utilities.*
@ -91,7 +90,7 @@ class StateMachineManagerImpl(
private val mutex = ThreadBox(InnerState()) private val mutex = ThreadBox(InnerState())
// This thread (only enabled in dev mode) deserialises checkpoints in the background to shake out bugs in checkpoint restore. // This thread (only enabled in dev mode) deserialises checkpoints in the background to shake out bugs in checkpoint restore.
private val checkpointCheckerThread = if (serviceHub.configuration.devMode private val checkpointCheckerThread = if (serviceHub.configuration.devMode
&& !serviceHub.configuration.isDevModeOptionsFlagSet(NodeConfiguration.DISABLE_CHECKPOINT_CHECKER)) && serviceHub.configuration.devModeOptions?.disableCheckpointChecker != true)
newNamedSingleThreadExecutor("CheckpointChecker") else null newNamedSingleThreadExecutor("CheckpointChecker") else null
@Volatile private var unrestorableCheckpoints = false @Volatile private var unrestorableCheckpoints = false

View File

@ -70,10 +70,10 @@ class FullNodeConfigurationTest {
activeMQServer = ActiveMqServerConfiguration(BridgeConfiguration(0, 0, 0.0)), activeMQServer = ActiveMqServerConfiguration(BridgeConfiguration(0, 0, 0.0)),
additionalNodeInfoPollingFrequencyMsec = 5.seconds.toMillis()) additionalNodeInfoPollingFrequencyMsec = 5.seconds.toMillis())
fun configDebugOptions(devMode: Boolean, debugOptions: Properties?) { fun configDebugOptions(devMode: Boolean, debugOptions: DevModeOptions?) {
testConfiguration.copy(devMode = devMode, devModeOptions = debugOptions) testConfiguration.copy(devMode = devMode, devModeOptions = debugOptions)
} }
val debugOptions = Properties() val debugOptions = DevModeOptions(null)
configDebugOptions(true, debugOptions) configDebugOptions(true, debugOptions)
configDebugOptions(true,null) configDebugOptions(true,null)
assertThatThrownBy{configDebugOptions(false, debugOptions)}.hasMessageMatching( "Cannot use devModeOptions outside of dev mode" ) assertThatThrownBy{configDebugOptions(false, debugOptions)}.hasMessageMatching( "Cannot use devModeOptions outside of dev mode" )
@ -105,14 +105,13 @@ class FullNodeConfigurationTest {
activeMQServer = ActiveMqServerConfiguration(BridgeConfiguration(0, 0, 0.0)), activeMQServer = ActiveMqServerConfiguration(BridgeConfiguration(0, 0, 0.0)),
additionalNodeInfoPollingFrequencyMsec = 5.seconds.toMillis()) additionalNodeInfoPollingFrequencyMsec = 5.seconds.toMillis())
fun configDebugOptions(devMode: Boolean, debugOptions: Properties?) : NodeConfiguration { fun configDebugOptions(devMode: Boolean, devModeOptions: DevModeOptions?) : NodeConfiguration {
return testConfiguration.copy(devMode = devMode, devModeOptions = debugOptions) return testConfiguration.copy(devMode = devMode, devModeOptions = devModeOptions)
} }
val debugOptions = Properties() assertFalse { configDebugOptions(true,null).devModeOptions?.disableCheckpointChecker == true}
assertFalse { configDebugOptions(true,null).isDevModeOptionsFlagSet("foo")} assertFalse { configDebugOptions(true,DevModeOptions(null)).devModeOptions?.disableCheckpointChecker == true}
assertFalse { configDebugOptions(true,debugOptions).isDevModeOptionsFlagSet("foo")} assertFalse { configDebugOptions(true,DevModeOptions(false)).devModeOptions?.disableCheckpointChecker == true}
debugOptions.setProperty("foo", "tRuE") assert ( configDebugOptions(true,DevModeOptions(true)).devModeOptions?.disableCheckpointChecker == true)
assert( configDebugOptions(true, debugOptions).isDevModeOptionsFlagSet("foo"))
} }
} }