Added channel-types.get REST method. Also made the versioning work when publishing nodes.

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@28923 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
N Smith
2011-07-11 16:24:58 +00:00
parent 52f5a1c7d0
commit c0eea3ae95
2 changed files with 49 additions and 54 deletions

View File

@@ -19,10 +19,7 @@
package org.alfresco.repo.publishing; package org.alfresco.repo.publishing;
import static junit.framework.Assert.assertEquals; import static org.alfresco.model.ContentModel.PROP_VERSION_LABEL;
import static junit.framework.Assert.assertNull;
import static junit.framework.Assert.assertNotNull;
import static junit.framework.Assert.assertTrue;
import static org.alfresco.repo.publishing.PublishingModel.PROP_PUBLISHING_EVENT_WORKFLOW_ID; import static org.alfresco.repo.publishing.PublishingModel.PROP_PUBLISHING_EVENT_WORKFLOW_ID;
import static org.alfresco.repo.publishing.PublishingModel.PROP_WF_PUBLISHING_EVENT; import static org.alfresco.repo.publishing.PublishingModel.PROP_WF_PUBLISHING_EVENT;
import static org.alfresco.repo.publishing.PublishingModel.PROP_WF_SCHEDULED_PUBLISH_DATE; import static org.alfresco.repo.publishing.PublishingModel.PROP_WF_SCHEDULED_PUBLISH_DATE;
@@ -35,8 +32,6 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import javax.annotation.Resource;
import org.alfresco.model.ContentModel; import org.alfresco.model.ContentModel;
import org.alfresco.repo.security.authentication.AuthenticationUtil; import org.alfresco.repo.security.authentication.AuthenticationUtil;
import org.alfresco.service.cmr.publishing.MutablePublishingPackage; import org.alfresco.service.cmr.publishing.MutablePublishingPackage;
@@ -75,6 +70,8 @@ public class PublishingQueueImplTest extends AbstractPublishingIntegrationTest
NodeRef firstNode = createContent("First"); NodeRef firstNode = createContent("First");
NodeRef secondNode = createContent("second"); NodeRef secondNode = createContent("second");
assertNull(nodeService.getProperty(firstNode, PROP_VERSION_LABEL));
assertNull(nodeService.getProperty(firstNode, PROP_VERSION_LABEL));
MutablePublishingPackage publishingPackage = queue.createPublishingPackage(); MutablePublishingPackage publishingPackage = queue.createPublishingPackage();
publishingPackage.addNodesToPublish(firstNode, secondNode); publishingPackage.addNodesToPublish(firstNode, secondNode);
@@ -87,6 +84,10 @@ public class PublishingQueueImplTest extends AbstractPublishingIntegrationTest
this.eventId = queue.scheduleNewEvent(publishingPackage, channelName, schedule, comment, null); this.eventId = queue.scheduleNewEvent(publishingPackage, channelName, schedule, comment, null);
//Check schedule triggered versioning.
Serializable version = nodeService.getProperty(firstNode, PROP_VERSION_LABEL);
assertNotNull(version);
PublishingEvent event = publishingService.getPublishingEvent(eventId); PublishingEvent event = publishingService.getPublishingEvent(eventId);
assertEquals(eventId, event.getId()); assertEquals(eventId, event.getId());
assertEquals(comment, event.getComment()); assertEquals(comment, event.getComment());
@@ -119,6 +120,10 @@ public class PublishingQueueImplTest extends AbstractPublishingIntegrationTest
// assertEquals(1, toUnpublish.size()); // assertEquals(1, toUnpublish.size());
// assertTrue(toUnpublish.contains(thirdNode)); // assertTrue(toUnpublish.contains(thirdNode));
// Check the correct version is recorded in the entry.
PublishingPackageEntry entry = publishingPackage.getEntryMap().get(firstNode);
assertEquals(version, entry.getSnapshot().getVersion());
NodeRef eventNode = new NodeRef(eventId); NodeRef eventNode = new NodeRef(eventId);
String wfId = (String) nodeService.getProperty(eventNode, PROP_PUBLISHING_EVENT_WORKFLOW_ID); String wfId = (String) nodeService.getProperty(eventNode, PROP_PUBLISHING_EVENT_WORKFLOW_ID);
@@ -131,6 +136,7 @@ public class PublishingQueueImplTest extends AbstractPublishingIntegrationTest
assertEquals(schedule, props.get(PROP_WF_SCHEDULED_PUBLISH_DATE)); assertEquals(schedule, props.get(PROP_WF_SCHEDULED_PUBLISH_DATE));
} }
@Test
public void testScheduleNewPublishingEventWithStatusUpdate() throws Exception public void testScheduleNewPublishingEventWithStatusUpdate() throws Exception
{ {
NodeRef firstNode = createContent("First"); NodeRef firstNode = createContent("First");
@@ -138,22 +144,22 @@ public class PublishingQueueImplTest extends AbstractPublishingIntegrationTest
List<String> channelNames = Arrays.asList("Channel1", "Channel2", "Channel3" ); List<String> channelNames = Arrays.asList("Channel1", "Channel2", "Channel3" );
String message = "The message"; String message = "The message";
queue.createStatusUpdate(message, secondNode, channelNames); StatusUpdate update = queue.createStatusUpdate(message, secondNode, channelNames);
// Publish an event with the StatusUpdate // Publish an event with the StatusUpdate
MutablePublishingPackage publishingPackage = queue.createPublishingPackage(); MutablePublishingPackage publishingPackage = queue.createPublishingPackage();
publishingPackage.addNodesToPublish(firstNode, secondNode); publishingPackage.addNodesToPublish(firstNode, secondNode);
Calendar schedule = Calendar.getInstance(); Calendar schedule = Calendar.getInstance();
schedule.add(Calendar.HOUR, 2); schedule.add(Calendar.HOUR, 2);
this.eventId = queue.scheduleNewEvent(publishingPackage, channelName, schedule, comment, null); this.eventId = queue.scheduleNewEvent(publishingPackage, channelName, schedule, comment, update);
PublishingEvent event = publishingService.getPublishingEvent(eventId); PublishingEvent event = publishingService.getPublishingEvent(eventId);
StatusUpdate update = event.getStatusUpdate(); StatusUpdate actualUpdate = event.getStatusUpdate();
// assertEquals(message, update.getMessage()); assertEquals(message, actualUpdate.getMessage());
// assertEquals(secondNode, update.getNodeToLinkTo()); assertEquals(secondNode, actualUpdate.getNodeToLinkTo());
// Set<String> names = update.getChannelNames(); Set<String> names = actualUpdate.getChannelNames();
// assertEquals(3, names.size()); assertEquals(3, names.size());
// assertTrue(names.containsAll(channelNames)); assertTrue(names.containsAll(channelNames));
} }
private NodeRef createContent(String name) private NodeRef createContent(String name)

