Result result = getInitializedResult();
ComponentNameConstructor compName = new ComponentNameConstructor(descriptor);
boolean oneFailed = false;
boolean notApp = false;
//<addition author="irfan@sun.com" [bug/rfe]-id="4715917" >
/*Set keys = descriptor.getEjbBundleDescriptor().getIasCmpMappingsKeys();
SunCmpMappings iasCmpMappings=null;
String forPmConfig=null;*/
SunCmpMappings iasCmpMappings = descriptor.getEjbBundleDescriptor().getIasCmpMappings();
String forPmConfig = com.sun.enterprise.deployment.EjbBundleXmlReader.IAS_CMP_MAPPING_JAR_ENTRY;
//</addition>
SunCmpMapping[] allIasCmpMapping=null;
SunCmpMapping iasCmpMapping=null;
/////test vars
EntityMapping[] entityMapping=null;
String ejbName=null;
String tableName=null;
//<addition author="irfan@sun.com" [bug/rfe]-id="4715917" >
if(iasCmpMappings!=null)
{
/*if(keys!=null && keys.size()>0)
{
Iterator it = keys.iterator();
while(it.hasNext()) {
forPmConfig=(String) it.next();
iasCmpMappings= descriptor.getEjbBundleDescriptor().getIasCmpMappings(forPmConfig);*/
//</addition>
allIasCmpMapping=iasCmpMappings.getSunCmpMapping();
for(int rep=0;rep<allIasCmpMapping.length;rep++){
iasCmpMapping=allIasCmpMapping[rep];
//test logic
entityMapping=iasCmpMapping.getEntityMapping();
if(entityMapping == null || entityMapping.length==0){//this should never happen
oneFailed = true;
result.failed(smh.getLocalString(getClass().getName()+".failed",
"FAILED [AS-CMP-MAPPING] : entity-mapping is NOT a valid entry, in the mapping file [ {0}], "+
"of the ejb archive [ {1} ]. "+
"Either null or empty.",
new Object[]{forPmConfig,descriptor.getName()}));
continue;
}
for(int rep1=0;rep1<entityMapping.length;rep1++){
ejbName=entityMapping[rep1].getEjbName();
tableName=entityMapping[rep1].getTableName();
if(validateEjbName(ejbName,descriptor)){
result.passed(smh.getLocalString(getClass().getName()+".passed",
"PASSED [AS-CMP-MAPPING] : entity-mapping->ejb-name [{0} ] is a valid entry, in the mapping file [ {1}], "+
"of the ejb archive [ {2} ]. ",
new Object[]{ejbName,forPmConfig,descriptor.getName()}));
}else{
oneFailed = true;
result.failed(smh.getLocalString(getClass().getName()+".failed1",
"FAILED [AS-CMP-MAPPING] : entity-mapping->ejb-name [{0} ] is NOT a valid entry, in the mapping file [ {1}], "+
"of the ejb archive [ {2} ]. "+
"Either null/empty or the ejb-name is not present in corresponding ejb-jar.xml.",
new Object[]{ejbName,forPmConfig,descriptor.getName()}));
}
if(validateTableName(tableName)){
result.passed(smh.getLocalString(getClass().getName()+".passed1",
"PASSED [AS-CMP-MAPPING] : entity-mapping->table-name [{0} ] is a valid entry, in the mapping file [ {1}], "+
"of the ejb archive [ {2} ]. ",
new Object[]{tableName,forPmConfig,descriptor.getName()}));
}else{
oneFailed = true;
result.failed(smh.getLocalString(getClass().getName()+".failed2",
"FAILED [AS-CMP-MAPPING] : entity-mapping->table-name [{0} ] is NOT a valid entry, in the mapping file [ {1}], "+
"of the ejb archive [ {2} ]. "+
"Either null or empty.",
new Object[]{tableName,forPmConfig,descriptor.getName()}));
}
}
}
//} 4715917 irfan
}
else
{
notApp = true;
result.notApplicable(smh.getLocalString
(getClass().getName() + ".notApplicable",
"NOT APPLICABLE [AS-CMP-MAPPING] : There is no ias-cmp-mappings file present, within the ejb archive [ {0} ].",
new Object[] {descriptor.getName()}));
}
if (oneFailed) {
result.setStatus(Result.FAILED);
} else if(notApp) {
result.setStatus(Result.NOT_APPLICABLE);
}else {
result.setStatus(Result.PASSED);
}
return result;