Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.enterprise.tools.verifier.tests.webservices;
import com.sun.enterprise.deployment.*;
import com.sun.enterprise.tools.verifier.*;
import java.util.*;
import com.sun.enterprise.tools.verifier.tests.*;
/*
* @class.setup_props: ;
*/
/*
* @testName: check
* @assertion_ids: JSR109_WS_10; JSR109_WS_11; JSR109_WS_12; JSR109_WS_13;
* JSR109_WS_14; JSR109_WS_47;
* @test_Strategy:
* @class.testArgs: Additional arguments (if any) to be passed when execing the client
*
* The Service Implementation Bean must have a default public constructor.
*
* The Service Implementation Bean may implement the Service Endpoint Interface as defined by
* the JAX-RPC Servlet model. The bean must implement all the method signatures of the SEI.
* The business methods of the bean must be public and must not be static.
*
* If the Service Implementation Bean does not implement the SEI, the business methods
* must not be final, must not be static.The bean must implement all the method signatures
* of the SEI.
*
* The Service Implementation Bean class must be public, must not be final and must
* not be abstract.
*
* The Service Implementation Bean class must not define the finalize() method.
*
* All the exceptions defined in the throws clause of the matching method of the session bean
* class must be defined in the throws clause of the method of the web service endpoint
* interface.
*
*/
public class JAXRPCServiceImplBeanChk extends WSTest implements WSCheck {
/**
* @param descriptor the WebService deployment descriptor
* @return Result the results for this assertion
*/
public Result check (WebServiceEndpoint descriptor) {
Result result = getInitializedResult();
ComponentNameConstructor compName = getVerifierContext().getComponentNameConstructor();
boolean pass = true;
if (descriptor.implementedByWebComponent()) {
Class> bean = loadImplBeanClass(descriptor, result);
if (bean == null) {
result.addErrorDetails(smh.getLocalString ("tests.componentNameConstructor",
"For [ {0} ]", new Object[] {compName.toString()}));
result.failed(smh.getLocalString
("com.sun.enterprise.tools.verifier.tests.webservices.failed", "[{0}]",
new Object[] {"Could not Load the Service Implementation Bean class for the JAX-RPC Endpoint"}));
}
else {
// get hold of the SEI Class
String s = descriptor.getServiceEndpointInterface();
if ((s == null) || (s.length() == 0)){
// internal error, should never happen
result.addErrorDetails(smh.getLocalString
("com.sun.enterprise.tools.verifier.tests.webservices.Error",
"Error: Unexpected error occurred [ {0} ]",
new Object[] {"SEI Class Name is Null"}));
}
Class> sei = loadSEIClass(descriptor, result);
if (sei == null) {
result.addErrorDetails(smh.getLocalString ("tests.componentNameConstructor",
"For [ {0} ]", new Object[] {compName.toString()}));
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()}));
}
else {
boolean implementsSEI = sei.isAssignableFrom(bean);
EndPointImplBeanClassChecker checker =
new EndPointImplBeanClassChecker(sei,bean,result,false);
if (implementsSEI) {
// result.passed
result.addGoodDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.passed(smh.getLocalString (
"com.sun.enterprise.tools.verifier.tests.webservices.passed", "[{0}]",
new Object[] {"The Service Impl Bean implements SEI"}));
}
else {
// business methods of the bean should be public, not final and not static
// This check will happen as part of this call
Vector notImpl = checker.getSEIMethodsNotImplemented();
if (notImpl.size() > 0) {
// result.fail, Set the not implemented methods into the result info??
result.addErrorDetails(smh.getLocalString ("tests.componentNameConstructor",
"For [ {0} ]", new Object[] {compName.toString()}));
result.failed(smh.getLocalString
("com.sun.enterprise.tools.verifier.tests.webservices.failed", "[{0}]",
new Object[] {"The Service Implementation Bean Does not Implement ALL SEI Methods"}));
}
else {
// result.pass :All SEI methods implemented
result.addGoodDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.passed(smh.getLocalString (
"com.sun.enterprise.tools.verifier.tests.webservices.passed", "[{0}]",
new Object[] {"The Service Impl Bean implements all Methods of the SEI"}));
}
}
// class should be public, not final and not abstract
// should not define finalize()
if (checker.check(compName)) {
// result.passed stuff done inside the check() method nothing todo here
result.setStatus(Result.PASSED);
}
else {
// result.fail : stuff done inside the check() method nothing todo here
result.setStatus(Result.FAILED);
}
}
}
}
else {
// result.notapplicable
result.addNaDetails(smh.getLocalString
("tests.componentNameConstructor", "For [ {0} ]",
new Object[] {compName.toString()}));
result.notApplicable(smh.getLocalString
("com.sun.enterprise.tools.verifier.tests.webservices.notapp",
"[{0}]", new Object[] {"Not Applicable since this is an EJB Service Endpoint"}));
}
return result;
}
}