View File

@@ -22,6 +22,7 @@ package org.alfresco.repo.publishing;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.OutputStreamWriter; import java.io.OutputStreamWriter;
import java.io.Serializable;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.io.Writer; import java.io.Writer;
import java.util.Collection; import java.util.Collection;
@@ -32,6 +33,7 @@ import java.util.Map;
import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import javax.xml.parsers.SAXParserFactory;
import org.alfresco.model.ContentModel;
import org.alfresco.repo.transfer.manifest.TransferManifestDeletedNode; import org.alfresco.repo.transfer.manifest.TransferManifestDeletedNode;
import org.alfresco.repo.transfer.manifest.TransferManifestHeader; import org.alfresco.repo.transfer.manifest.TransferManifestHeader;
import org.alfresco.repo.transfer.manifest.TransferManifestNormalNode; import org.alfresco.repo.transfer.manifest.TransferManifestNormalNode;
@@ -41,22 +43,18 @@ import org.alfresco.repo.transfer.manifest.XMLTransferManifestWriter;
import org.alfresco.service.cmr.publishing.PublishingPackage; import org.alfresco.service.cmr.publishing.PublishingPackage;
import org.alfresco.service.cmr.publishing.PublishingPackageEntry; import org.alfresco.service.cmr.publishing.PublishingPackageEntry;
import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.namespace.QName;
import org.xml.sax.SAXException; import org.xml.sax.SAXException;
/** /**
* @author Brian * @author Brian
* * @author Nick Smith
*/ */
public class StandardPublishingPackageSerializer implements PublishingPackageSerializer public class StandardPublishingPackageSerializer implements PublishingPackageSerializer
{ {
/* /**
* (non-Javadoc) * {@inheritDoc}
*
* @see
* org.alfresco.repo.publishing.PublishingPackageSerializer#deserialize(
* java.io.Reader)
*/ */
@Override
public PublishingPackage deserialize(InputStream input) throws Exception public PublishingPackage deserialize(InputStream input) throws Exception
{ {
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance(); SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
@@ -69,14 +67,9 @@ public class StandardPublishingPackageSerializer implements PublishingPackageSer
return publishingPackage; return publishingPackage;
} }
/* /**
* (non-Javadoc) * {@inheritDoc}
*
* @see
* org.alfresco.repo.publishing.PublishingPackageSerializer#serialize(org
* .alfresco.service.cmr.publishing.PublishingPackage, java.io.Writer)
*/ */
@Override
public void serialize(PublishingPackage publishingPackage, OutputStream output) throws Exception public void serialize(PublishingPackage publishingPackage, OutputStream output) throws Exception
{ {
try try
@@ -96,7 +89,7 @@ public class StandardPublishingPackageSerializer implements PublishingPackageSer
transferManifestWriter.writeTransferManifestHeader(header); transferManifestWriter.writeTransferManifestHeader(header);
for (PublishingPackageEntry entry : entries) for (PublishingPackageEntry entry : entries)
{ {
if (PublishingPackageEntryImpl.class.isAssignableFrom(entry.getClass())) if (entry instanceof PublishingPackageEntryImpl)
{ {
PublishingPackageEntryImpl entryImpl = (PublishingPackageEntryImpl)entry; PublishingPackageEntryImpl entryImpl = (PublishingPackageEntryImpl)entry;
transferManifestWriter.writeTransferManifestNode(entryImpl.getPayload()); transferManifestWriter.writeTransferManifestNode(entryImpl.getPayload());
@@ -118,14 +111,13 @@ public class StandardPublishingPackageSerializer implements PublishingPackageSer
/** /**
* @author Brian * @author Brian
* @author Nick Smith
* *
*/ */
public static class PublishingPackageDeserializer implements TransferManifestProcessor public static class PublishingPackageDeserializer implements TransferManifestProcessor
{ {
Map<NodeRef,PublishingPackageEntry> entries = new HashMap<NodeRef,PublishingPackageEntry>(); Map<NodeRef,PublishingPackageEntry> entries = new HashMap<NodeRef,PublishingPackageEntry>();
/** /**
* @return the entries * @return the entries
*/ */
@@ -134,46 +126,43 @@ public class StandardPublishingPackageSerializer implements PublishingPackageSer
return entries; return entries;
} }
/* (non-Javadoc) /**
* @see org.alfresco.repo.transfer.manifest.TransferManifestProcessor#endTransferManifest() * {@inheritDoc}
*/ */
@Override
public void endTransferManifest() public void endTransferManifest()
{ {
//NOOP //NOOP
} }
/* (non-Javadoc) /**
* @see org.alfresco.repo.transfer.manifest.TransferManifestProcessor#processTransferManifestNode(org.alfresco.repo.transfer.manifest.TransferManifestNormalNode) * {@inheritDoc}
*/ */
@Override
public void processTransferManifestNode(TransferManifestNormalNode node) public void processTransferManifestNode(TransferManifestNormalNode node)
{ {
entries.put(node.getNodeRef(), new PublishingPackageEntryImpl(true, node.getNodeRef(), node, null)); Map<QName, Serializable> props = node.getProperties();
String version = (String) props.get(ContentModel.PROP_VERSION_LABEL);
entries.put(node.getNodeRef(), new PublishingPackageEntryImpl(true, node.getNodeRef(), node, version));
} }
/* (non-Javadoc) /**
* @see org.alfresco.repo.transfer.manifest.TransferManifestProcessor#processTransferManifestNode(org.alfresco.repo.transfer.manifest.TransferManifestDeletedNode) * {@inheritDoc}
*/ */
@Override
public void processTransferManifestNode(TransferManifestDeletedNode node) public void processTransferManifestNode(TransferManifestDeletedNode node)
{ {
entries.put(node.getNodeRef(), new PublishingPackageEntryImpl(false, node.getNodeRef(), null, null)); entries.put(node.getNodeRef(), new PublishingPackageEntryImpl(false, node.getNodeRef(), null, null));
} }
/* (non-Javadoc) /**
* @see org.alfresco.repo.transfer.manifest.TransferManifestProcessor#processTransferManifiestHeader(org.alfresco.repo.transfer.manifest.TransferManifestHeader) * {@inheritDoc}
*/ */
@Override
public void processTransferManifiestHeader(TransferManifestHeader header) public void processTransferManifiestHeader(TransferManifestHeader header)
{ {
//NOOP //NOOP
} }
/* (non-Javadoc) /**
* @see org.alfresco.repo.transfer.manifest.TransferManifestProcessor#startTransferManifest() * {@inheritDoc}
*/ */
@Override
public void startTransferManifest() public void startTransferManifest()
{ {
//NOOP //NOOP