use of org.apache.syncope.common.lib.to.ResourceTO in project syncope by apache.
the class ResourceITCase method issueSYNCOPE888.
@Test
public void issueSYNCOPE888() {
String resourceKey = RESOURCE_NAME_CREATE_WRONG;
ResourceTO resourceTO = new ResourceTO();
resourceTO.setKey(resourceKey);
resourceTO.setConnector("5ffbb4ac-a8c3-4b44-b699-11b398a1ba08");
ProvisionTO provisionTO = new ProvisionTO();
provisionTO.setAnyType(AnyTypeKind.USER.name());
provisionTO.setObjectClass(ObjectClass.ACCOUNT_NAME);
resourceTO.getProvisions().add(provisionTO);
MappingTO mapping = new MappingTO();
provisionTO.setMapping(mapping);
ItemTO item = new ItemTO();
item.setIntAttrName("key");
item.setExtAttrName("userId");
item.setConnObjectKey(true);
item.setPurpose(MappingPurpose.BOTH);
mapping.setConnObjectKeyItem(item);
// Add mapping for a not existing internal attribute
item = new ItemTO();
item.setIntAttrName("locatio");
item.setExtAttrName("location");
item.setPurpose(MappingPurpose.BOTH);
mapping.add(item);
try {
createResource(resourceTO);
fail("Create should not have worked");
} catch (SyncopeClientException e) {
assertEquals(ClientExceptionType.InvalidMapping, e.getType());
assertEquals(1, e.getElements().size());
assertEquals("'locatio' not existing", e.getElements().iterator().next());
}
}
use of org.apache.syncope.common.lib.to.ResourceTO in project syncope by apache.
the class ResourceITCase method update.
@Test
public void update() {
String resourceKey = RESOURCE_NAME_UPDATE;
ResourceTO resourceTO = new ResourceTO();
resourceTO.setKey(resourceKey);
resourceTO.setConnector("5aa5b8be-7521-481a-9651-c557aea078c1");
ProvisionTO provisionTO = new ProvisionTO();
provisionTO.setAnyType(AnyTypeKind.USER.name());
provisionTO.setObjectClass(ObjectClass.ACCOUNT_NAME);
resourceTO.getProvisions().add(provisionTO);
MappingTO mapping = new MappingTO();
provisionTO.setMapping(mapping);
// Update with an existing and already assigned mapping
ItemTO item = new ItemTO();
item.setKey("cc973ed6-d031-4790-adab-fc059ac0c818");
item.setExtAttrName("test3");
item.setIntAttrName("fullname");
item.setPurpose(MappingPurpose.BOTH);
mapping.add(item);
// Update defining new mappings
for (int i = 4; i < 6; i++) {
item = new ItemTO();
item.setExtAttrName("test" + i);
item.setIntAttrName("fullname");
item.setPurpose(MappingPurpose.BOTH);
mapping.add(item);
}
item = new ItemTO();
item.setExtAttrName("username");
item.setIntAttrName("key");
item.setConnObjectKey(true);
item.setPurpose(MappingPurpose.BOTH);
mapping.setConnObjectKeyItem(item);
resourceService.update(resourceTO);
ResourceTO actual = resourceService.read(resourceTO.getKey());
assertNotNull(actual);
// check for existence
Collection<ItemTO> mapItems = actual.getProvision(AnyTypeKind.USER.name()).get().getMapping().getItems();
assertNotNull(mapItems);
assertEquals(4, mapItems.size());
}
use of org.apache.syncope.common.lib.to.ResourceTO in project syncope by apache.
the class ResourceITCase method createWithPasswordPolicy.
@Test
public void createWithPasswordPolicy() {
String resourceKey = "res-with-password-policy";
ResourceTO resourceTO = new ResourceTO();
resourceTO.setKey(resourceKey);
resourceTO.setConnector("5ffbb4ac-a8c3-4b44-b699-11b398a1ba08");
resourceTO.setPasswordPolicy("986d1236-3ac5-4a19-810c-5ab21d79cba1");
ProvisionTO provisionTO = new ProvisionTO();
provisionTO.setAnyType(AnyTypeKind.USER.name());
provisionTO.setObjectClass(ObjectClass.ACCOUNT_NAME);
resourceTO.getProvisions().add(provisionTO);
MappingTO mapping = new MappingTO();
provisionTO.setMapping(mapping);
ItemTO item = new ItemTO();
item.setExtAttrName("userId");
item.setIntAttrName("userId");
item.setConnObjectKey(true);
item.setPurpose(MappingPurpose.BOTH);
mapping.setConnObjectKeyItem(item);
Response response = resourceService.create(resourceTO);
ResourceTO actual = getObject(response.getLocation(), ResourceService.class, ResourceTO.class);
assertNotNull(actual);
// check the existence
actual = resourceService.read(resourceKey);
assertNotNull(actual);
assertNotNull(actual.getPasswordPolicy());
assertEquals("986d1236-3ac5-4a19-810c-5ab21d79cba1", actual.getPasswordPolicy());
}
use of org.apache.syncope.common.lib.to.ResourceTO in project syncope by apache.
the class ResourceITCase method issueSYNCOPE360.
@Test
public void issueSYNCOPE360() {
final String name = "SYNCOPE360-" + getUUIDString();
resourceService.create(buildResourceTO(name));
ResourceTO resource = resourceService.read(name);
assertNotNull(resource);
assertNotNull(resource.getProvision(AnyTypeKind.USER.name()).get().getMapping());
resource.getProvision(AnyTypeKind.USER.name()).get().setMapping(null);
resourceService.update(resource);
resource = resourceService.read(name);
assertNotNull(resource);
assertNull(resource.getProvision(AnyTypeKind.USER.name()).get().getMapping());
}
use of org.apache.syncope.common.lib.to.ResourceTO in project syncope by apache.
the class ResourceITCase method createWithoutExtAttr.
@Test
public void createWithoutExtAttr() {
assertThrows(SyncopeClientException.class, () -> {
String resourceKey = RESOURCE_NAME_CREATE_WRONG;
ResourceTO resourceTO = new ResourceTO();
resourceTO.setKey(resourceKey);
resourceTO.setConnector("5ffbb4ac-a8c3-4b44-b699-11b398a1ba08");
ProvisionTO provisionTO = new ProvisionTO();
provisionTO.setAnyType(AnyTypeKind.USER.name());
provisionTO.setObjectClass(ObjectClass.ACCOUNT_NAME);
resourceTO.getProvisions().add(provisionTO);
MappingTO mapping = new MappingTO();
provisionTO.setMapping(mapping);
ItemTO item = new ItemTO();
item.setIntAttrName("key");
item.setExtAttrName("userId");
item.setConnObjectKey(true);
mapping.setConnObjectKeyItem(item);
item = new ItemTO();
item.setIntAttrName("usernane");
// missing extAttrName ...
mapping.add(item);
createResource(resourceTO);
});
}
Aggregations