mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
125603 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125781 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
203 lines
7.2 KiB
Java
203 lines
7.2 KiB
Java
package org.alfresco.repo.webdav;
|
|
|
|
import static org.junit.Assert.assertEquals;
|
|
import static org.junit.Assert.assertNull;
|
|
import static org.junit.Assert.assertTrue;
|
|
|
|
import java.io.IOException;
|
|
import java.util.Date;
|
|
import java.util.Iterator;
|
|
import java.util.Set;
|
|
import java.util.TreeSet;
|
|
|
|
import org.codehaus.jackson.JsonParseException;
|
|
import org.codehaus.jackson.map.JsonMappingException;
|
|
import org.codehaus.jackson.map.ObjectMapper;
|
|
import org.junit.Test;
|
|
|
|
|
|
public class LockInfoImplTest
|
|
{
|
|
@Test
|
|
public void canSetTimeoutSeconds()
|
|
{
|
|
LockInfoImplEx lockInfo = new LockInfoImplEx();
|
|
|
|
// This should add 7 seconds (7000 millis) to the expiry date.
|
|
lockInfo.setTimeoutSeconds(7);
|
|
|
|
// Check the new date.
|
|
assertEquals(86407000, lockInfo.getExpires().getTime());
|
|
}
|
|
|
|
@Test
|
|
public void canSetTimeoutSecondsToInfinity()
|
|
{
|
|
LockInfoImplEx lockInfo = new LockInfoImplEx();
|
|
|
|
lockInfo.setTimeoutSeconds(WebDAV.TIMEOUT_INFINITY);
|
|
|
|
// Check the new date.
|
|
assertNull(lockInfo.getExpires());
|
|
}
|
|
|
|
@Test
|
|
public void canSetTimeoutMinutes()
|
|
{
|
|
LockInfoImplEx lockInfo = new LockInfoImplEx();
|
|
|
|
// This should add 5 minutes to the expiry date.
|
|
lockInfo.setTimeoutMinutes(5);
|
|
|
|
// Check the new date.
|
|
assertEquals(86700000, lockInfo.getExpires().getTime());
|
|
}
|
|
|
|
@Test
|
|
public void canSetTimeoutMinutesToInfinity()
|
|
{
|
|
LockInfoImplEx lockInfo = new LockInfoImplEx();
|
|
|
|
lockInfo.setTimeoutMinutes(WebDAV.TIMEOUT_INFINITY);
|
|
|
|
// Check the new date.
|
|
assertNull(lockInfo.getExpires());
|
|
}
|
|
|
|
@Test
|
|
public void canGetRemainingTimeoutSeconds()
|
|
{
|
|
LockInfoImplEx lockInfo = new LockInfoImplEx();
|
|
|
|
lockInfo.setTimeoutSeconds(7);
|
|
|
|
assertEquals(7, lockInfo.getRemainingTimeoutSeconds());
|
|
}
|
|
|
|
@Test(expected=IllegalStateException.class)
|
|
public void cannotChangeSharedLockToExclusive()
|
|
{
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.addSharedLockToken("shared-token");
|
|
|
|
// Not allowed
|
|
lockInfo.setExclusiveLockToken("token");
|
|
}
|
|
|
|
@Test(expected=IllegalStateException.class)
|
|
public void cannotChangeExclusiveLockToShared()
|
|
{
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.setExclusiveLockToken("token");
|
|
|
|
// Not allowed
|
|
lockInfo.addSharedLockToken("shared-token");
|
|
}
|
|
|
|
public void canSetShared()
|
|
{
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.setExclusiveLockToken("exc-token");
|
|
|
|
assertEquals("exc-token", lockInfo.getExclusiveLockToken());
|
|
}
|
|
|
|
public void canSetExclusive()
|
|
{
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.addSharedLockToken("shared1");
|
|
lockInfo.addSharedLockToken("shared2");
|
|
|
|
assertEquals(2, lockInfo.getSharedLockTokens().size());
|
|
assertTrue(lockInfo.getSharedLockTokens().contains("shared1"));
|
|
assertTrue(lockInfo.getSharedLockTokens().contains("shared2"));
|
|
}
|
|
|
|
@Test
|
|
public void canGenerateJSON() throws JsonParseException, JsonMappingException, IOException
|
|
{
|
|
// Exclusive lock
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.setExclusiveLockToken("opaque-lock-token");
|
|
lockInfo.setDepth(WebDAV.INFINITY);
|
|
lockInfo.setScope(WebDAV.XML_EXCLUSIVE);
|
|
|
|
String json = lockInfo.toJSON();
|
|
ObjectMapper objectMapper = new ObjectMapper();
|
|
assertTrue("ADDINFO_WEBDAV_MARKER", json.startsWith(LockInfoImpl.ADDINFO_WEBDAV_MARKER));
|
|
json = json.substring(LockInfoImpl.ADDINFO_WEBDAV_MARKER.length() + 1);
|
|
LockInfoImpl parsed = objectMapper.readValue(json, LockInfoImpl.class);
|
|
assertEquals("opaque-lock-token", parsed.getExclusiveLockToken());
|
|
assertEquals(WebDAV.INFINITY, parsed.getDepth());
|
|
assertEquals(WebDAV.XML_EXCLUSIVE, parsed.getScope());
|
|
|
|
// Shared lock
|
|
lockInfo = new LockInfoImpl();
|
|
lockInfo.addSharedLockToken("opaque-lock-token-1");
|
|
lockInfo.addSharedLockToken("opaque-lock-token-2");
|
|
lockInfo.addSharedLockToken("opaque-lock-token-3");
|
|
lockInfo.setDepth(WebDAV.ZERO);
|
|
lockInfo.setScope(WebDAV.XML_SHARED);
|
|
|
|
json = lockInfo.toJSON();
|
|
assertTrue("ADDINFO_WEBDAV_MARKER", json.startsWith(LockInfoImpl.ADDINFO_WEBDAV_MARKER));
|
|
json = json.substring(LockInfoImpl.ADDINFO_WEBDAV_MARKER.length() + 1);
|
|
parsed = objectMapper.readValue(json, LockInfoImpl.class);
|
|
Set<String> sortedTokens = new TreeSet<String>(parsed.getSharedLockTokens());
|
|
Iterator<String> tokenIt = sortedTokens.iterator();
|
|
assertEquals("opaque-lock-token-1", tokenIt.next());
|
|
assertEquals("opaque-lock-token-2", tokenIt.next());
|
|
assertEquals("opaque-lock-token-3", tokenIt.next());
|
|
assertEquals(WebDAV.ZERO, parsed.getDepth());
|
|
assertEquals(WebDAV.XML_SHARED, parsed.getScope());
|
|
}
|
|
|
|
@Test
|
|
public void canParseJSON() throws JsonParseException, JsonMappingException, IOException
|
|
{
|
|
// Exclusive lock
|
|
LockInfoImpl lockInfo = new LockInfoImpl();
|
|
lockInfo.setExclusiveLockToken("opaque-lock-token");
|
|
lockInfo.setDepth(WebDAV.INFINITY);
|
|
lockInfo.setScope(WebDAV.XML_EXCLUSIVE);
|
|
|
|
String json = lockInfo.toJSON();
|
|
// Execute the factory method we're testing
|
|
LockInfo parsed = LockInfoImpl.fromJSON(json);
|
|
assertEquals("opaque-lock-token", parsed.getExclusiveLockToken());
|
|
assertEquals(WebDAV.INFINITY, parsed.getDepth());
|
|
assertEquals(WebDAV.XML_EXCLUSIVE, parsed.getScope());
|
|
|
|
// Shared lock
|
|
lockInfo = new LockInfoImpl();
|
|
lockInfo.addSharedLockToken("opaque-lock-token-1");
|
|
lockInfo.addSharedLockToken("opaque-lock-token-2");
|
|
lockInfo.addSharedLockToken("opaque-lock-token-3");
|
|
lockInfo.setDepth(WebDAV.ZERO);
|
|
lockInfo.setScope(WebDAV.XML_SHARED);
|
|
|
|
json = lockInfo.toJSON();
|
|
// Execute the factory method we're testing
|
|
parsed = LockInfoImpl.fromJSON(json);
|
|
Set<String> sortedTokens = new TreeSet<String>(parsed.getSharedLockTokens());
|
|
Iterator<String> tokenIt = sortedTokens.iterator();
|
|
assertEquals("opaque-lock-token-1", tokenIt.next());
|
|
assertEquals("opaque-lock-token-2", tokenIt.next());
|
|
assertEquals("opaque-lock-token-3", tokenIt.next());
|
|
assertEquals(WebDAV.ZERO, parsed.getDepth());
|
|
assertEquals(WebDAV.XML_SHARED, parsed.getScope());
|
|
}
|
|
|
|
public static class LockInfoImplEx extends LockInfoImpl
|
|
{
|
|
public static final Date DATE_NOW = new Date(86400000);
|
|
private static final long serialVersionUID = 1669378516554195322L;
|
|
|
|
@Override
|
|
protected Date dateNow()
|
|
{
|
|
return DATE_NOW;
|
|
}
|
|
}
|
|
}
|