From 92048efaa4a1ce5ae849cc64750fcbaaf3169128 Mon Sep 17 00:00:00 2001 From: Katelyn Baker Date: Thu, 10 May 2018 10:59:15 +0100 Subject: [PATCH] CORDA-1414 - node should continue with parameters from file when network map not available (#3061) (#3098) Fix CORDA-1414 If network map is not available or returns exception on network parameters reading, node should continue with parameters from file. --- .../corda/node/internal/NetworkParametersReader.kt | 5 ++--- .../network/NetworkParametersReaderTest.kt | 14 +++++++++++++- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/node/src/main/kotlin/net/corda/node/internal/NetworkParametersReader.kt b/node/src/main/kotlin/net/corda/node/internal/NetworkParametersReader.kt index ed37b8792b..fde338affe 100644 --- a/node/src/main/kotlin/net/corda/node/internal/NetworkParametersReader.kt +++ b/node/src/main/kotlin/net/corda/node/internal/NetworkParametersReader.kt @@ -10,7 +10,6 @@ import net.corda.nodeapi.internal.network.NETWORK_PARAMS_FILE_NAME import net.corda.nodeapi.internal.network.NETWORK_PARAMS_UPDATE_FILE_NAME import net.corda.nodeapi.internal.network.SignedNetworkParameters import net.corda.nodeapi.internal.network.verifiedNetworkMapCert -import java.net.ConnectException import java.nio.file.Path import java.nio.file.StandardCopyOption import java.security.cert.X509Certificate @@ -29,8 +28,8 @@ class NetworkParametersReader(private val trustRoot: X509Certificate, private fun retrieveNetworkParameters(): NetworkParameters { val advertisedParametersHash = try { networkMapClient?.getNetworkMap()?.payload?.networkParameterHash - } catch (e: ConnectException) { - logger.info("Couldn't connect to NetworkMap", e) + } catch (e: Exception) { + logger.info("Unable to download network map", e) // If NetworkMap is down while restarting the node, we should be still able to continue with parameters from file null } diff --git a/node/src/test/kotlin/net/corda/node/services/network/NetworkParametersReaderTest.kt b/node/src/test/kotlin/net/corda/node/services/network/NetworkParametersReaderTest.kt index 370657e42c..794262e6fd 100644 --- a/node/src/test/kotlin/net/corda/node/services/network/NetworkParametersReaderTest.kt +++ b/node/src/test/kotlin/net/corda/node/services/network/NetworkParametersReaderTest.kt @@ -14,6 +14,7 @@ import net.corda.testing.core.SerializationEnvironmentRule import net.corda.testing.driver.PortAllocation import net.corda.testing.internal.DEV_ROOT_CA import net.corda.testing.node.internal.network.NetworkMapServer +import org.assertj.core.api.Assertions.assertThat import org.junit.After import org.junit.Before import org.junit.Rule @@ -27,6 +28,7 @@ class NetworkParametersReaderTest { @JvmField val testSerialization = SerializationEnvironmentRule(true) + val fs = Jimfs.newFileSystem(Configuration.unix()) private val cacheTimeout = 100000.seconds private lateinit var server: NetworkMapServer @@ -42,11 +44,11 @@ class NetworkParametersReaderTest { @After fun tearDown() { server.close() + fs.close() } @Test fun `read correct set of parameters from file`() { - val fs = Jimfs.newFileSystem(Configuration.unix()) val baseDirectory = fs.getPath("/node").createDirectories() val oldParameters = testNetworkParameters(epoch = 1) NetworkParametersCopier(oldParameters).install(baseDirectory) @@ -60,4 +62,14 @@ class NetworkParametersReaderTest { .verifiedNetworkMapCert(DEV_ROOT_CA.certificate) assertEquals(server.networkParameters, parametersFromFile) } + + @Test + fun `read network parameters from file when network map server is down`() { + server.close() + val baseDirectory = fs.getPath("/node").createDirectories() + val fileParameters = testNetworkParameters(epoch = 1) + NetworkParametersCopier(fileParameters).install(baseDirectory) + val parameters = NetworkParametersReader(DEV_ROOT_CA.certificate, networkMapClient, baseDirectory).networkParameters + assertThat(parameters).isEqualTo(fileParameters) + } } \ No newline at end of file