diff options
| author | Robert Gemmell <robbie@apache.org> | 2012-07-19 16:22:02 +0000 |
|---|---|---|
| committer | Robert Gemmell <robbie@apache.org> | 2012-07-19 16:22:02 +0000 |
| commit | 860c6e3314fc21025daab26ba665eb2c27225500 (patch) | |
| tree | 05a0057acab28557c386570813e412e9fe01a32d /qpid/java | |
| parent | c54a1ba9aab37fd44beeda6557a70b5624acd858 (diff) | |
| download | qpid-python-860c6e3314fc21025daab26ba665eb2c27225500.tar.gz | |
QPID-3998: Add HTTPS test for REST interfaces
Applied patch from Oleksandr Rudyy <orudyy@gmail.com>
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1363413 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java')
3 files changed, 103 insertions, 4 deletions
diff --git a/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/BrokerRestHttpsTest.java b/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/BrokerRestHttpsTest.java new file mode 100644 index 0000000000..4bbe9155cd --- /dev/null +++ b/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/BrokerRestHttpsTest.java @@ -0,0 +1,86 @@ +/* + * + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + * + */ +package org.apache.qpid.server.management.plugin.servlet.rest; + +import java.io.IOException; +import java.net.HttpURLConnection; +import java.net.URL; +import java.util.Map; + +import javax.net.ssl.HttpsURLConnection; +import javax.net.ssl.SSLSocketFactory; + +import org.apache.commons.configuration.ConfigurationException; +import org.apache.qpid.server.model.Broker; + +public class BrokerRestHttpsTest extends QpidRestTestCase +{ + private static final String TRUSTSTORE = "test-profiles/test_resources/ssl/java_client_truststore.jks"; + private static final String TRUSTSTORE_PASSWORD = "password"; + + @Override + public void setUp() throws Exception + { + setSystemProperty("javax.net.debug", "ssl"); + super.setUp(); + setSystemProperty("javax.net.ssl.trustStore", TRUSTSTORE); + setSystemProperty("javax.net.ssl.trustStorePassword", TRUSTSTORE_PASSWORD); + } + + @Override + protected void customizeConfiguration() throws ConfigurationException, IOException + { + setConfigurationProperty("management.enabled", "true"); + setConfigurationProperty("management.http.enabled", "false"); + setConfigurationProperty("management.https.enabled", "true"); + setConfigurationProperty("management.https.port", Integer.toString(getHttpPort())); + } + + @Override + protected String getHostName() + { + return "localhost"; + } + + @Override + protected String getProtocol() + { + return "https"; + } + + @Override + protected HttpURLConnection openManagementConection(String path) throws IOException + { + URL url = getManagementURL(path); + HttpURLConnection httpCon = (HttpURLConnection) url.openConnection(); + ((HttpsURLConnection) httpCon).setSSLSocketFactory((SSLSocketFactory) SSLSocketFactory.getDefault()); + httpCon.setDoOutput(true); + return httpCon; + } + + public void testGetWithHttps() throws Exception + { + Map<String, Object> brokerDetails = getJsonAsSingletonList("/rest/broker"); + + Asserts.assertAttributesPresent(brokerDetails, Broker.AVAILABLE_ATTRIBUTES, Broker.BYTES_RETAINED, + Broker.PROCESS_PID, Broker.SUPPORTED_STORE_TYPES, Broker.CREATED, Broker.TIME_TO_LIVE, Broker.UPDATED); + } +} diff --git a/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/QpidRestTestCase.java b/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/QpidRestTestCase.java index 5e9135f267..e83341de80 100644 --- a/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/QpidRestTestCase.java +++ b/qpid/java/broker-plugins/management-http/src/test/java/org/apache/qpid/server/management/plugin/servlet/rest/QpidRestTestCase.java @@ -33,6 +33,7 @@ import java.util.LinkedHashMap; import java.util.List; import java.util.Map; +import org.apache.commons.configuration.ConfigurationException; import org.apache.log4j.Logger; import org.apache.qpid.test.utils.QpidBrokerTestCase; import org.codehaus.jackson.JsonGenerationException; @@ -54,16 +55,23 @@ public class QpidRestTestCase extends QpidBrokerTestCase private String _hostName; private List<HttpURLConnection> _httpConnections; + @Override public void setUp() throws Exception { _httpConnections = new ArrayList<HttpURLConnection>(); _hostName = InetAddress.getLocalHost().getHostName(); _httpPort = findFreePort(); - setConfigurationProperty("management.enabled", "true"); + customizeConfiguration(); + super.setUp(); + + } + + protected void customizeConfiguration() throws ConfigurationException, IOException + { + setConfigurationProperty("management.enabled", "false"); setConfigurationProperty("management.http.enabled", "true"); + setConfigurationProperty("management.https.enabled", "false"); setConfigurationProperty("management.http.port", Integer.toString(_httpPort)); - setConfigurationProperty("management.jmx.enabled", "false"); - super.setUp(); } public void teearDown() throws Exception @@ -92,9 +100,14 @@ public class QpidRestTestCase extends QpidBrokerTestCase return _hostName; } + protected String getProtocol() + { + return "http"; + } + protected String getManagementURL() { - return "http://" + _hostName + ":" + _httpPort; + return getProtocol() + "://" + getHostName() + ":" + getHttpPort(); } protected URL getManagementURL(String path) throws MalformedURLException diff --git a/qpid/java/test-profiles/test_resources/ssl/java_broker_keystore.jks b/qpid/java/test-profiles/test_resources/ssl/java_broker_keystore.jks Binary files differindex 38a9a269a5..29ae3a8e67 100644 --- a/qpid/java/test-profiles/test_resources/ssl/java_broker_keystore.jks +++ b/qpid/java/test-profiles/test_resources/ssl/java_broker_keystore.jks |
