|
|
@@ -36,6 +36,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
|
|
|
|
import org.alfresco.service.cmr.repository.NodeService;
|
|
|
|
import org.alfresco.service.cmr.repository.NodeService;
|
|
|
|
import org.alfresco.service.cmr.repository.StoreRef;
|
|
|
|
import org.alfresco.service.cmr.repository.StoreRef;
|
|
|
|
import org.alfresco.service.cmr.repository.datatype.DefaultTypeConverter;
|
|
|
|
import org.alfresco.service.cmr.repository.datatype.DefaultTypeConverter;
|
|
|
|
|
|
|
|
import org.alfresco.service.cmr.security.AuthorityService;
|
|
|
|
import org.alfresco.service.cmr.security.NoSuchPersonException;
|
|
|
|
import org.alfresco.service.cmr.security.NoSuchPersonException;
|
|
|
|
import org.alfresco.service.cmr.security.PermissionService;
|
|
|
|
import org.alfresco.service.cmr.security.PermissionService;
|
|
|
|
import org.alfresco.service.cmr.security.PersonService;
|
|
|
|
import org.alfresco.service.cmr.security.PersonService;
|
|
|
@@ -48,7 +49,7 @@ import org.alfresco.util.GUID;
|
|
|
|
public class PersonTest extends BaseSpringTest
|
|
|
|
public class PersonTest extends BaseSpringTest
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private TransactionService transactionService;
|
|
|
|
private TransactionService transactionService;
|
|
|
|
|
|
|
|
|
|
|
|
private PersonService personService;
|
|
|
|
private PersonService personService;
|
|
|
|
|
|
|
|
|
|
|
|
private NodeService nodeService;
|
|
|
|
private NodeService nodeService;
|
|
|
@@ -57,6 +58,8 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
|
|
|
|
|
|
|
|
private PermissionService permissionService;
|
|
|
|
private PermissionService permissionService;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private AuthorityService authorityService;
|
|
|
|
|
|
|
|
|
|
|
|
public PersonTest()
|
|
|
|
public PersonTest()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
super();
|
|
|
|
super();
|
|
|
@@ -69,13 +72,18 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
personService = (PersonService) applicationContext.getBean("personService");
|
|
|
|
personService = (PersonService) applicationContext.getBean("personService");
|
|
|
|
nodeService = (NodeService) applicationContext.getBean("nodeService");
|
|
|
|
nodeService = (NodeService) applicationContext.getBean("nodeService");
|
|
|
|
permissionService = (PermissionService) applicationContext.getBean("permissionService");
|
|
|
|
permissionService = (PermissionService) applicationContext.getBean("permissionService");
|
|
|
|
|
|
|
|
authorityService = (AuthorityService) applicationContext.getBean("authorityService");
|
|
|
|
|
|
|
|
|
|
|
|
StoreRef storeRef = nodeService.createStore(StoreRef.PROTOCOL_WORKSPACE, "Test_" + System.currentTimeMillis());
|
|
|
|
StoreRef storeRef = nodeService.createStore(StoreRef.PROTOCOL_WORKSPACE, "Test_" + System.currentTimeMillis());
|
|
|
|
rootNodeRef = nodeService.getRootNode(storeRef);
|
|
|
|
rootNodeRef = nodeService.getRootNode(storeRef);
|
|
|
|
|
|
|
|
|
|
|
|
for (NodeRef nodeRef : personService.getAllPeople())
|
|
|
|
for (NodeRef nodeRef : personService.getAllPeople())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nodeService.deleteNode(nodeRef);
|
|
|
|
String uid = DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_USERNAME));
|
|
|
|
|
|
|
|
if (!uid.equals("admin"))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
nodeService.deleteNode(nodeRef);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
personService.setCreateMissingPeople(true);
|
|
|
|
personService.setCreateMissingPeople(true);
|
|
|
@@ -90,8 +98,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
|
|
|
|
|
|
|
|
personService
|
|
|
|
personService.createPerson(createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
.createPerson(createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
long create = 0;
|
|
|
|
long create = 0;
|
|
|
|
|
|
|
|
|
|
|
@@ -142,7 +149,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
endTransaction();
|
|
|
|
endTransaction();
|
|
|
|
startNewTransaction();
|
|
|
|
startNewTransaction();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void testCreateAndThenDelete()
|
|
|
|
public void testCreateAndThenDelete()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
@@ -174,7 +181,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void testCreateMissingPeople1()
|
|
|
|
public void testCreateMissingPeople1()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
@@ -198,7 +205,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
public void testCreateMissingPeople2()
|
|
|
|
public void testCreateMissingPeople2()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
System.out.print(personService.getAllPeople());
|
|
|
|
System.out.print(personService.getAllPeople());
|
|
|
|
|
|
|
|
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
assertFalse(personService.createMissingPeople());
|
|
|
|
assertFalse(personService.createMissingPeople());
|
|
|
|
|
|
|
|
|
|
|
@@ -211,10 +218,10 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
|
|
|
|
|
|
|
|
nodeRef = personService.getPerson("andy");
|
|
|
|
nodeRef = personService.getPerson("andy");
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
|
|
|
|
|
|
|
|
nodeRef = personService.getPerson("Andy");
|
|
|
|
nodeRef = personService.getPerson("Andy");
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
|
|
|
|
|
|
|
|
assertEquals(nodeRef, personService.getPerson("Andy"));
|
|
|
|
assertEquals(nodeRef, personService.getPerson("Andy"));
|
|
|
|
nodeRef = personService.getPerson("Andy");
|
|
|
|
nodeRef = personService.getPerson("Andy");
|
|
|
|
assertNotNull(nodeRef);
|
|
|
|
assertNotNull(nodeRef);
|
|
|
@@ -230,8 +237,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh",
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
"alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
fail("Getting Derek should fail");
|
|
|
|
fail("Getting Derek should fail");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (PersonException pe)
|
|
|
|
catch (PersonException pe)
|
|
|
@@ -253,13 +259,12 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
testProperties(nodeRef, "andy", "andy", "", "", "");
|
|
|
|
|
|
|
|
|
|
|
|
personService.setCreateMissingPeople(true);
|
|
|
|
personService.setCreateMissingPeople(true);
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh",
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
"alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("andy"), "andy", "andy", "", "", "");
|
|
|
|
testProperties(personService.getPerson("andy"), "andy", "andy", "", "", "");
|
|
|
|
|
|
|
|
|
|
|
|
assertEquals(2, personService.getAllPeople().size());
|
|
|
|
assertEquals(3, personService.getAllPeople().size());
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("andy")));
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("andy")));
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("derek")));
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("derek")));
|
|
|
|
|
|
|
|
|
|
|
@@ -293,21 +298,18 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
public void testPersonCRUD2()
|
|
|
|
public void testPersonCRUD2()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService
|
|
|
|
personService.createPerson(createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
.createPerson(createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
|
|
|
|
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek_", "Hulley_", "dh@dh_",
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_", rootNodeRef));
|
|
|
|
"alfresco_", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_");
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_");
|
|
|
|
|
|
|
|
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh",
|
|
|
|
personService.setPersonProperties("derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
"alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
testProperties(personService.getPerson("derek"), "derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
|
|
|
|
|
|
|
|
assertEquals(1, personService.getAllPeople().size());
|
|
|
|
assertEquals(2, personService.getAllPeople().size());
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("derek")));
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("derek")));
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_USERNAME, "derek").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_USERNAME, "derek").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_EMAIL, "dh@dh").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_EMAIL, "dh@dh").size());
|
|
|
@@ -317,7 +319,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
assertEquals(0, personService.getPeopleFilteredByProperty(ContentModel.PROP_ORGID, "microsoft").size());
|
|
|
|
assertEquals(0, personService.getPeopleFilteredByProperty(ContentModel.PROP_ORGID, "microsoft").size());
|
|
|
|
|
|
|
|
|
|
|
|
personService.deletePerson("derek");
|
|
|
|
personService.deletePerson("derek");
|
|
|
|
assertEquals(0, personService.getAllPeople().size());
|
|
|
|
assertEquals(1, personService.getAllPeople().size());
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.getPerson("derek");
|
|
|
|
personService.getPerson("derek");
|
|
|
@@ -332,21 +334,18 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
public void testPersonCRUD()
|
|
|
|
public void testPersonCRUD()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService.setCreateMissingPeople(false);
|
|
|
|
personService
|
|
|
|
personService.createPerson(createDefaultProperties("Derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
.createPerson(createDefaultProperties("Derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
|
|
|
|
|
|
|
|
personService.setPersonProperties("Derek", createDefaultProperties("derek", "Derek_", "Hulley_", "dh@dh_",
|
|
|
|
personService.setPersonProperties("Derek", createDefaultProperties("derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_", rootNodeRef));
|
|
|
|
"alfresco_", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_");
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek_", "Hulley_", "dh@dh_", "alfresco_");
|
|
|
|
|
|
|
|
|
|
|
|
personService.setPersonProperties("Derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh",
|
|
|
|
personService.setPersonProperties("Derek", createDefaultProperties("derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
"alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
testProperties(personService.getPerson("Derek"), "Derek", "Derek", "Hulley", "dh@dh", "alfresco");
|
|
|
|
|
|
|
|
|
|
|
|
assertEquals(1, personService.getAllPeople().size());
|
|
|
|
assertEquals(2, personService.getAllPeople().size());
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("Derek")));
|
|
|
|
assertTrue(personService.getAllPeople().contains(personService.getPerson("Derek")));
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_USERNAME, "Derek").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_USERNAME, "Derek").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_EMAIL, "dh@dh").size());
|
|
|
|
assertEquals(1, personService.getPeopleFilteredByProperty(ContentModel.PROP_EMAIL, "dh@dh").size());
|
|
|
@@ -359,29 +358,22 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
assertEquals(personService.personExists("DEREK"), EqualsHelper.nullSafeEquals(personService.getUserIdentifier("DEREK"), "Derek"));
|
|
|
|
assertEquals(personService.personExists("DEREK"), EqualsHelper.nullSafeEquals(personService.getUserIdentifier("DEREK"), "Derek"));
|
|
|
|
|
|
|
|
|
|
|
|
personService.deletePerson("Derek");
|
|
|
|
personService.deletePerson("Derek");
|
|
|
|
assertEquals(0, personService.getAllPeople().size());
|
|
|
|
assertEquals(1, personService.getAllPeople().size());
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void testProperties(NodeRef nodeRef, String userName, String firstName, String lastName, String email,
|
|
|
|
private void testProperties(NodeRef nodeRef, String userName, String firstName, String lastName, String email, String orgId)
|
|
|
|
String orgId)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Map<QName, Serializable> props = nodeService.getProperties(nodeRef);
|
|
|
|
Map<QName, Serializable> props = nodeService.getProperties(nodeRef);
|
|
|
|
assertEquals(userName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef,
|
|
|
|
assertEquals(userName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_USERNAME)));
|
|
|
|
ContentModel.PROP_USERNAME)));
|
|
|
|
|
|
|
|
assertNotNull(nodeService.getProperty(nodeRef, ContentModel.PROP_HOMEFOLDER));
|
|
|
|
assertNotNull(nodeService.getProperty(nodeRef, ContentModel.PROP_HOMEFOLDER));
|
|
|
|
assertEquals(firstName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef,
|
|
|
|
assertEquals(firstName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_FIRSTNAME)));
|
|
|
|
ContentModel.PROP_FIRSTNAME)));
|
|
|
|
assertEquals(lastName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_LASTNAME)));
|
|
|
|
assertEquals(lastName, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef,
|
|
|
|
assertEquals(email, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_EMAIL)));
|
|
|
|
ContentModel.PROP_LASTNAME)));
|
|
|
|
assertEquals(orgId, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef, ContentModel.PROP_ORGID)));
|
|
|
|
assertEquals(email, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef,
|
|
|
|
|
|
|
|
ContentModel.PROP_EMAIL)));
|
|
|
|
|
|
|
|
assertEquals(orgId, DefaultTypeConverter.INSTANCE.convert(String.class, nodeService.getProperty(nodeRef,
|
|
|
|
|
|
|
|
ContentModel.PROP_ORGID)));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private Map<QName, Serializable> createDefaultProperties(String userName, String firstName, String lastName,
|
|
|
|
private Map<QName, Serializable> createDefaultProperties(String userName, String firstName, String lastName, String email, String orgId, NodeRef home)
|
|
|
|
String email, String orgId, NodeRef home)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
HashMap<QName, Serializable> properties = new HashMap<QName, Serializable>();
|
|
|
|
HashMap<QName, Serializable> properties = new HashMap<QName, Serializable>();
|
|
|
|
properties.put(ContentModel.PROP_USERNAME, userName);
|
|
|
|
properties.put(ContentModel.PROP_USERNAME, userName);
|
|
|
@@ -396,8 +388,7 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
public void testCaseSensitive()
|
|
|
|
public void testCaseSensitive()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
personService
|
|
|
|
personService.createPerson(createDefaultProperties("Derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
.createPerson(createDefaultProperties("Derek", "Derek", "Hulley", "dh@dh", "alfresco", rootNodeRef));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
@@ -450,16 +441,16 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
}
|
|
|
|
}
|
|
|
|
personService.getPerson("Derek");
|
|
|
|
personService.getPerson("Derek");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void testReadOnlyTransactionHandling() throws Exception
|
|
|
|
public void testReadOnlyTransactionHandling() throws Exception
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Kill the annoying Spring-managed txn
|
|
|
|
// Kill the annoying Spring-managed txn
|
|
|
|
super.setComplete();
|
|
|
|
super.setComplete();
|
|
|
|
super.endTransaction();
|
|
|
|
super.endTransaction();
|
|
|
|
|
|
|
|
|
|
|
|
boolean createMissingPeople = personService.createMissingPeople();
|
|
|
|
boolean createMissingPeople = personService.createMissingPeople();
|
|
|
|
assertTrue("Default should be to create missing people", createMissingPeople);
|
|
|
|
assertTrue("Default should be to create missing people", createMissingPeople);
|
|
|
|
|
|
|
|
|
|
|
|
final String username = "Derek";
|
|
|
|
final String username = "Derek";
|
|
|
|
// Make sure that the person is missing
|
|
|
|
// Make sure that the person is missing
|
|
|
|
RetryingTransactionCallback<Object> deletePersonWork = new RetryingTransactionCallback<Object>()
|
|
|
|
RetryingTransactionCallback<Object> deletePersonWork = new RetryingTransactionCallback<Object>()
|
|
|
@@ -497,13 +488,13 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
// Kill the annoying Spring-managed txn
|
|
|
|
// Kill the annoying Spring-managed txn
|
|
|
|
super.setComplete();
|
|
|
|
super.setComplete();
|
|
|
|
super.endTransaction();
|
|
|
|
super.endTransaction();
|
|
|
|
|
|
|
|
|
|
|
|
boolean createMissingPeople = personService.createMissingPeople();
|
|
|
|
boolean createMissingPeople = personService.createMissingPeople();
|
|
|
|
assertTrue("Default should be to create missing people", createMissingPeople);
|
|
|
|
assertTrue("Default should be to create missing people", createMissingPeople);
|
|
|
|
|
|
|
|
|
|
|
|
PersonServiceImpl personServiceImpl = (PersonServiceImpl) personService;
|
|
|
|
PersonServiceImpl personServiceImpl = (PersonServiceImpl) personService;
|
|
|
|
personServiceImpl.setDuplicateMode("LEAVE");
|
|
|
|
personServiceImpl.setDuplicateMode("LEAVE");
|
|
|
|
|
|
|
|
|
|
|
|
// The user to duplicate
|
|
|
|
// The user to duplicate
|
|
|
|
final String duplicateUsername = GUID.generate();
|
|
|
|
final String duplicateUsername = GUID.generate();
|
|
|
|
// Make sure that the person is missing
|
|
|
|
// Make sure that the person is missing
|
|
|
@@ -530,8 +521,14 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
public NodeRef execute() throws Throwable
|
|
|
|
public NodeRef execute() throws Throwable
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Wait for the trigger to start
|
|
|
|
// Wait for the trigger to start
|
|
|
|
try { startLatch.await(); } catch (InterruptedException e) {}
|
|
|
|
try
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
startLatch.await();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch (InterruptedException e)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Trigger
|
|
|
|
// Trigger
|
|
|
|
NodeRef personNodeRef = personService.getPerson(duplicateUsername);
|
|
|
|
NodeRef personNodeRef = personService.getPerson(duplicateUsername);
|
|
|
|
return personNodeRef;
|
|
|
|
return personNodeRef;
|
|
|
@@ -562,11 +559,17 @@ public class PersonTest extends BaseSpringTest
|
|
|
|
thread.start();
|
|
|
|
thread.start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Wait for the threads to have finished
|
|
|
|
// Wait for the threads to have finished
|
|
|
|
try { endLatch.await(60, TimeUnit.SECONDS); } catch (InterruptedException e) {}
|
|
|
|
try
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
endLatch.await(60, TimeUnit.SECONDS);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
catch (InterruptedException e)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Now, get the user with full split person handling
|
|
|
|
// Now, get the user with full split person handling
|
|
|
|
personServiceImpl.setDuplicateMode("DELETE");
|
|
|
|
personServiceImpl.setDuplicateMode("DELETE");
|
|
|
|
|
|
|
|
|
|
|
|
RetryingTransactionCallback<NodeRef> getPersonWork = new RetryingTransactionCallback<NodeRef>()
|
|
|
|
RetryingTransactionCallback<NodeRef> getPersonWork = new RetryingTransactionCallback<NodeRef>()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public NodeRef execute() throws Throwable
|
|
|
|
public NodeRef execute() throws Throwable
|
|
|
|