aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@gmail.com>2013-10-14 01:00:12 +0200
committerSimon Brandhof <simon.brandhof@gmail.com>2013-10-14 01:00:12 +0200
commit275da1c743917341256322a09a3172a2ccf04ef3 (patch)
tree42f62b18140966f7da89847f6033ce8691700285 /sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java
parent5b4b4172c45aa794d7b40c8e5b9fde6d3a001492 (diff)
downloadsonarqube-275da1c743917341256322a09a3172a2ccf04ef3.tar.gz
sonarqube-275da1c743917341256322a09a3172a2ccf04ef3.zip
SONAR-4741 HTTPS mode
Diffstat (limited to 'sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java')
-rw-r--r--sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java141
1 files changed, 105 insertions, 36 deletions
diff --git a/sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java b/sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java
index b40b79b32f0..c1594b2c46a 100644
--- a/sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java
+++ b/sonar-application/src/test/java/org/sonar/application/ConnectorsTest.java
@@ -19,98 +19,167 @@
*/
package org.sonar.application;
+import com.google.common.collect.ImmutableMap;
import org.apache.catalina.connector.Connector;
import org.apache.catalina.startup.Tomcat;
import org.junit.Test;
import org.mockito.ArgumentMatcher;
import org.mockito.Mockito;
+import java.util.Map;
import java.util.Properties;
+import static org.fest.assertions.Assertions.assertThat;
+import static org.fest.assertions.Fail.fail;
import static org.mockito.Matchers.anyInt;
import static org.mockito.Matchers.anyString;
import static org.mockito.Matchers.argThat;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.never;
-import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.*;
public class ConnectorsTest {
+
+ Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
+
+ //---- connectors
+
@Test
- public void enable_shutdown_port() throws Exception {
+ public void configure_thread_pool() throws Exception {
Properties p = new Properties();
- p.setProperty(Connectors.PROPERTY_SHUTDOWN_PORT, "9010");
- p.setProperty(Connectors.PROPERTY_SHUTDOWN_TOKEN, "SHUTDOWN");
+ p.setProperty("sonar.web.http.minThreads", "2");
+ p.setProperty("sonar.web.http.maxThreads", "30");
+ p.setProperty("sonar.web.http.acceptCount", "20");
Props props = new Props(p);
- Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
Connectors.configure(tomcat, props);
- verify(tomcat.getServer()).setPort(9010);
- verify(tomcat.getServer()).setShutdown("SHUTDOWN");
+ verify(tomcat).setConnector(argThat(new PropertiesMatcher(
+ ImmutableMap.<String, Object>of("minSpareThreads", 2, "maxThreads", 30, "acceptCount", 20)
+ )));
}
@Test
- public void disable_shutdown_port_by_default() throws Exception {
+ public void configure_default_thread_pool() throws Exception {
Props props = new Props(new Properties());
- Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
Connectors.configure(tomcat, props);
- verify(tomcat.getServer(), never()).setPort(anyInt());
- verify(tomcat.getServer(), never()).setShutdown(anyString());
+ verify(tomcat).setConnector(argThat(new PropertiesMatcher(
+ ImmutableMap.<String, Object>of("minSpareThreads", 5, "maxThreads", 50, "acceptCount", 25)
+ )));
}
@Test
- public void disable_shutdown_port_if_missing_token() throws Exception {
+ public void fail_if_both_http_and_https_are_disabled() {
Properties p = new Properties();
- // only the port, but not the token
- p.setProperty(Connectors.PROPERTY_SHUTDOWN_PORT, "9010");
+ p.setProperty("sonar.web.http.enable", "false");
+ p.setProperty("sonar.web.https.enable", "false");
Props props = new Props(p);
- Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
- Connectors.configure(tomcat, props);
-
- verify(tomcat.getServer(), never()).setPort(anyInt());
- verify(tomcat.getServer(), never()).setShutdown(anyString());
+ try {
+ Connectors.configure(tomcat, props);
+ fail();
+ } catch (IllegalStateException e) {
+ assertThat(e.getMessage()).isEqualTo("Both HTTP and HTTPS connectors are disabled");
+ }
}
@Test
- public void configure_thread_pool() throws Exception {
+ public void only_https_is_enabled() {
Properties p = new Properties();
- p.setProperty(Connectors.PROPERTY_MIN_THREADS, "2");
- p.setProperty(Connectors.PROPERTY_MAX_THREADS, "30");
- p.setProperty(Connectors.PROPERTY_ACCEPT_COUNT, "20");
+ p.setProperty("sonar.web.http.enable", "false");
+ p.setProperty("sonar.web.https.enable", "true");
Props props = new Props(p);
- Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
Connectors.configure(tomcat, props);
verify(tomcat).setConnector(argThat(new ArgumentMatcher<Connector>() {
@Override
public boolean matches(Object o) {
Connector c = (Connector)o;
- return (Integer)c.getProperty("minSpareThreads") == 2 &&
- (Integer) c.getProperty("maxThreads") == 30 &&
- (Integer) c.getProperty("acceptCount") == 20;
+ return c.getScheme().equals("https") && c.getPort()==9443;
}
}));
}
@Test
- public void configure_default_thread_pool() throws Exception {
- Props props = new Props(new Properties());
+ public void both_http_and_https_are_enabled() {
+ Properties p = new Properties();
+ p.setProperty("sonar.web.http.enable", "true");
+ p.setProperty("sonar.web.https.enable", "true");
+ Props props = new Props(p);
- Tomcat tomcat = mock(Tomcat.class, Mockito.RETURNS_DEEP_STUBS);
Connectors.configure(tomcat, props);
- verify(tomcat).setConnector(argThat(new ArgumentMatcher<Connector>() {
+ verify(tomcat.getService()).addConnector(argThat(new ArgumentMatcher<Connector>() {
@Override
public boolean matches(Object o) {
Connector c = (Connector)o;
- return (Integer)c.getProperty("minSpareThreads") == 5 &&
- (Integer) c.getProperty("maxThreads") == 50 &&
- (Integer) c.getProperty("acceptCount") == 25;
+ return c.getScheme().equals("http") && c.getPort()==9000;
}
}));
+ verify(tomcat.getService()).addConnector(argThat(new ArgumentMatcher<Connector>() {
+ @Override
+ public boolean matches(Object o) {
+ Connector c = (Connector)o;
+ return c.getScheme().equals("https") && c.getPort()==9443;
+ }
+ }));
+ }
+
+
+ //---- shutdown port
+
+ @Test
+ public void enable_shutdown_port() throws Exception {
+ Properties p = new Properties();
+ p.setProperty("sonar.web.shutdown.port", "9010");
+ p.setProperty("sonar.web.shutdown.token", "SHUTDOWN");
+ Props props = new Props(p);
+
+ Connectors.configure(tomcat, props);
+
+ verify(tomcat.getServer()).setPort(9010);
+ verify(tomcat.getServer()).setShutdown("SHUTDOWN");
+ }
+
+ @Test
+ public void disable_shutdown_port_by_default() throws Exception {
+ Props props = new Props(new Properties());
+
+ Connectors.configure(tomcat, props);
+
+ verify(tomcat.getServer(), never()).setPort(anyInt());
+ verify(tomcat.getServer(), never()).setShutdown(anyString());
+ }
+
+ @Test
+ public void disable_shutdown_port_if_missing_token() throws Exception {
+ Properties p = new Properties();
+ // only the port, but not the token
+ p.setProperty("sonar.web.shutdown.port", "9010");
+ Props props = new Props(p);
+
+ Connectors.configure(tomcat, props);
+
+ verify(tomcat.getServer(), never()).setPort(anyInt());
+ verify(tomcat.getServer(), never()).setShutdown(anyString());
+ }
+
+ private static class PropertiesMatcher extends ArgumentMatcher<Connector> {
+ private final Map<String, Object> expected;
+
+ PropertiesMatcher(Map<String, Object> expected) {
+ this.expected = expected;
+ }
+
+ public boolean matches(Object o) {
+ Connector c = (Connector) o;
+ for (Map.Entry<String, Object> entry : expected.entrySet()) {
+ if (!entry.getValue().equals(c.getProperty(entry.getKey()))) {
+ return false;
+ }
+ }
+ return true;
+ }
}
}