All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.enterprise.tools.verifier.tests.webservices.WSTest Maven / Gradle / Ivy

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 1997-2011 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 com.sun.enterprise.tools.verifier.tests.webservices;


import com.sun.enterprise.tools.verifier.*;
import com.sun.enterprise.deployment.*;
import org.glassfish.deployment.common.Descriptor;
import org.glassfish.deployment.common.ModuleDescriptor;

import java.lang.ClassLoader;
import com.sun.enterprise.tools.verifier.tests.*;
import com.sun.enterprise.util.io.FileUtils;

import java.lang.reflect.*;

import java.io.File;

/**
 * Superclass for all EJB tests, contains common services.
 *
 * @version 
 */
/* 
 *   @class.setup_props: ; 
 */ 

/*  
 *   @testName: check  
 *   @assertion_ids:  ; 
 *   @test_Strategy: 
 *   @class.testArgs: Additional arguments (if any) to be passed when execing the client  
 */

public abstract class WSTest extends VerifierTest implements VerifierCheck, WSCheck {
        
    /**
     * 

* run an individual test against the deployment descriptor for the * archive the verifier is performing compliance tests against. *

* * @paramm descriptor deployment descriptor for the archive * @return result object containing the result of the individual test * performed */ public Result check(Descriptor descriptor) { return check((WebServiceEndpoint) descriptor); } // tests which require the WebService descriptor can obtain it from the WebServiceEndpoint // similarly tests which require WebServiceDescriptor can query one more level up to get the // descriptor. /** * @param descriptor deployment descriptor for the archive file * @return result object containing the result of the individual test performed */ public abstract Result check(WebServiceEndpoint descriptor); /** *

* load the declared SEI class from the archive *

* * @param descriptor the deployment descriptors for the WebService * @param result result to use if the load fails * @return the class object for the Service Endpoint Interface */ protected Class loadSEIClass(WebServiceEndpoint descriptor, Result result) { ComponentNameConstructor compName = getVerifierContext().getComponentNameConstructor(); try { VerifierTestContext context = getVerifierContext(); ClassLoader jcl = context.getClassLoader(); Class cl = Class.forName(descriptor.getServiceEndpointInterface(), false, getVerifierContext().getClassLoader()); result.passed(smh.getLocalString ( "com.sun.enterprise.tools.verifier.tests.webservices.clpassed", "The [{0}] Class [{1}] exists and was loaded successfully.", new Object[] {"SEI",descriptor.getServiceEndpointInterface()})); return cl; } catch (ClassNotFoundException e) { Verifier.debug(e); result.failed(smh.getLocalString ("com.sun.enterprise.tools.verifier.tests.webservices.WSTest.SEIClassExists", "Error: Service Endpoint Interface class [ {0} ] not found.", new Object[] {descriptor.getServiceEndpointInterface()})); return null; } } /** *

* load the declared Service Impl Bean class from the archive *

* * @param descriptor the deployment descriptors for the WebService * @param result result to use if the load fails * @return the class object for the Service Endpoint Interface */ protected Class loadImplBeanClass(WebServiceEndpoint descriptor, Result result) { // here we could be an EJB Endpoint or a Servlet Endpoint take care of that ComponentNameConstructor compName = getVerifierContext().getComponentNameConstructor(); String beanClassName = null; if (descriptor.implementedByEjbComponent()) { beanClassName = descriptor.getEjbComponentImpl().getEjbClassName(); } else if (descriptor.implementedByWebComponent()) { WebComponentDescriptor wcd = descriptor.getWebComponentImpl(); if(wcd!=null) beanClassName = wcd.getWebComponentImplementation(); } else { //result.fail, neither implemented by web nor EJB result.addErrorDetails(smh.getLocalString ("com.sun.enterprise.tools.verifier.tests.webservices.Error", "Error: Unexpected error occurred [ {0} ]", new Object[] {"The WebService is neither implemented by an EJB nor a Servlet"})); } if (beanClassName != null) { try { VerifierTestContext context = getVerifierContext(); ClassLoader jcl = context.getClassLoader(); return Class.forName(beanClassName, false, getVerifierContext().getClassLoader()); } catch (ClassNotFoundException e) { Verifier.debug(e); result.failed(smh.getLocalString ("com.sun.enterprise.tools.verifier.tests.webservices.WSTest.BeanClassExists", "Error: Service Endpoint Implementation Bean class [ {0} ] not found.", new Object[] {beanClassName})); return null; } } //result.fail , beanclass name is NULL result.addErrorDetails(smh.getLocalString ("com.sun.enterprise.tools.verifier.tests.webservices.Error", "Error: Unexpected error occurred [ {0} ]", new Object[] {"The Servlet Impl Bean class name could not be resolved"})); return null; } public boolean isSEIMethod (MethodDescriptor mdesc, EjbDescriptor desc, Class sei, ClassLoader cl) { Method[] seiMeths = sei.getMethods(); Method methToBeTested = null; try { methToBeTested = mdesc.getMethod(desc); } catch(Exception e) { // internal error cannot get Method for MethodDescriptor /* result.addErrorDetails(smh.getLocalString ("com.sun.enterprise.tools.verifier.tests.webservices.Error", "Error: Unexpected error occurred [ {0} ]", new Object[] {e.getMessage()})); */ return false; } for (int i=0; i < seiMeths.length; i++) { if (WSTest.matchesSignatureAndReturn(seiMeths[i], methToBeTested)) return true; } return false; } public static boolean matchesSignatureAndReturn (Method meth1, Method meth2) { if (!(meth1.getName()).equals(meth2.getName())) return false; /* int mod1 = meth1.getModifiers(); int mod2 = meth2.getModifiers(); if (mod1 != mod2) return false; */ Class ret1 = meth1.getReturnType(); Class ret2 = meth2.getReturnType(); if (ret1 != ret2) return false; Class[] param1 = meth1.getParameterTypes(); Class[] param2 = meth2.getParameterTypes(); if(param1.length != param2.length) return false; for(int i = 0; i < param1.length; i++) if(param1[i] != param2[i]) return false; // for exceptions, every exception in meth2 should be defined // in meth1 Class[] excep1 = meth1.getExceptionTypes(); Class[] excep2 = meth2.getExceptionTypes(); for(int i = 0; i < excep2.length; i++) { if(!isMatching(excep2[i], excep1)) return false; } return true; } private static boolean isMatching(Class cl, Class[] classes) { for (int i= 0; i < classes.length; i++) { /* if (classes[i].isAssignableFrom(cl)) return true; if (cl.isAssignableFrom(classes[i])) return true; */ if (classes[i].equals(cl)) return true; } return false; } protected String getAbstractArchiveUri(WebServiceEndpoint desc) { String archBase = getVerifierContext().getAbstractArchive(). getURI().toString(); final ModuleDescriptor moduleDescriptor = desc.getBundleDescriptor(). getModuleDescriptor(); if (moduleDescriptor.isStandalone()) { return archBase; // it must be a stand-alone module; no such physical dir exists } else { return archBase + "/" + FileUtils.makeFriendlyFilename(moduleDescriptor.getArchiveUri()); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy