For each application client ejb-link element, there must be only one
corresponding ejb that fullfils that dependancy in the scope of the
application.
Result result = getInitializedResult();
ComponentNameConstructor compName = getVerifierContext().getComponentNameConstructor();
int resolved = 0;
boolean oneFailed = false;
int na = 0;
boolean pathPrefix = false;
String jar_name = "";
/*
if (Verifier.getEarFile() == null) {
// this appclient is not part of an .ear file
result.addNaDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.notApplicable
(smh.getLocalString
(getClass().getName() + ".no_ear",
"This Application Client [ {0} ] is not part of a J2EE Archive.",
new Object[] {descriptor.getName()}));
return result;
}
*/
// String applicationName = null;
// The value of the ejb-link element must be the ejb-name of an enterprise
// bean in the same ejb-jar file.
if (!descriptor.getEjbReferenceDescriptors().isEmpty()) {
for (Iterator itr = descriptor.getEjbReferenceDescriptors().iterator();
itr.hasNext();) {
EjbReferenceDescriptor nextEjbReference = (EjbReferenceDescriptor) itr.next();
if (nextEjbReference.isLinked()) {
String ejb_link = nextEjbReference.getLinkName();
if (ejb_link.indexOf("#") != -1) {
jar_name = ejb_link.substring(0,ejb_link.indexOf("#"));
ejb_link = ejb_link.substring(ejb_link.indexOf("#") + 1);
pathPrefix = true;
}
// get the application descriptor and check all ejb-jars in the application
try {
// iterate through the ejb jars in this J2EE Application
Set ejbBundles = descriptor.getApplication().getEjbBundleDescriptors();
Iterator ejbBundlesIterator = ejbBundles.iterator();
EjbBundleDescriptor ejbBundle = null;
resolved = 0;
while (ejbBundlesIterator.hasNext()) {
ejbBundle = (EjbBundleDescriptor)ejbBundlesIterator.next();
String ejbBundleName = ejbBundle.getModuleDescriptor().getArchiveUri();
// Kumar: this code here seems like dead code to me, because tmpFile is
// not being used. and extractBundleToFile, does not modify ejbBundle
//((Application)application).getApplicationArchivist().
//extractBundleToFile(ejbBundle, tmpFile);
for (Iterator itr2 = ejbBundle.getEjbs().iterator(); itr2.hasNext();) {
EjbDescriptor ejbDescriptor = (EjbDescriptor) itr2.next();
if (ejbDescriptor.getName().equals(ejb_link)) {
if ((pathPrefix == true && jar_name.equals(ejbBundleName)) || pathPrefix == false) {
resolved++;
logger.log(Level.FINE, getClass().getName() + ".debug",
new Object[] {ejb_link, ejbDescriptor.getName(), descriptor.getName()});
}
}
if (resolved > 0) {
break;
}
}
if (resolved > 0) {
break;
}
}
}catch (Exception e) {
logger.log(Level.FINE, "com.sun.enterprise.tools.verifier.testsprint",
new Object[] {"[" + getClass() + "] Error: " + e.getMessage()});
if (!oneFailed) {
oneFailed = true;
}
}
// before you go onto the next ejb-link, tell me whether you
// resolved the last ejb-link okay
if (resolved == 0) {
if (!oneFailed) {
oneFailed = true;
}
result.addErrorDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.addErrorDetails(smh.getLocalString
(getClass().getName() + ".failed",
"Error: Failed to resolve EJB reference [ {0} ] to a unique EJB in this application.",
new Object[] {nextEjbReference.getLinkName()}));
} else if (resolved == 1 || (pathPrefix == true && resolved > 0)) {
// clear the resolved counter for the next ejb-link
resolved=0;
result.addGoodDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.addGoodDetails
(smh.getLocalString
(getClass().getName() + ".passed",
"EJB reference [ {0} ] is successfully resolved.",
new Object[] {nextEjbReference.getLinkName()}));
} else {
// Cannot get the link name of an ejb reference referring
// to an external bean, The value of the ejb-link element
// must be the ejb-name of an enterprise bean in the same
// ejb-ear file.
result.addNaDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.addNaDetails
(smh.getLocalString
(getClass().getName() + ".notApplicable1",
"Warning: Cannot verify the existence of an ejb reference [ {0} ] to external bean within different .ear file.",
new Object[] {nextEjbReference.getName()}));
}
}else {
// Cannot get the link name of an ejb reference referring
// to an external bean, The value of the ejb-link element
// must be the ejb-name of an enterprise bean in the same
// ejb-ear file.
result.addNaDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.addNaDetails
(smh.getLocalString
(getClass().getName() + ".notApplicable1",
"Not Applicable: Cannot verify the existence of an ejb reference [ {0} ] to external bean within different .ear file.",
new Object[] {nextEjbReference.getName()}));
na++;
}
}
if (oneFailed) {
result.setStatus(result.FAILED);
} else if (na == descriptor.getEjbReferenceDescriptors().size()) {
result.setStatus(result.NOT_APPLICABLE);
} else {
result.setStatus(result.PASSED);
}
// File tmpFile = new File(System.getProperty("java.io.tmpdir"));
// tmpFile = new File(tmpFile, Verifier.TMPFILENAME + ".tmp");
// tmpFile.delete();
return result;
} else {
result.addNaDetails(smh.getLocalString
("tests.componentNameConstructor",
"For [ {0} ]",
new Object[] {compName.toString()}));
result.notApplicable(smh.getLocalString
(getClass().getName() + ".notApplicable",
"There are no ejb references to other beans within this application client [ {0} ]",
new Object[] {descriptor.getName()}));
}
return result;