FileDocCategorySizeDatePackage
ReferencesTest.javaAPI DocGlassfish v2 API11851Fri May 04 22:23:56 BST 2007com.sun.enterprise.management.config

ReferencesTest.java

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 * 
 * Copyright 1997-2007 Sun Microsystems, Inc. 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.html
 * or glassfish/bootstrap/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 glassfish/bootstrap/legal/LICENSE.txt.
 * Sun designates this particular file as subject to the "Classpath" exception
 * as provided by Sun in the GPL Version 2 section of the License file that
 * accompanied this code.  If applicable, add the following below the License
 * Header, with the fields enclosed by brackets [] replaced by your own
 * identifying information: "Portions Copyrighted [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.
 */

/*
 * $Header: /cvs/glassfish/admin/mbeanapi-impl/tests/com/sun/enterprise/management/config/ReferencesTest.java,v 1.8 2007/05/05 05:23:55 tcfujii Exp $
 * $Revision: 1.8 $
 * $Date: 2007/05/05 05:23:55 $
 */
package com.sun.enterprise.management.config;

import java.util.Set;
import java.util.Map;

import javax.management.AttributeList;
import javax.management.Notification;
import javax.management.NotificationListener;
import javax.management.MBeanServerConnection;
import javax.management.NotCompliantMBeanException;

import com.sun.appserv.management.base.XTypes;
import com.sun.appserv.management.base.AMX;
import com.sun.appserv.management.base.QueryMgr;

import com.sun.appserv.management.client.AppserverConnectionSource;

import com.sun.appserv.management.config.ClusterConfig;
import com.sun.appserv.management.config.ConfigConfig;
import com.sun.appserv.management.config.StandaloneServerConfig;
import com.sun.appserv.management.config.ResourceRefConfig;
import com.sun.appserv.management.config.MailResourceConfig;
import com.sun.appserv.management.config.DomainConfig;



import com.sun.enterprise.management.AMXTestBase;
import com.sun.enterprise.management.Capabilities;


/**
 */
public final class ReferencesTest extends AMXTestBase
{
    public ReferencesTest()
    {
    }
    
    
    private static final String MAIL_RESOURCE_NAME  = "test/mail1";
    
        MailResourceConfig
    createMailResourceConfig()
    {
        final MailResourceConfig    mr  =
            getDomainConfig().createMailResourceConfig(
                MAIL_RESOURCE_NAME,
                "localhost",
                "mailuser@domain.com",
                "mailfrom@domain.com",
                null );
        return mr;
    }
    
      MailResourceConfig
    ensureMailResourceConfig()
    {
        final Map<String,MailResourceConfig>  mails =
            getDomainConfig().getMailResourceConfigMap();
        
        MailResourceConfig mr   = mails.get( MAIL_RESOURCE_NAME );
        if ( mr == null )
        {
            mr  = createMailResourceConfig();
        }
        return mr;
    }
    
        void
    removeMailResourceConfig()
    {
        final Map<String,MailResourceConfig>  mails =
            getDomainConfig().getMailResourceConfigMap();
        
        MailResourceConfig mr   = mails.get( MAIL_RESOURCE_NAME );
        if ( mr != null )
        {
            getDomainConfig().removeMailResourceConfig( mr.getName() );
        }
    }
    
        public void
    testCreateAndRemoveResourceRefStandaloneServer()
        throws Exception
    {
	    if ( ! checkNotOffline( "testCreateRemove" ) )
	    {
	        return;
	    }
	    
        final Map<String,AppserverConnectionSource> nodeAgents  =
            getNodeAgents();
        
        if ( nodeAgents.keySet().size() == 0 )
        {
            warning(
                "testCreateAndRemoveResourceRefStandaloneServer: no Node Agents--SKIPPING TEST" );
            return;
        }
        final String    nodeAgentName   = nodeAgents.keySet().iterator().next();
        
        final ConfigSetup setup  = new ConfigSetup( getDomainRoot() );
        
        ensureMailResourceConfig();
        
        final String    serverName  = "testCreateAndRemoveResourceRefStandaloneServer";
        final String    configName  = serverName + "-config";
        
        final ConfigConfig  config  = setup.createConfig( configName );
        try
        {
            final int       basePort    = 34770;
            
            final StandaloneServerConfig server =
                setup.createServer( serverName, basePort, nodeAgentName, configName );
            try
            {
        		final ResourceRefConfig ref =
        		    server.createResourceRefConfig( MAIL_RESOURCE_NAME );
        		assert( ref != null );
        		
                server.removeResourceRefConfig( ref.getName() );
            }
            catch( Exception e )
            {
                setup.removeServer( serverName );
                throw e;
            }
            finally
            {
                removeMailResourceConfig();
            }
        }
        catch( Exception e )
        {
            setup.removeConfig( configName );
            throw e;
        }
    }
    
