Package com.sun.jini.test.impl.joinmanager

Source Code of com.sun.jini.test.impl.joinmanager.TerminateSemantics

/*
* 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 com.sun.jini.test.impl.joinmanager;

import java.util.logging.Level;

import com.sun.jini.qa.harness.TestException;
import com.sun.jini.test.spec.joinmanager.AbstractBaseTest;

import net.jini.discovery.DiscoveryManagement;
import net.jini.lease.LeaseRenewalManager;
import net.jini.lookup.JoinManager;

import net.jini.core.entry.Entry;
import net.jini.core.lookup.ServiceRegistrar;

/**
* With respect to the current implementation of the <code>JoinManager</code>
* utility, this class verifies that if any of the public methods of that
* utility are invoked after the join manager has been terminated, an
* <code>IllegalStateException</code> results.
*
* The environment in which this class expects to operate is as follows:
* <p><ul>
*   <li> no lookup services
*   <li> one instance of JoinManager
*   <li> after invoking the terminate method on the join manager, each
*        version of each public is invoked
* </ul><p>
*
* If the <code>JoinManager</code> utility functions as intended, then upon
* invoking any of the public methods on and inatacne of the utility after
* that instance has been terminated, an <code>IllegalStateException</code>
* will occur.
*
*/
public class TerminateSemantics extends AbstractBaseTest {

    /** Performs actions necessary to prepare for execution of the
     *  current test as follows:
     * <p><ul>
     *     <li> creates an instance of JoinManager inputting an instance of
     *          a test service, a set of attributes (either null or non-null)
     *          with which to register the service, and both a null instance
     *          of a lookup discovery manager, and a null instance of a
     *          lease renewal manager
     *   </ul>
     */
    public void setup(com.sun.jini.qa.harness.QAConfig sysConfig) throws Exception {
        super.setup(sysConfig);
        logger.log(Level.FINE, "creating a service ID join manager ...");
        joinMgrSrvcID = new JoinManager(testService,serviceAttrs,serviceID,
                                        null,null,
          sysConfig.getConfiguration());
    }//end setup

    /** Executes the current test by doing the following:
     * <p>
     *  Terminates the join manager created in setup and verifies that
     *  an invocation of any of that join manager's public methods will
     *  result in an <code>IllegalStateException</code>.
     */
    public void run() throws Exception {
        logger.log(Level.FINE, ""+": run()");
        /* Terminate the join manager */
        logger.log(Level.FINE, "terminating the join manager ...");
        joinMgrSrvcID.terminate();
        String methodStr = "";
        String successStr = "IllegalStateException occurred as expected -- ";
        String errStr = "no IllegalStateException -- ";
        boolean failed = false;
        /* Invoke methods on terminated join manager -- getDiscoveryManager */
        methodStr = "getDiscoveryManager()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            DiscoveryManagement dm = joinMgrSrvcID.getDiscoveryManager();
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        /* getLeaseRenewalManager */
        methodStr = "getLeaseRenewalManager()";
        logger.log(Level.FINE, ""+": invoking "+methodStr+" ...");
        try {
            LeaseRenewalManager lrm = joinMgrSrvcID.getLeaseRenewalManager();
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        /* getJoinSet */
        methodStr = "getJoinSet()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            ServiceRegistrar[] regs = joinMgrSrvcID.getJoinSet();
            logger.log(Level.FINE, ""+errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, ""+successStr+methodStr);
        }
        /* getAttributes */
        methodStr = "getAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            Entry[] attrs = joinMgrSrvcID.getAttributes();
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        /* addAttributes */
        Entry[] newEntries = {new TestServiceIntAttr(99999)};
        methodStr = "first form of addAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            joinMgrSrvcID.addAttributes( newEntries );
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        methodStr = "second form of addAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            joinMgrSrvcID.addAttributes( newEntries, true );
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        /* setAttributes */
        methodStr = "setAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            joinMgrSrvcID.setAttributes( newEntries );
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        /* modifyAttributes */
        Entry[] tmpls = {new TestServiceIntAttr(88888)};
        methodStr = "first form of modifyAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            joinMgrSrvcID.modifyAttributes( tmpls,newEntries );
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }
        methodStr = "second form of modifyAttributes()";
        logger.log(Level.FINE, "invoking "+methodStr+" ...");
        try {
            joinMgrSrvcID.modifyAttributes( tmpls,newEntries,true );
            logger.log(Level.FINE, errStr+methodStr);
            failed = true;
        } catch(IllegalStateException e) {
            logger.log(Level.FINE, successStr+methodStr);
        }

        if(failed) {
      throw new TestException("no IllegalStateException "
            +"from least one method");
  }
    }//end run

}//end class TerminateSemantics

TOP

Related Classes of com.sun.jini.test.impl.joinmanager.TerminateSemantics

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.