mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-21 18:09:20 +00:00
Merged FILE-FOLDER-API (5.2.0) to HEAD (5.2)
122792 jkaabimofrad: RA-676, RA-677, RA-678: - Added check to return 404 response when the renditionId is registered but is not applicable for the node's mimeType. - Added check to return 400 when the source node has no content. - Changed the create rendition response to return an empty body. - Modified the exception when the renditionId is not registered. - Fixed the framework to include “errorKey” in the error response which was missing from some exceptions such as EntityNotFoundException. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@126509 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -33,6 +33,7 @@ import org.alfresco.rest.api.tests.RepoService.TestNetwork;
|
||||
import org.alfresco.rest.api.tests.RepoService.TestPerson;
|
||||
import org.alfresco.rest.api.tests.RepoService.TestSite;
|
||||
import org.alfresco.rest.api.tests.client.HttpResponse;
|
||||
import org.alfresco.rest.api.tests.client.PublicApiClient.ExpectedErrorResponse;
|
||||
import org.alfresco.rest.api.tests.client.PublicApiClient.ExpectedPaging;
|
||||
import org.alfresco.rest.api.tests.client.PublicApiClient.Paging;
|
||||
import org.alfresco.rest.api.tests.client.data.ContentInfo;
|
||||
@@ -68,7 +69,7 @@ import java.util.UUID;
|
||||
public class RenditionsTest extends AbstractBaseApiTest
|
||||
{
|
||||
private static final long PAUSE_TIME = 5000; //millisecond
|
||||
private static final int MAX_RETRY = 8;
|
||||
private static final int MAX_RETRY = 10;
|
||||
|
||||
/**
|
||||
* User one from network one
|
||||
@@ -221,6 +222,19 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
|
||||
// nodeId in the path parameter does not exist
|
||||
getAll(getRenditionsUrl(UUID.randomUUID().toString()), userOneN1.getId(), paging, params, 404);
|
||||
|
||||
// Create a node without any content
|
||||
String emptyContentNodeId = addToDocumentLibrary(userOneN1Site, "emptyDoc.txt", ContentModel.TYPE_CONTENT, userOneN1.getId());
|
||||
// The source node has no content
|
||||
getAll(getRenditionsUrl(emptyContentNodeId), userOneN1.getId(), paging, params, 400);
|
||||
|
||||
// Invalid status value
|
||||
params.put("where", "(status='WRONG')");
|
||||
getAll(getRenditionsUrl(contentNodeId), userOneN1.getId(), paging, params, 400);
|
||||
|
||||
// Invalid filter (only 'status' is supported)
|
||||
params.put("where", "(id='doclib')");
|
||||
getAll(getRenditionsUrl(contentNodeId), userOneN1.getId(), paging, params, 400);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -277,6 +291,33 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
|
||||
// renditionId in the path parameter is not registered/available
|
||||
getSingle(getRenditionsUrl(contentNodeId), userOneN1.getId(), ("renditionId" + System.currentTimeMillis()), 404);
|
||||
|
||||
// Create a node without any content
|
||||
String emptyContentNodeId = addToDocumentLibrary(userOneN1Site, "emptyDoc.txt", ContentModel.TYPE_CONTENT, userOneN1.getId());
|
||||
// The source node has no content
|
||||
getSingle(getRenditionsUrl(emptyContentNodeId), userOneN1.getId(), "doclib", 400);
|
||||
|
||||
// Create multipart request
|
||||
String jpgFileName = "quick.jpg";
|
||||
File jpgFile = getResourceFile(fileName);
|
||||
reqBody = MultiPartBuilder.create()
|
||||
.setFileData(new FileData(jpgFileName, jpgFile, MimetypeMap.MIMETYPE_IMAGE_JPEG))
|
||||
.build();
|
||||
|
||||
// Upload quick.jpg file into 'folder'
|
||||
response = post("nodes/" + folder_Id + "/children", userOneN1.getId(), reqBody.getBody(), null, reqBody.getContentType(), 201);
|
||||
Document jpgImage = RestApiUtil.parseRestApiEntry(response.getJsonResponse(), Document.class);
|
||||
String jpgImageNodeId = jpgImage.getId();
|
||||
|
||||
// List all available renditions (includes those that have been created and those that are yet to be created)
|
||||
response = getAll(getRenditionsUrl(jpgImageNodeId), userOneN1.getId(), getPaging(0, 50), 200);
|
||||
List<Rendition> renditions = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Rendition.class);
|
||||
// Check there is no pdf rendition is available for the jpg file
|
||||
Rendition pdf = getRendition(renditions, "pdf");
|
||||
assertNull(pdf);
|
||||
|
||||
// The renditionId (pdf) is registered but it is not applicable for the node's mimeType
|
||||
getSingle(getRenditionsUrl(jpgImageNodeId), userOneN1.getId(), "pdf", 404);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -321,7 +362,14 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
|
||||
// -ve Tests
|
||||
// The rendition requested already exists
|
||||
post(getRenditionsUrl(folder_Id), userOneN1.getId(), toJsonAsString(new Rendition().setId("imgpreview")), 400);
|
||||
response = post(getRenditionsUrl(contentNodeId), userOneN1.getId(), toJsonAsString(new Rendition().setId("imgpreview")), 400);
|
||||
ExpectedErrorResponse errorResponse = RestApiUtil.parseErrorResponse(response.getJsonResponse());
|
||||
assertNotNull(errorResponse);
|
||||
assertNotNull(errorResponse.getErrorKey());
|
||||
assertNotNull(errorResponse.getBriefSummary());
|
||||
assertNotNull(errorResponse.getStackTrace());
|
||||
assertNotNull(errorResponse.getDescriptionURL());
|
||||
assertEquals(400, errorResponse.getStatusCode());
|
||||
|
||||
// Create 'doclib' rendition request
|
||||
Rendition renditionRequest = new Rendition().setId("doclib");
|
||||
@@ -329,12 +377,26 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
post(getRenditionsUrl(folder_Id), userOneN1.getId(), toJsonAsString(renditionRequest), 400);
|
||||
|
||||
// nodeId in the path parameter does not exist
|
||||
post(getRenditionsUrl(UUID.randomUUID().toString()), userOneN1.getId(), toJsonAsString(renditionRequest), 404);
|
||||
response = post(getRenditionsUrl(UUID.randomUUID().toString()), userOneN1.getId(), toJsonAsString(renditionRequest), 404);
|
||||
// EntityNotFoundException
|
||||
errorResponse = RestApiUtil.parseErrorResponse(response.getJsonResponse());
|
||||
assertNotNull(errorResponse);
|
||||
assertNotNull(errorResponse.getErrorKey());
|
||||
assertNotNull(errorResponse.getBriefSummary());
|
||||
assertNotNull(errorResponse.getStackTrace());
|
||||
assertNotNull(errorResponse.getDescriptionURL());
|
||||
assertEquals(404, errorResponse.getStatusCode());
|
||||
|
||||
// renditionId is not registered
|
||||
final String randomRenditionId = "renditionId" + System.currentTimeMillis();
|
||||
post(getRenditionsUrl(contentNodeId), userOneN1.getId(), toJsonAsString(new Rendition().setId(randomRenditionId)), 404);
|
||||
|
||||
// renditionId is null
|
||||
post(getRenditionsUrl(contentNodeId), userOneN1.getId(), toJsonAsString(new Rendition().setId(null)), 400);
|
||||
|
||||
// renditionId is empty
|
||||
post(getRenditionsUrl(contentNodeId), userOneN1.getId(), toJsonAsString(new Rendition().setId("")), 400);
|
||||
|
||||
// Create a node without any content
|
||||
String emptyContentNodeId = addToDocumentLibrary(userOneN1Site, "emptyDoc.txt", ContentModel.TYPE_CONTENT, userOneN1.getId());
|
||||
// The source node has no content
|
||||
@@ -364,7 +426,14 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
response = post("nodes/" + folder_Id + "/children", userOneN1.getId(), reqBody.getBody(), null, reqBody.getContentType(), 201);
|
||||
Document txtDocument = RestApiUtil.parseRestApiEntry(response.getJsonResponse(), Document.class);
|
||||
// Thumbnail generation has been disabled
|
||||
post(getRenditionsUrl(txtDocument.getId()), userOneN1.getId(), toJsonAsString(renditionRequest), 501);
|
||||
response = post(getRenditionsUrl(txtDocument.getId()), userOneN1.getId(), toJsonAsString(renditionRequest), 501);
|
||||
errorResponse = RestApiUtil.parseErrorResponse(response.getJsonResponse());
|
||||
assertNotNull(errorResponse);
|
||||
assertNotNull(errorResponse.getErrorKey());
|
||||
assertNotNull(errorResponse.getBriefSummary());
|
||||
assertNotNull(errorResponse.getStackTrace());
|
||||
assertNotNull(errorResponse.getDescriptionURL());
|
||||
assertEquals(501, errorResponse.getStatusCode());
|
||||
}
|
||||
finally
|
||||
{
|
||||
@@ -481,7 +550,7 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
InputStream inputStream = new ByteArrayInputStream("The quick brown fox jumps over the lazy dog".getBytes());
|
||||
file = TempFileProvider.createTempFile(inputStream, "RenditionsTest-", ".abcdef");
|
||||
reqBody = MultiPartBuilder.create()
|
||||
.setFileData(new FileData(file.getName(), file, "application/unknown"))
|
||||
.setFileData(new FileData(file.getName(), file, MimetypeMap.MIMETYPE_TEXT_PLAIN))
|
||||
.build();
|
||||
// Upload temp file into 'folder'
|
||||
response = post("nodes/" + folder_Id + "/children", userOneN1.getId(), reqBody.getBody(), null, reqBody.getContentType(), 201);
|
||||
@@ -504,6 +573,11 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
params = Collections.singletonMap("placeholder", "true");
|
||||
getSingle(getRenditionsUrl(contentNodeId), userOneN1.getId(), ("renditionId" + System.currentTimeMillis() + "/content"), params, 404);
|
||||
|
||||
// Create a node without any content
|
||||
String emptyContentNodeId = addToDocumentLibrary(userOneN1Site, "emptyDoc.txt", ContentModel.TYPE_CONTENT, userOneN1.getId());
|
||||
// The source node has no content
|
||||
getSingle(getRenditionsUrl(emptyContentNodeId), userOneN1.getId(), "doclib/content", params, 400);
|
||||
|
||||
//TODO add tests for 304 response
|
||||
}
|
||||
|
||||
@@ -529,7 +603,8 @@ public class RenditionsTest extends AbstractBaseApiTest
|
||||
{
|
||||
try
|
||||
{
|
||||
post(getRenditionsUrl(sourceNodeId), userOneN1.getId(), toJsonAsString(renditionRequest), 202);
|
||||
HttpResponse res = post(getRenditionsUrl(sourceNodeId), userOneN1.getId(), toJsonAsString(renditionRequest), 202);
|
||||
assertNull(res.getJsonResponse());
|
||||
break;
|
||||
}
|
||||
catch (AssertionError ex)
|
||||
|
@@ -26,6 +26,7 @@ import java.io.Serializable;
|
||||
import java.math.BigInteger;
|
||||
import java.text.ParseException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
@@ -2002,4 +2003,114 @@ public class PublicApiClient
|
||||
+ (maxItems != null ? "maxItems=" + maxItems : "") + "]";
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Representation of an error response.
|
||||
*
|
||||
* @author Jamal Kaabi-Mofrad
|
||||
*/
|
||||
public static class ExpectedErrorResponse
|
||||
{
|
||||
private String errorKey;
|
||||
private int statusCode;
|
||||
private String briefSummary;
|
||||
private String stackTrace;
|
||||
private Map<String, Object> additionalState;
|
||||
private String descriptionURL;
|
||||
|
||||
public ExpectedErrorResponse()
|
||||
{
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse(String errorKey, int statusCode, String briefSummary, StackTraceElement[] stackTrace,
|
||||
Map<String, Object> additionalState)
|
||||
{
|
||||
super();
|
||||
this.errorKey = errorKey;
|
||||
this.statusCode = statusCode;
|
||||
this.briefSummary = briefSummary;
|
||||
this.stackTrace = Arrays.toString(stackTrace);
|
||||
this.additionalState = additionalState;
|
||||
}
|
||||
|
||||
public String getErrorKey()
|
||||
{
|
||||
return errorKey;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setErrorKey(String errorKey)
|
||||
{
|
||||
this.errorKey = errorKey;
|
||||
return this;
|
||||
}
|
||||
|
||||
public int getStatusCode()
|
||||
{
|
||||
return statusCode;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setStatusCode(int statusCode)
|
||||
{
|
||||
this.statusCode = statusCode;
|
||||
return this;
|
||||
}
|
||||
|
||||
public String getBriefSummary()
|
||||
{
|
||||
return briefSummary;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setBriefSummary(String briefSummary)
|
||||
{
|
||||
this.briefSummary = briefSummary;
|
||||
return this;
|
||||
}
|
||||
|
||||
public String getStackTrace()
|
||||
{
|
||||
return stackTrace;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setStackTrace(String stackTrace)
|
||||
{
|
||||
this.stackTrace = stackTrace;
|
||||
return this;
|
||||
}
|
||||
|
||||
public Map<String, Object> getAdditionalState()
|
||||
{
|
||||
return additionalState;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setAdditionalState(Map<String, Object> additionalState)
|
||||
{
|
||||
this.additionalState = additionalState;
|
||||
return this;
|
||||
}
|
||||
|
||||
public String getDescriptionURL()
|
||||
{
|
||||
return descriptionURL;
|
||||
}
|
||||
|
||||
public ExpectedErrorResponse setDescriptionURL(String descriptionURL)
|
||||
{
|
||||
this.descriptionURL = descriptionURL;
|
||||
return this;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
final StringBuilder sb = new StringBuilder(250);
|
||||
sb.append("ExpectedErrorResponse [errorKey='").append(errorKey)
|
||||
.append(", statusCode=").append(statusCode)
|
||||
.append(", briefSummary='").append(briefSummary)
|
||||
.append(", stackTrace='").append(stackTrace)
|
||||
.append(", additionalState=").append(additionalState)
|
||||
.append(", descriptionURL='").append(descriptionURL)
|
||||
.append(']');
|
||||
return sb.toString();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2015 Alfresco Software Limited.
|
||||
* Copyright (C) 2005-2016 Alfresco Software Limited.
|
||||
*
|
||||
* This file is part of Alfresco
|
||||
*
|
||||
@@ -127,6 +127,18 @@ public class RestApiUtil
|
||||
return pojoModel;
|
||||
}
|
||||
|
||||
/**
|
||||
* Parses the alfresco REST API error response.
|
||||
*
|
||||
* @param jsonObject the {@code JSONObject} derived from the response
|
||||
* @return ExpectedErrorResponse the error object
|
||||
* @throws Exception
|
||||
*/
|
||||
public static PublicApiClient.ExpectedErrorResponse parseErrorResponse(JSONObject jsonObject) throws Exception
|
||||
{
|
||||
return parsePojo("error", jsonObject, PublicApiClient.ExpectedErrorResponse.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts the POJO which represents the JSON payload into a JSON string
|
||||
*/
|
||||
|
Reference in New Issue
Block a user