        public void
    testCreateRefToMissingTarget()
    {
	    if ( ! checkNotOffline( "testCreateRemove" ) )
	    {
	        return;
	    }
	    
	    final String MISSING_NAME   = "NonExistent";
	    
	    final DomainConfig domainConfig = getDomainRoot().getDomainConfig();
	    final StandaloneServerConfig serverConfig =
	        domainConfig.getStandaloneServerConfigMap().get( "server" );
	    
	    try
	    {
	        serverConfig.createResourceRefConfig( MISSING_NAME );
	        assert false;
	        
	        serverConfig.createDeployedItemRefConfig( MISSING_NAME );
	        assert false;
	    }
	    catch( Exception e )
	    {
	        // good
	    }
	    
    }
    
    /*
    public void testCreateAndRemoveResourceRefCluster()
	{
        Map clusterMap<String,ClusterConfig> =
            getDomainConfig().getClusterConfigMap();
        
        ClusterConfig cluster = clusterMap.get("testCluster");
        
		cluster.createResourceRefConfig("jdbc/PointBase");
        
        cluster.removeResourceRefConfig("jdbc/PointBase");
    }
    */
 
    /*


    
    public void testCreateAndRemoveDeployedItemRef()  {
        trace("\n..testCreateAndRemoveDeployedItemRef");
        
        StandaloneServerConfigMgr proxy =
        getDomainConfig().getStandaloneServerConfigMgr();
        
        ClusterConfigMgr c =
            getDomainConfig().getClusterConfigMgr();

        Map serverMap =
            getDomainConfig().getStandaloneServerConfigMap();
        
        Map clusterMap =
            getDomainConfig().getClusterConfigMap();
         
        trace("I got the names of the servers!!!!!" + serverMap);
        StandaloneServerConfig server =
        (StandaloneServerConfig)serverMap.get("testServer");
        
        trace("I got the names of the clusters!!!!!" + clusterMap);
        ClusterConfig cluster =
            (ClusterConfig)clusterMap.get("testCluster");
         
        DeployedItemRefConfigMgr deploy =
        server.getDeployedItemRefConfigMgr();
        
        
        DeployedItemRefConfigMgr deploy2 =
            cluster.getDeployedItemRefConfigMgr();
         
        trace("I got the deploy item ref mgr proxy from server! " + deploy);
        
        trace("I got the deploy item ref mgr proxy from cluster! " + deploy2);
         
        trace("New deployedItemRef: " +
            deploy.create("jndiTree", new java.util.HashMap()));
         
        trace("New deployedItemRef: " +
            deploy2.create("jndiTree", new java.util.HashMap()));
   
        try {
            trace("Sleeping.....");
            Thread.sleep(2000);
        } catch (Exception e) {
            e.printStackTrace();
        }

        // remove("testDeployedItemRefServer");
        // c.remove("testDeployedItemRefCluster");
        
        deploy.remove("jndiTree");
        deploy2.remove("jndiTree");
    }
    
    
    public void testCreateAndRemoveServerRef()
             {
        trace("\n..testCreateAndRemoveServerRef");
     
        Map map =
            getDomainConfig().getClusterConfigMap();
        Set names = map.keySet();
        trace("I got the names of the clusters!!!!!" + map);
        ClusterConfig proxy =
            (ClusterConfig)map.get("testCluster");
     
        ServerRefConfigMgr serverRefMgr =
            getServerRefConfigMgr();
     
        trace("I got the server ref proxy! " + serverRefMgr);
     
        trace("New server reference: " +
            serverRefMgr.create("testServerRef"));
     
        try {
            trace("Sleeping.....");
            Thread.sleep(2000);
        } catch (Exception e) {
            e.printStackTrace();
        }
     
        trace("Removing the server reference!!");
        serverRefMgr.remove("testServerRef");
     
    }
   
    
    public void testCreateAndRemoveStandaloneServer()
             {
        trace("\n..testCreateAndRemoveServer");
     
        ConfigConfigMgr configMgr =
            getDomainConfig().getConfigConfigMgr();
     
        trace("I got the config proxy! " + configMgr);
        trace("New config: " +
            configMgr.create("testConfig", new java.util.HashMap()));
        StandaloneServerConfigMgr proxy =
            getDomainConfig().getStandaloneServerConfigMgr();
     
        trace("I got the standalone server proxy! " + proxy);
     
        assert(proxy != null) : "The StandaloneServerConfigMgr is NULL!!";
        
        trace("New standAloneServer: " +
            create("testStandaloneServerWithNewSig", "test-agent",
                "testConfig", null));
     
        try {
            trace("Sleeping.....");
            Thread.sleep(2000);
        } catch (Exception e) {
            e.printStackTrace();
        }
     
        trace("Removing the standalone server!!");
     
        remove("testStandaloneServerWithNewSig");
     
       // configMgr.remove("testConfig");
    }
    
    
    public void testCreateAndRemoveClusteredServer()
            throws IOException {
        trace("\n..testCreateAndRemoveClusteredServer");
     
        ClusteredServerConfigMgr proxy =
            getDomainConfig().getClusteredServerConfigMgr();
     
        trace("I got the clustered server proxy! " + proxy);
     
     
        trace("New cluster: " +
            create("testClusteredServerWithNewSig", null, null, ));
     
        try {
            trace("Sleeping.....");
            Thread.sleep(2000);
        } catch (Exception e) {
            e.printStackTrace();
        }
     
        trace("Removing the slustered server!!");
        remove("testClusteredServer");
     
    }
     */
    
    
}