mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
ALF-1878 : Duplicate incoming email Subjects over-write each other
new configuration property email.handler.folder.overwriteDuplicates added, defaults to true so existing behaviour is maintained. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@30952 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -33,12 +33,14 @@ import javax.mail.internet.InternetAddress;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
import org.alfresco.email.server.handler.FolderEmailMessageHandler;
|
||||
import org.alfresco.email.server.impl.subetha.SubethaEmailMessage;
|
||||
import org.alfresco.model.ContentModel;
|
||||
import org.alfresco.repo.management.subsystems.ChildApplicationContextFactory;
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||
import org.alfresco.service.cmr.email.EmailMessageException;
|
||||
import org.alfresco.service.cmr.email.EmailService;
|
||||
import org.alfresco.service.cmr.repository.ChildAssociationRef;
|
||||
import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.alfresco.service.cmr.repository.NodeService;
|
||||
import org.alfresco.service.cmr.repository.StoreRef;
|
||||
@@ -47,6 +49,7 @@ import org.alfresco.service.cmr.security.AuthorityService;
|
||||
import org.alfresco.service.cmr.security.PersonService;
|
||||
import org.alfresco.service.namespace.NamespaceService;
|
||||
import org.alfresco.service.namespace.QName;
|
||||
import org.alfresco.service.namespace.RegexQNamePattern;
|
||||
import org.alfresco.util.ApplicationContextHelper;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
@@ -75,6 +78,7 @@ public class EmailServiceImplTest extends TestCase
|
||||
private AuthorityService authorityService;
|
||||
private SearchService searchService;
|
||||
private NamespaceService namespaceService;
|
||||
private FolderEmailMessageHandler folderEmailMessageHandler;
|
||||
|
||||
String TEST_USER="EmailServiceImplTestUser";
|
||||
|
||||
@@ -92,11 +96,13 @@ public class EmailServiceImplTest extends TestCase
|
||||
emailService = (EmailService)emailCtx.getBean("emailService");
|
||||
assertNotNull("emailService", emailService);
|
||||
personService = (PersonService)emailCtx.getBean("PersonService");
|
||||
assertNotNull("personService", personService);
|
||||
searchService = (SearchService)emailCtx.getBean("SearchService");
|
||||
assertNotNull("searchService", searchService);
|
||||
assertNotNull("personService", personService);
|
||||
namespaceService = (NamespaceService)emailCtx.getBean("NamespaceService");
|
||||
assertNotNull("namespaceService", namespaceService);
|
||||
searchService = (SearchService)emailCtx.getBean("SearchService");
|
||||
assertNotNull("searchService", searchService);
|
||||
folderEmailMessageHandler = (FolderEmailMessageHandler) emailCtx.getBean("folderEmailMessageHandler");
|
||||
assertNotNull("folderEmailMessageHandler", folderEmailMessageHandler);
|
||||
}
|
||||
|
||||
public void tearDown() throws Exception
|
||||
@@ -124,6 +130,8 @@ public class EmailServiceImplTest extends TestCase
|
||||
public void testFromName() throws Exception
|
||||
{
|
||||
|
||||
folderEmailMessageHandler.setOverwriteDuplicates(true);
|
||||
|
||||
logger.debug("Start testFromName");
|
||||
|
||||
String TEST_EMAIL="buffy@sunnydale.high";
|
||||
@@ -318,6 +326,8 @@ public class EmailServiceImplTest extends TestCase
|
||||
|
||||
String TEST_EMAIL="buffy@sunnydale.high";
|
||||
|
||||
folderEmailMessageHandler.setOverwriteDuplicates(true);
|
||||
|
||||
// TODO Investigate why setting PROP_EMAIL on createPerson does not work.
|
||||
NodeRef person = personService.getPerson(TEST_USER);
|
||||
if(person == null)
|
||||
@@ -379,6 +389,129 @@ public class EmailServiceImplTest extends TestCase
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* ALF-1878
|
||||
*
|
||||
* Duplicate incoming email Subjects over-write each other
|
||||
*/
|
||||
public void testMultipleMessagesToFolder() throws Exception
|
||||
{
|
||||
logger.debug("Start testFromName");
|
||||
|
||||
String TEST_EMAIL="buffy@sunnydale.high";
|
||||
|
||||
String TEST_SUBJECT="Practical Bee Keeping";
|
||||
|
||||
String TEST_LONG_SUBJECT = "This is a very very long name in particular it is greater than eitghty six characters which was a problem explored in ALF-9544";
|
||||
|
||||
|
||||
// TODO Investigate why setting PROP_EMAIL on createPerson does not work.
|
||||
NodeRef person = personService.getPerson(TEST_USER);
|
||||
if(person == null)
|
||||
{
|
||||
logger.debug("new person created");
|
||||
Map<QName, Serializable> props = new HashMap<QName, Serializable>();
|
||||
props.put(ContentModel.PROP_USERNAME, TEST_USER);
|
||||
props.put(ContentModel.PROP_EMAIL, TEST_EMAIL);
|
||||
person = personService.createPerson(props);
|
||||
}
|
||||
nodeService.setProperty(person, ContentModel.PROP_EMAIL, TEST_EMAIL);
|
||||
|
||||
Set<String> auths = authorityService.getContainedAuthorities(null, "GROUP_EMAIL_CONTRIBUTORS", true);
|
||||
if(!auths.contains(TEST_USER))
|
||||
{
|
||||
authorityService.addAuthority("GROUP_EMAIL_CONTRIBUTORS", TEST_USER);
|
||||
}
|
||||
|
||||
String companyHomePathInStore = "/app:company_home";
|
||||
String storePath = "workspace://SpacesStore";
|
||||
StoreRef storeRef = new StoreRef(storePath);
|
||||
|
||||
NodeRef storeRootNodeRef = nodeService.getRootNode(storeRef);
|
||||
List<NodeRef> nodeRefs = searchService.selectNodes(storeRootNodeRef, companyHomePathInStore, null, namespaceService, false);
|
||||
NodeRef companyHomeNodeRef = nodeRefs.get(0);
|
||||
assertNotNull("company home is null", companyHomeNodeRef);
|
||||
String companyHomeDBID = ((Long)nodeService.getProperty(companyHomeNodeRef, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||
String testUserDBID = ((Long)nodeService.getProperty(person, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||
NodeRef testUserHomeFolder = (NodeRef)nodeService.getProperty(person, ContentModel.PROP_HOMEFOLDER);
|
||||
assertNotNull("testUserHomeFolder is null", testUserHomeFolder);
|
||||
String testUserHomeDBID = ((Long)nodeService.getProperty(testUserHomeFolder, ContentModel.PROP_NODE_DBID)).toString() + "@Alfresco.com";
|
||||
|
||||
// Clean up old messages in test folder
|
||||
List<ChildAssociationRef> assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
for(ChildAssociationRef assoc : assocs)
|
||||
{
|
||||
nodeService.deleteNode(assoc.getChildRef());
|
||||
}
|
||||
|
||||
/**
|
||||
* Send From the test user TEST_EMAIL to the test user's home
|
||||
*/
|
||||
String from = TEST_EMAIL;
|
||||
String to = testUserHomeDBID;
|
||||
String content = "hello world";
|
||||
|
||||
Session sess = Session.getDefaultInstance(new Properties());
|
||||
assertNotNull("sess is null", sess);
|
||||
SMTPMessage msg = new SMTPMessage(sess);
|
||||
InternetAddress[] toa = { new InternetAddress(to) };
|
||||
|
||||
msg.setFrom(new InternetAddress(TEST_EMAIL));
|
||||
msg.setRecipients(Message.RecipientType.TO, toa);
|
||||
msg.setSubject(TEST_SUBJECT);
|
||||
msg.setContent(content, "text/plain");
|
||||
|
||||
ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
||||
msg.writeTo(bos);
|
||||
InputStream is = new StringInputStream(bos.toString());
|
||||
assertNotNull("is is null", is);
|
||||
|
||||
SubethaEmailMessage m = new SubethaEmailMessage(is);
|
||||
|
||||
/**
|
||||
* Turn on overwriteDuplicates
|
||||
*/
|
||||
logger.debug("Step 1: turn on Overwite Duplicates");
|
||||
folderEmailMessageHandler.setOverwriteDuplicates(true);
|
||||
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 1", 1, assocs.size());
|
||||
assertEquals("name of link not as expected", assocs.get(0).getQName(), QName.createQName(NamespaceService.CONTENT_MODEL_1_0_URI, TEST_SUBJECT));
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 1", 1, assocs.size());
|
||||
|
||||
/**
|
||||
* Turn off overwrite Duplicates
|
||||
*/
|
||||
logger.debug("Step 2: turn off Overwite Duplicates");
|
||||
folderEmailMessageHandler.setOverwriteDuplicates(false);
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 2", 2, assocs.size());
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 3", 3, assocs.size());
|
||||
|
||||
/**
|
||||
* Check assoc rename with long names. So truncation and rename need to work together.
|
||||
*/
|
||||
logger.debug("Step 3: turn off Overwite Duplicates with long subject name");
|
||||
msg.setSubject(TEST_LONG_SUBJECT);
|
||||
ByteArrayOutputStream bos2 = new ByteArrayOutputStream();
|
||||
msg.writeTo(bos2);
|
||||
is = new StringInputStream(bos2.toString());
|
||||
assertNotNull("is is null", is);
|
||||
m = new SubethaEmailMessage(is);
|
||||
|
||||
folderEmailMessageHandler.setOverwriteDuplicates(false);
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 4", 4, assocs.size());
|
||||
emailService.importMessage(m);
|
||||
assocs = nodeService.getChildAssocs(testUserHomeFolder, ContentModel.ASSOC_CONTAINS, RegexQNamePattern.MATCH_ALL);
|
||||
assertEquals("assocs not 5", 5, assocs.size());
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user