[OLINGO-1191] Code Improvements

This commit is contained in:
ramya vasanth 2017-11-08 10:36:03 +05:30
parent dd992163b7
commit a3a84c9e86
3 changed files with 19 additions and 28 deletions

View File

@ -125,12 +125,14 @@ public class CsdlTypeValidator {
baseTypeFQName = validateCsdlEntityTypeWithAlias(baseTypeFQName); baseTypeFQName = validateCsdlEntityTypeWithAlias(baseTypeFQName);
} }
baseEntityType = csdlEntityTypesMap.get(baseTypeFQName); baseEntityType = csdlEntityTypesMap.get(baseTypeFQName);
if (baseEntityType.getKey() != null) { if (baseEntityType != null) {
break; if (baseEntityType.getKey() != null) {
} else if (baseEntityType != null && baseEntityType.getBaseType() != null) { break;
baseTypeFQName = baseEntityType.getBaseTypeFQN(); } else if (baseEntityType.getBaseType() != null) {
} else if (baseEntityType.getBaseType() == null) { baseTypeFQName = baseEntityType.getBaseTypeFQN();
break; } else if (baseEntityType.getBaseType() == null) {
break;
}
} }
} }
return baseEntityType; return baseEntityType;
@ -149,16 +151,18 @@ public class CsdlTypeValidator {
baseTypeFQName = validateCsdlEntityTypeWithAlias(baseTypeFQName); baseTypeFQName = validateCsdlEntityTypeWithAlias(baseTypeFQName);
} }
baseEntityType = csdlEntityTypesMap.get(baseTypeFQName); baseEntityType = csdlEntityTypesMap.get(baseTypeFQName);
if (baseEntityType.getNavigationProperty(navBindingProperty) != null) { if (baseEntityType != null) {
break; if (baseEntityType.getNavigationProperty(navBindingProperty) != null) {
} else if (baseEntityType != null && baseEntityType.getBaseType() != null) { break;
baseTypeFQName = baseEntityType.getBaseTypeFQN(); } else if (baseEntityType.getBaseType() != null) {
} else if (baseEntityType.getBaseType() == null) { baseTypeFQName = baseEntityType.getBaseTypeFQN();
break; } else if (baseEntityType.getBaseType() == null) {
break;
}
} }
} }
if (baseEntityType == null) { if (baseEntityType == null) {
throw new RuntimeException("Entity TYpe is null with fully qualified name:" + baseTypeFQName); throw new RuntimeException("Entity Type is null with fully qualified name:" + baseTypeFQName);
} }
return baseEntityType.getNavigationProperty(navBindingProperty); return baseEntityType.getNavigationProperty(navBindingProperty);
} }

View File

@ -404,17 +404,4 @@ public class EntityTest extends AbstractTest {
assertTrue(property.isPrimitive()); assertTrue(property.isPrimitive());
assertEquals(property.getValueType(), ValueType.PRIMITIVE); assertEquals(property.getValueType(), ValueType.PRIMITIVE);
} }
@Test
public void testFindTypeInEdmEnabledClient() throws Exception {
final Edm edm = client.getReader().readMetadata(getClass().getResourceAsStream("metadata_TripInService.xml"));
assertNotNull(edm);
final InputStream input = getClass().getResourceAsStream("tripinServEntity.json");
EdmEnabledODataClient edmClient = ODataClientFactory.getEdmEnabledClient(SERVICE_URI, ContentType.APPLICATION_JSON);
ClientEntity entity = edmClient.getBinder().getODataEntity(
edmClient.getDeserializer(ContentType.APPLICATION_JSON).toEntity(input));
assertNotNull(entity);
assertEquals(entity.getTypeName().getFullQualifiedNameAsString(),
"Microsoft.OData.SampleService.Models.TripPin.Person");
}
} }

View File

@ -350,8 +350,8 @@ public class ODataJsonSerializer extends AbstractODataSerializer {
* @return ascii representation of the entity id * @return ascii representation of the entity id
*/ */
private String getEntityId(Entity entity, EdmEntityType entityType, String name) throws SerializerException { private String getEntityId(Entity entity, EdmEntityType entityType, String name) throws SerializerException {
if(entity.getId() == null) { if(entity != null && entity.getId() == null) {
if(entity == null || entityType == null || entityType.getKeyPredicateNames() == null if(entityType == null || entityType.getKeyPredicateNames() == null
|| name == null) { || name == null) {
throw new SerializerException("Entity id is null.", SerializerException.MessageKeys.MISSING_ID); throw new SerializerException("Entity id is null.", SerializerException.MessageKeys.MISSING_ID);
}else{ }else{