/* * Copyright 2014 Red Hat, Inc. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * and Apache License v2.0 which accompanies this distribution. * * The Eclipse Public License is available at * http://www.eclipse.org/legal/epl-v10.html * * The Apache License v2.0 is available at * http://www.opensource.org/licenses/apache2.0.php * * You may elect to redistribute this code under either of these licenses. */ package io.vertx.test.core; import io.vertx.core.VertxOptions; import io.vertx.core.json.JsonObject; import io.vertx.core.metrics.MetricsOptions; import io.vertx.core.spi.cluster.ClusterManager; import io.vertx.test.fakecluster.FakeClusterManager; import org.junit.Test; import java.util.Random; /** * @author <a href="http://tfox.org">Tim Fox</a> */ public class VertxOptionsTest extends VertxTestBase { @Test public void testOptions() { VertxOptions options = new VertxOptions(); assertEquals(2 * Runtime.getRuntime().availableProcessors(), options.getEventLoopPoolSize()); int rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setEventLoopPoolSize(rand)); assertEquals(rand, options.getEventLoopPoolSize()); try { options.setEventLoopPoolSize(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(20, options.getWorkerPoolSize()); rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setWorkerPoolSize(rand)); assertEquals(rand, options.getWorkerPoolSize()); try { options.setWorkerPoolSize(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(20, options.getInternalBlockingPoolSize()); rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setInternalBlockingPoolSize(rand)); assertEquals(rand, options.getInternalBlockingPoolSize()); try { options.setInternalBlockingPoolSize(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertFalse(options.isClustered()); assertEquals(options, options.setClustered(true)); assertTrue(options.isClustered()); assertEquals(0, options.getClusterPort()); assertEquals(options, options.setClusterPort(1234)); assertEquals(1234, options.getClusterPort()); try { options.setClusterPort(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } try { options.setClusterPort(65536); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(-1, options.getClusterPublicPort()); assertEquals(options, options.setClusterPublicPort(1234)); assertEquals(1234, options.getClusterPublicPort()); try { options.setClusterPublicPort(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } try { options.setClusterPublicPort(65536); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals("localhost", options.getClusterHost()); String randString = TestUtils.randomUnicodeString(100); assertEquals(options, options.setClusterHost(randString)); assertEquals(randString, options.getClusterHost()); assertEquals(null, options.getClusterPublicHost()); randString = TestUtils.randomUnicodeString(100); assertEquals(options, options.setClusterPublicHost(randString)); assertEquals(randString, options.getClusterPublicHost()); assertEquals(20000, options.getClusterPingInterval()); long randomLong = TestUtils.randomPositiveLong(); assertEquals(options, options.setClusterPingInterval(randomLong)); assertEquals(randomLong, options.getClusterPingInterval()); try { options.setClusterPingInterval(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { assertEquals(randomLong, options.getClusterPingInterval()); } assertEquals(20000, options.getClusterPingReplyInterval()); randomLong = TestUtils.randomPositiveLong(); assertEquals(options, options.setClusterPingReplyInterval(randomLong)); assertEquals(randomLong, options.getClusterPingReplyInterval()); try { options.setClusterPingReplyInterval(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { assertEquals(randomLong, options.getClusterPingReplyInterval()); } assertEquals(1000, options.getBlockedThreadCheckInterval()); rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setBlockedThreadCheckInterval(rand)); assertEquals(rand, options.getBlockedThreadCheckInterval()); try { options.setBlockedThreadCheckInterval(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(2000l * 1000000, options.getMaxEventLoopExecuteTime()); // 2 seconds in nano seconds rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setMaxEventLoopExecuteTime(rand)); assertEquals(rand, options.getMaxEventLoopExecuteTime()); try { options.setMaxEventLoopExecuteTime(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(1l * 60 * 1000 * 1000000, options.getMaxWorkerExecuteTime()); // 1 minute in nano seconds rand = TestUtils.randomPositiveInt(); assertEquals(options, options.setMaxWorkerExecuteTime(rand)); assertEquals(rand, options.getMaxWorkerExecuteTime()); try { options.setMaxWorkerExecuteTime(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } ClusterManager mgr = new FakeClusterManager(); assertNull(options.getClusterManager()); assertEquals(options, options.setClusterManager(mgr)); assertSame(mgr, options.getClusterManager()); assertFalse(options.isHAEnabled()); assertEquals(options, options.setHAEnabled(true)); assertTrue(options.isHAEnabled()); rand = TestUtils.randomPositiveInt(); assertEquals(1, options.getQuorumSize()); assertEquals(options, options.setQuorumSize(rand)); assertEquals(rand, options.getQuorumSize()); try { options.setQuorumSize(0); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } try { options.setQuorumSize(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(VertxOptions.DEFAULT_HA_GROUP, options.getHAGroup()); randString = TestUtils.randomUnicodeString(100); assertEquals(options, options.setHAGroup(randString)); assertEquals(randString, options.getHAGroup()); try { options.setHAGroup(null); fail("Should throw exception"); } catch (NullPointerException e) { // OK } assertNotNull(options.getMetricsOptions()); try { options.setWarningExceptionTime(-1); fail("Should throw exception"); } catch (IllegalArgumentException e) { // OK } assertEquals(options, options.setWarningExceptionTime(1000000000l)); assertEquals(1000000000l, options.getWarningExceptionTime()); } @Test public void testCopyOptions() { VertxOptions options = new VertxOptions(); int clusterPort = TestUtils.randomPortInt(); int clusterPublicPort = TestUtils.randomPortInt(); int eventLoopPoolSize = TestUtils.randomPositiveInt(); int internalBlockingPoolSize = TestUtils.randomPositiveInt(); int workerPoolSize = TestUtils.randomPositiveInt(); int blockedThreadCheckInterval = TestUtils.randomPositiveInt(); String clusterHost = TestUtils.randomAlphaString(100); String clusterPublicHost = TestUtils.randomAlphaString(100); long clusterPingInterval = TestUtils.randomPositiveLong(); long clusterPingReplyInterval = TestUtils.randomPositiveLong(); int maxEventLoopExecuteTime = TestUtils.randomPositiveInt(); int maxWorkerExecuteTime = TestUtils.randomPositiveInt(); Random rand = new Random(); boolean haEnabled = rand.nextBoolean(); boolean metricsEnabled = rand.nextBoolean(); int quorumSize = 51214; String haGroup = TestUtils.randomAlphaString(100); long warningExceptionTime = TestUtils.randomPositiveLong(); options.setClusterPort(clusterPort); options.setClusterPublicPort(clusterPublicPort); options.setEventLoopPoolSize(eventLoopPoolSize); options.setInternalBlockingPoolSize(internalBlockingPoolSize); options.setWorkerPoolSize(workerPoolSize); options.setBlockedThreadCheckInterval(blockedThreadCheckInterval); options.setClusterHost(clusterHost); options.setClusterPublicHost(clusterPublicHost); options.setClusterPingInterval(clusterPingInterval); options.setClusterPingReplyInterval(clusterPingReplyInterval); options.setMaxEventLoopExecuteTime(maxEventLoopExecuteTime); options.setMaxWorkerExecuteTime(maxWorkerExecuteTime); options.setHAEnabled(haEnabled); options.setQuorumSize(quorumSize); options.setHAGroup(haGroup); options.setMetricsOptions( new MetricsOptions(). setEnabled(metricsEnabled)); options.setWarningExceptionTime(warningExceptionTime); options = new VertxOptions(options); assertEquals(clusterPort, options.getClusterPort()); assertEquals(clusterPublicPort, options.getClusterPublicPort()); assertEquals(clusterPingInterval, options.getClusterPingInterval()); assertEquals(clusterPingReplyInterval, options.getClusterPingReplyInterval()); assertEquals(eventLoopPoolSize, options.getEventLoopPoolSize()); assertEquals(internalBlockingPoolSize, options.getInternalBlockingPoolSize()); assertEquals(workerPoolSize, options.getWorkerPoolSize()); assertEquals(blockedThreadCheckInterval, options.getBlockedThreadCheckInterval()); assertEquals(clusterHost, options.getClusterHost()); assertEquals(clusterPublicHost, options.getClusterPublicHost()); assertEquals(maxEventLoopExecuteTime, options.getMaxEventLoopExecuteTime()); assertEquals(maxWorkerExecuteTime, options.getMaxWorkerExecuteTime()); assertEquals(haEnabled, options.isHAEnabled()); assertEquals(quorumSize, options.getQuorumSize()); assertEquals(haGroup, options.getHAGroup()); MetricsOptions metricsOptions = options.getMetricsOptions(); assertNotNull(metricsOptions); assertEquals(metricsEnabled, metricsOptions.isEnabled()); assertEquals(warningExceptionTime, options.getWarningExceptionTime()); } @Test public void testDefaultJsonOptions() { VertxOptions def = new VertxOptions(); VertxOptions json = new VertxOptions(new JsonObject()); assertEquals(def.getEventLoopPoolSize(), json.getEventLoopPoolSize()); assertEquals(def.getWorkerPoolSize(), json.getWorkerPoolSize()); assertEquals(def.isClustered(), json.isClustered()); assertEquals(def.getClusterHost(), json.getClusterHost()); assertEquals(def.getClusterPublicHost(), json.getClusterPublicHost()); assertEquals(def.getClusterPublicPort(), json.getClusterPublicPort()); assertEquals(def.getClusterPingInterval(), json.getClusterPingInterval()); assertEquals(def.getClusterPingReplyInterval(), json.getClusterPingReplyInterval()); assertEquals(def.getBlockedThreadCheckInterval(), json.getBlockedThreadCheckInterval()); assertEquals(def.getMaxEventLoopExecuteTime(), json.getMaxEventLoopExecuteTime()); assertEquals(def.getMaxWorkerExecuteTime(), json.getMaxWorkerExecuteTime()); assertEquals(def.getInternalBlockingPoolSize(), json.getInternalBlockingPoolSize()); assertEquals(def.isHAEnabled(), json.isHAEnabled()); assertEquals(def.getQuorumSize(), json.getQuorumSize()); assertEquals(def.getHAGroup(), json.getHAGroup()); assertEquals(def.getWarningExceptionTime(), json.getWarningExceptionTime()); } @Test public void testJsonOptions() { VertxOptions options = new VertxOptions(new JsonObject()); assertEquals(0, options.getClusterPort()); assertEquals(-1, options.getClusterPublicPort()); assertEquals(20000, options.getClusterPingInterval()); assertEquals(20000, options.getClusterPingReplyInterval()); assertEquals(2 * Runtime.getRuntime().availableProcessors(), options.getEventLoopPoolSize()); assertEquals(20, options.getInternalBlockingPoolSize()); assertEquals(20, options.getWorkerPoolSize()); assertEquals(1000, options.getBlockedThreadCheckInterval()); assertEquals("localhost", options.getClusterHost()); assertNull(options.getClusterPublicHost()); assertEquals(null, options.getClusterManager()); assertEquals(2000l * 1000000, options.getMaxEventLoopExecuteTime()); assertEquals(1l * 60 * 1000 * 1000000, options.getMaxWorkerExecuteTime()); assertFalse(options.isHAEnabled()); assertEquals(1, options.getQuorumSize()); assertEquals(VertxOptions.DEFAULT_HA_GROUP, options.getHAGroup()); assertNotNull(options.getMetricsOptions()); assertEquals(5000000000l, options.getWarningExceptionTime()); int clusterPort = TestUtils.randomPortInt(); int clusterPublicPort = TestUtils.randomPortInt(); int eventLoopPoolSize = TestUtils.randomPositiveInt(); int internalBlockingPoolSize = TestUtils.randomPositiveInt(); int workerPoolSize = TestUtils.randomPositiveInt(); int blockedThreadCheckInterval = TestUtils.randomPositiveInt(); String clusterHost = TestUtils.randomAlphaString(100); String clusterPublicHost = TestUtils.randomAlphaString(100); long clusterPingInterval = TestUtils.randomPositiveLong(); long clusterPingReplyInterval = TestUtils.randomPositiveLong(); int maxEventLoopExecuteTime = TestUtils.randomPositiveInt(); int maxWorkerExecuteTime = TestUtils.randomPositiveInt(); int proxyOperationTimeout = TestUtils.randomPositiveInt(); long warningExceptionTime = TestUtils.randomPositiveLong(); Random rand = new Random(); boolean haEnabled = rand.nextBoolean(); int quorumSize = TestUtils.randomShort() + 1; String haGroup = TestUtils.randomAlphaString(100); boolean metricsEnabled = rand.nextBoolean(); boolean jmxEnabled = rand.nextBoolean(); String jmxDomain = TestUtils.randomAlphaString(100); options = new VertxOptions(new JsonObject(). put("clusterPort", clusterPort). put("clusterPublicPort", clusterPublicPort). put("eventLoopPoolSize", eventLoopPoolSize). put("internalBlockingPoolSize", internalBlockingPoolSize). put("workerPoolSize", workerPoolSize). put("blockedThreadCheckInterval", blockedThreadCheckInterval). put("clusterHost", clusterHost). put("clusterPublicHost", clusterPublicHost). put("clusterPingInterval", clusterPingInterval). put("clusterPingReplyInterval", clusterPingReplyInterval). put("maxEventLoopExecuteTime", maxEventLoopExecuteTime). put("maxWorkerExecuteTime", maxWorkerExecuteTime). put("proxyOperationTimeout", proxyOperationTimeout). put("haEnabled", haEnabled). put("quorumSize", quorumSize). put("haGroup", haGroup). put("warningExceptionTime", warningExceptionTime). put("metricsOptions", new JsonObject(). put("enabled", metricsEnabled). put("jmxEnabled", jmxEnabled). put("jmxDomain", jmxDomain)) ); assertEquals(clusterPort, options.getClusterPort()); assertEquals(clusterPublicPort, options.getClusterPublicPort()); assertEquals(clusterPublicHost, options.getClusterPublicHost()); assertEquals(clusterPingInterval, options.getClusterPingInterval()); assertEquals(clusterPingReplyInterval, options.getClusterPingReplyInterval()); assertEquals(eventLoopPoolSize, options.getEventLoopPoolSize()); assertEquals(internalBlockingPoolSize, options.getInternalBlockingPoolSize()); assertEquals(workerPoolSize, options.getWorkerPoolSize()); assertEquals(blockedThreadCheckInterval, options.getBlockedThreadCheckInterval()); assertEquals(clusterHost, options.getClusterHost()); assertEquals(null, options.getClusterManager()); assertEquals(maxEventLoopExecuteTime, options.getMaxEventLoopExecuteTime()); assertEquals(maxWorkerExecuteTime, options.getMaxWorkerExecuteTime()); assertEquals(haEnabled, options.isHAEnabled()); assertEquals(quorumSize, options.getQuorumSize()); assertEquals(haGroup, options.getHAGroup()); MetricsOptions metricsOptions = options.getMetricsOptions(); assertEquals(metricsEnabled, metricsOptions.isEnabled()); assertEquals(warningExceptionTime, options.getWarningExceptionTime()); } }