/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 1997-2010 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package org.glassfish.admin.amxtest.config;
import com.sun.appserv.management.base.Container;
import com.sun.appserv.management.base.XTypes;
import com.sun.appserv.management.config.AMXConfig;
import com.sun.appserv.management.config.HTTPListenerConfig;
import com.sun.appserv.management.config.HTTPListenerConfigKeys;
import com.sun.appserv.management.config.HTTPServiceConfig;
import com.sun.appserv.management.config.PropertiesAccess;
import com.sun.appserv.management.config.SSLConfig;
import static com.sun.appserv.management.config.SSLConfigKeys.*;
import com.sun.appserv.management.util.misc.MapUtil;
import com.sun.appserv.management.util.misc.TypeCast;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
/**
*/
public final class HTTPListenerConfigTest
extends ConfigMgrTestBase {
static final String ADDRESS = "0.0.0.0";
static final String DEF_VIRTUAL_SERVER = "server";
static final String SERVER_NAME = "localhost";
// !!! deliberately use old, incorrect form; it should still succeed
static final Map<String, Object> OPTIONAL = new HashMap<String, Object>();
static {
OPTIONAL.put(PropertiesAccess.PROPERTY_PREFIX + "xyz", "abc");
OPTIONAL.put(HTTPListenerConfigKeys.ENABLED_KEY, Boolean.FALSE);
OPTIONAL.put(HTTPListenerConfigKeys.ACCEPTOR_THREADS_KEY, new Integer(4));
//OPTIONAL.put( HTTPListenerConfigKeys.BLOCKING_ENABLED_KEY, "false" );
//OPTIONAL.put( HTTPListenerConfigKeys.REDIRECT_PORT_KEY, "9081" );
OPTIONAL.put(HTTPListenerConfigKeys.XPOWERED_BY_KEY, Boolean.TRUE);
//OPTIONAL.put( HTTPListenerConfigKeys.FAMILY_KEY, HTTPListenerConfigFamilyValues.INET );
}
public HTTPListenerConfigTest() {
}
HTTPServiceConfig
getHTTPServiceConfig() {
return (getConfigConfig().getHTTPServiceConfig());
}
public void
testGetHTTPListeners() {
final HTTPServiceConfig httpService =
getConfigConfig().getHTTPServiceConfig();
final Map<String, HTTPListenerConfig> proxies = httpService.getHTTPListenerConfigMap();
for (final String listenerName : proxies.keySet()) {
final HTTPListenerConfig listener = (HTTPListenerConfig)
proxies.get(listenerName);
listener.getEnabled();
}
}
protected String
getProgenyTestName() {
return ("HTTPListenerConfigMgrTest-test-listener");
}
protected Container
getProgenyContainer() {
return getHTTPService();
}
protected String
getProgenyJ2EEType() {
return XTypes.HTTP_LISTENER_CONFIG;
}
protected void
removeProgeny(final String name) {
getHTTPService().removeHTTPListenerConfig(name);
}
protected final AMXConfig
createProgeny(
final String name,
final Map<String, String> options) {
// this is incorrect code-on purpose-to test backward compatibility with Maps
// that aren't of type <String,String>
final Map<String, String> optional = TypeCast.asMap(OPTIONAL);
assert (!MapUtil.isAllStrings(optional));
final Map<String, String> allOptions = MapUtil.newMap(options, optional);
assert (!MapUtil.isAllStrings(allOptions));
final int port = 31000 + (name.hashCode() % 31000);
final HTTPListenerConfig config =
getHTTPService().createHTTPListenerConfig(name,
ADDRESS, port, DEF_VIRTUAL_SERVER, SERVER_NAME, allOptions);
return (config);
}
protected final HTTPServiceConfig
getHTTPService() {
return getConfigConfig().getHTTPServiceConfig();
}
public void
testCreateSSL()
throws Exception {
final Map<String, String> options =
Collections.unmodifiableMap(MapUtil.newMap(
new String[]
{
CLIENT_AUTH_ENABLED_KEY, "false",
SSL_2_ENABLED_KEY, "true",
SSL_3_ENABLED_KEY, "true",
SSL_2_CIPHERS_KEY, "+rc4,-rc4export,-rc2,-rc2export,+idea,+des,+desede3",
SSL3_TLS_CIPHERS_KEY,
"+rsa_rc4_128_md5,+rsa3des_sha,+rsa_des_sha,-rsa_rc4_40_md5" +
"-rsa_rc2_40_md5,-rsa_null_md5,-rsa_des_56_sha,-rsa_rc4_56_sha",
TLS_ENABLED_KEY, "true",
TLS_ROLLBACK_ENABLED_KEY, "true",
}
));
if (!checkNotOffline("testCreateSSL")) {
return;
}
final String NAME = "HTTPListenerConfigMgr-listener-for-testCreateSSL";
try {
removeEx(NAME);
final HTTPListenerConfig newListener =
(HTTPListenerConfig) createProgeny(NAME, null);
assert newListener != null;
// verify that the new listener is present
final Map<String, HTTPListenerConfig> listeners =
getHTTPService().getHTTPListenerConfigMap();
final HTTPListenerConfig listener = listeners.get(NAME);
assert listener != null;
assert listener == newListener;
final String CERT_NICKNAME = NAME + "Cert";
final SSLConfig ssl = listener.createSSLConfig(CERT_NICKNAME, options);
assert ssl != null;
assert ssl.getCertNickname().equals(CERT_NICKNAME);
listener.removeSSLConfig();
}
finally {
remove(NAME);
}
}
}