-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add test to check keepAlive configuration
- Loading branch information
1 parent
91397c2
commit 363a1e2
Showing
1 changed file
with
148 additions
and
0 deletions.
There are no files selected for viewing
148 changes: 148 additions & 0 deletions
148
carapace-server/src/test/java/org/carapaceproxy/listeners/ListenerConfigurationTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,148 @@ | ||
package org.carapaceproxy.listeners; | ||
|
||
import org.carapaceproxy.configstore.PropertiesConfigurationStore; | ||
import org.carapaceproxy.core.HttpProxyServer; | ||
import org.carapaceproxy.core.Listeners; | ||
import org.carapaceproxy.server.config.ConfigurationChangeInProgressException; | ||
import org.carapaceproxy.server.config.NetworkListenerConfiguration; | ||
import org.junit.Rule; | ||
import org.junit.Test; | ||
import org.junit.rules.TemporaryFolder; | ||
|
||
import java.util.Map; | ||
import java.util.Properties; | ||
|
||
import static org.junit.Assert.assertEquals; | ||
import static org.junit.Assert.assertTrue; | ||
|
||
public class ListenerConfigurationTest { | ||
|
||
@Rule | ||
public TemporaryFolder tmpDir = new TemporaryFolder(); | ||
|
||
@Test | ||
public void testListenerKeepAliveConfiguration() throws Exception { | ||
try (HttpProxyServer server = new HttpProxyServer(null, tmpDir.newFolder());) { | ||
|
||
{ | ||
Properties configuration = new Properties(); | ||
configuration.put("listener.1.host", "localhost"); | ||
configuration.put("listener.1.port", "8080"); | ||
configuration.put("listener.1.enabled", "true"); | ||
|
||
server.configureAtBoot(new PropertiesConfigurationStore(configuration)); | ||
} | ||
server.start(); | ||
|
||
NetworkListenerConfiguration.HostPort listenerKey = | ||
new NetworkListenerConfiguration.HostPort("localhost", 8080); | ||
|
||
{ | ||
Map<NetworkListenerConfiguration.HostPort, Listeners.ListeningChannel> listeners = | ||
server.getListeners().getListeningChannels(); | ||
|
||
//check default configuration | ||
assertEquals(true, listeners.get(listenerKey).getConfig().isKeepAlive()); | ||
assertEquals(128, listeners.get(listenerKey).getConfig().getSoBacklog()); | ||
assertEquals(300, listeners.get(listenerKey).getConfig().getKeepAliveIdle()); | ||
assertEquals(60, listeners.get(listenerKey).getConfig().getKeepAliveInterval()); | ||
assertEquals(8, listeners.get(listenerKey).getConfig().getKeepAliveCount()); | ||
assertEquals(1000, listeners.get(listenerKey).getConfig().getMaxKeepAliveRequests()); | ||
} | ||
//disable keepAlive | ||
{ | ||
Properties configuration = new Properties(); | ||
configuration.put("listener.1.host", "localhost"); | ||
configuration.put("listener.1.port", "8080"); | ||
configuration.put("listener.1.keepalive", "false"); | ||
configuration.put("listener.1.enabled", "true"); | ||
|
||
reloadConfiguration(configuration, server); | ||
|
||
Map<NetworkListenerConfiguration.HostPort, Listeners.ListeningChannel> listeners = | ||
server.getListeners().getListeningChannels(); | ||
|
||
assertEquals(1, listeners.size()); | ||
assertEquals(false, listeners.get(listenerKey).getConfig().isKeepAlive()); | ||
} | ||
|
||
//customize keepAlive options | ||
{ | ||
Properties configuration = new Properties(); | ||
// SSL Listener | ||
configuration.put("listener.1.host", "localhost"); | ||
configuration.put("listener.1.port", "8080"); | ||
configuration.put("listener.1.keepalive", "true"); | ||
configuration.put("listener.1.keepaliveidle", "10"); | ||
configuration.put("listener.1.keepaliveinterval", "5"); | ||
configuration.put("listener.1.keepalivecount", "2"); | ||
configuration.put("listener.1.maxkeepaliverequests", "2"); | ||
configuration.put("listener.1.sobacklog", "10"); | ||
configuration.put("listener.1.enabled", "true"); | ||
reloadConfiguration(configuration, server); | ||
|
||
Map<NetworkListenerConfiguration.HostPort, Listeners.ListeningChannel> listeners = | ||
server.getListeners().getListeningChannels(); | ||
|
||
assertEquals(true, listeners.get(listenerKey).getConfig().isKeepAlive()); | ||
assertEquals(10, listeners.get(listenerKey).getConfig().getSoBacklog()); | ||
assertEquals(10, listeners.get(listenerKey).getConfig().getKeepAliveIdle()); | ||
assertEquals(5, listeners.get(listenerKey).getConfig().getKeepAliveInterval()); | ||
assertEquals(2, listeners.get(listenerKey).getConfig().getKeepAliveCount()); | ||
assertEquals(2, listeners.get(listenerKey).getConfig().getMaxKeepAliveRequests()); | ||
} | ||
|
||
//negative maxkeepAliverequests | ||
// value accepted -1, 1, >0 | ||
{ | ||
try { | ||
Properties configuration = new Properties(); | ||
configuration.put("listener.1.host", "localhost"); | ||
configuration.put("listener.1.port", "8080"); | ||
configuration.put("listener.1.keepalive", "true"); | ||
configuration.put("listener.1.maxkeepaliverequests", "-10"); // negative value not valid | ||
configuration.put("listener.1.enabled", "true"); | ||
|
||
reloadConfiguration(configuration, server); | ||
|
||
Map<NetworkListenerConfiguration.HostPort, Listeners.ListeningChannel> listeners = | ||
server.getListeners().getListeningChannels(); | ||
|
||
assertEquals(1, listeners.size()); | ||
assertEquals(false, listeners.get(listenerKey).getConfig().isKeepAlive()); | ||
} catch (IllegalArgumentException e) { | ||
assertTrue(e.getMessage().contains("maxKeepAliveRequests must be positive or -1")); | ||
} | ||
} | ||
|
||
// maxkeepAliverequests = 0 | ||
// value accepted -1, 1, >0 | ||
{ | ||
try { | ||
Properties configuration = new Properties(); | ||
configuration.put("listener.1.host", "localhost"); | ||
configuration.put("listener.1.port", "8080"); | ||
configuration.put("listener.1.keepalive", "true"); | ||
configuration.put("listener.1.maxkeepaliverequests", "0"); //0 is not valid | ||
configuration.put("listener.1.enabled", "true"); | ||
|
||
reloadConfiguration(configuration, server); | ||
|
||
Map<NetworkListenerConfiguration.HostPort, Listeners.ListeningChannel> listeners = | ||
server.getListeners().getListeningChannels(); | ||
|
||
assertEquals(1, listeners.size()); | ||
assertEquals(false, listeners.get(listenerKey).getConfig().isKeepAlive()); | ||
} catch (IllegalArgumentException e) { | ||
assertTrue(e.getMessage().contains("maxKeepAliveRequests must be positive or -1")); | ||
} | ||
} | ||
} | ||
} | ||
|
||
private void reloadConfiguration(Properties configuration, final HttpProxyServer server) throws | ||
ConfigurationChangeInProgressException, InterruptedException { | ||
PropertiesConfigurationStore config = new PropertiesConfigurationStore(configuration); | ||
server.applyDynamicConfigurationFromAPI(config); | ||
} | ||
} |