mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
Merged HEAD (5.2) to 5.2.N (5.2.1)
126600 jkaabimofrad: Merged FILE-FOLDER-API (5.2.0) to HEAD (5.2) 124911 jvonka: RA-767: Queries API - additional tests & fixes (re: tag hits & also optional "include" info in results) git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@126945 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -1223,7 +1223,7 @@ public class NodesImpl implements Nodes
|
|||||||
{
|
{
|
||||||
FileInfo fInfo = page.get(index);
|
FileInfo fInfo = page.get(index);
|
||||||
|
|
||||||
// minimal info by default (unless "select"ed otherwise)
|
// minimal info by default (unless "include"d otherwise)
|
||||||
return getFolderOrDocument(fInfo.getNodeRef(), parentNodeRef, fInfo.getType(), includeParam, mapUserInfo);
|
return getFolderOrDocument(fInfo.getNodeRef(), parentNodeRef, fInfo.getType(), includeParam, mapUserInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -24,6 +24,7 @@ import org.alfresco.query.PagingRequest;
|
|||||||
import org.alfresco.rest.api.Nodes;
|
import org.alfresco.rest.api.Nodes;
|
||||||
import org.alfresco.rest.api.Queries;
|
import org.alfresco.rest.api.Queries;
|
||||||
import org.alfresco.rest.api.model.Node;
|
import org.alfresco.rest.api.model.Node;
|
||||||
|
import org.alfresco.rest.api.model.UserInfo;
|
||||||
import org.alfresco.rest.framework.core.exceptions.EntityNotFoundException;
|
import org.alfresco.rest.framework.core.exceptions.EntityNotFoundException;
|
||||||
import org.alfresco.rest.framework.core.exceptions.InvalidArgumentException;
|
import org.alfresco.rest.framework.core.exceptions.InvalidArgumentException;
|
||||||
import org.alfresco.rest.framework.core.exceptions.NotFoundException;
|
import org.alfresco.rest.framework.core.exceptions.NotFoundException;
|
||||||
@@ -221,10 +222,16 @@ public class QueriesImpl implements Queries, InitializingBean
|
|||||||
|
|
||||||
List<Node> nodeList = new ArrayList<>(results.length());
|
List<Node> nodeList = new ArrayList<>(results.length());
|
||||||
|
|
||||||
|
final Map<String, UserInfo> mapUserInfo = new HashMap<>(10);
|
||||||
|
|
||||||
|
List<String> includeParam = parameters.getInclude();
|
||||||
|
|
||||||
for (ResultSetRow row : results)
|
for (ResultSetRow row : results)
|
||||||
{
|
{
|
||||||
NodeRef nodeRef = row.getNodeRef();
|
NodeRef nodeRef = row.getNodeRef();
|
||||||
nodeList.add(nodes.getFolderOrDocument(nodeRef.getId(), parameters));
|
|
||||||
|
// minimal info by default (unless "include"d otherwise)
|
||||||
|
nodeList.add(nodes.getFolderOrDocument(nodeRef, null, null, includeParam, mapUserInfo));
|
||||||
}
|
}
|
||||||
|
|
||||||
results.close();
|
results.close();
|
||||||
|
@@ -20,11 +20,16 @@ package org.alfresco.rest.api.tests;
|
|||||||
|
|
||||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||||
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
import org.alfresco.repo.transaction.RetryingTransactionHelper.RetryingTransactionCallback;
|
||||||
|
import org.alfresco.rest.api.Nodes;
|
||||||
import org.alfresco.rest.api.Queries;
|
import org.alfresco.rest.api.Queries;
|
||||||
import org.alfresco.rest.api.tests.client.HttpResponse;
|
import org.alfresco.rest.api.tests.client.HttpResponse;
|
||||||
|
import org.alfresco.rest.api.tests.client.PublicApiClient;
|
||||||
import org.alfresco.rest.api.tests.client.PublicApiClient.Paging;
|
import org.alfresco.rest.api.tests.client.PublicApiClient.Paging;
|
||||||
|
import org.alfresco.rest.api.tests.client.RequestContext;
|
||||||
import org.alfresco.rest.api.tests.client.data.Document;
|
import org.alfresco.rest.api.tests.client.data.Document;
|
||||||
|
import org.alfresco.rest.api.tests.client.data.Folder;
|
||||||
import org.alfresco.rest.api.tests.client.data.Node;
|
import org.alfresco.rest.api.tests.client.data.Node;
|
||||||
|
import org.alfresco.rest.api.tests.client.data.Tag;
|
||||||
import org.alfresco.rest.api.tests.util.RestApiUtil;
|
import org.alfresco.rest.api.tests.util.RestApiUtil;
|
||||||
import org.alfresco.service.cmr.security.MutableAuthenticationService;
|
import org.alfresco.service.cmr.security.MutableAuthenticationService;
|
||||||
import org.alfresco.service.cmr.security.PersonService;
|
import org.alfresco.service.cmr.security.PersonService;
|
||||||
@@ -125,13 +130,13 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests api for nodes live search
|
* Tests basic api for nodes live search - metadata (name, title, description) &/or full text search of file/content
|
||||||
*
|
*
|
||||||
* <p>GET:</p>
|
* <p>GET:</p>
|
||||||
* {@literal <host>:<port>/alfresco/api/<networkId>/public/alfresco/versions/1/queries/live-search-nodes}
|
* {@literal <host>:<port>/alfresco/api/<networkId>/public/alfresco/versions/1/queries/live-search-nodes}
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void testLiveSearchNodes() throws Exception
|
public void testLiveSearchNodes_FTS_and_Metadata() throws Exception
|
||||||
{
|
{
|
||||||
int f1Count = 5;
|
int f1Count = 5;
|
||||||
List<String> f1NodeIds = new ArrayList<>(f1Count);
|
List<String> f1NodeIds = new ArrayList<>(f1Count);
|
||||||
@@ -145,7 +150,7 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
int totalCount = f1Count + f2Count + f3Count;
|
int totalCount = f1Count + f2Count + f3Count;
|
||||||
List<String> allIds = new ArrayList<>(totalCount);
|
List<String> allIds = new ArrayList<>(totalCount);
|
||||||
|
|
||||||
String testTerm = "abc123";
|
String testTerm = "abc123basic";
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@@ -205,11 +210,11 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
String num = String.format("%05d", nameIdx);
|
String num = String.format("%05d", nameIdx);
|
||||||
String docName = name+num+name;
|
String docName = name+num+name;
|
||||||
|
|
||||||
Map<String,String> docProps = new HashMap<>(2);
|
Map<String, String> props = new HashMap<>(2);
|
||||||
docProps.put("cm:title", title+num+title);
|
props.put("cm:title", title+num+title);
|
||||||
docProps.put("cm:description", descrip+num+descrip);
|
props.put("cm:description", descrip+num+descrip);
|
||||||
|
|
||||||
Document doc = createTextFile(user1, f2Id, docName, contentText, "UTF-8", docProps);
|
Document doc = createTextFile(user1, f2Id, docName, contentText, "UTF-8", props);
|
||||||
|
|
||||||
f2NodeIds.add(doc.getId());
|
f2NodeIds.add(doc.getId());
|
||||||
idNameMap.put(doc.getId(), docName);
|
idNameMap.put(doc.getId(), docName);
|
||||||
@@ -224,7 +229,11 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
String num = String.format("%05d", nameIdx);
|
String num = String.format("%05d", nameIdx);
|
||||||
String folderName = name+num+name+folderNameSuffix;
|
String folderName = name+num+name+folderNameSuffix;
|
||||||
|
|
||||||
Node node = createFolder(user1, myFolderNodeId, folderName);
|
Map<String, Object> props = new HashMap<>(2);
|
||||||
|
props.put("cm:title", title+num+title);
|
||||||
|
props.put("cm:description", descrip+num+descrip);
|
||||||
|
|
||||||
|
Node node = createFolder(user1, myFolderNodeId, folderName, props);
|
||||||
|
|
||||||
f3NodeIds.add(node.getId());
|
f3NodeIds.add(node.getId());
|
||||||
idNameMap.put(node.getId(), folderName);
|
idNameMap.put(node.getId(), folderName);
|
||||||
@@ -232,25 +241,6 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
nameIdx--;
|
nameIdx--;
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> idsSortedByNameAsc = new ArrayList<>(sortByValue(idNameMap).keySet());
|
|
||||||
|
|
||||||
List<String> idsSortedByNameDescCreatedAtAsc = new ArrayList<>(totalCount);
|
|
||||||
for (int i = 0; i < totalCount; i++)
|
|
||||||
{
|
|
||||||
if (i < f1Count)
|
|
||||||
{
|
|
||||||
idsSortedByNameDescCreatedAtAsc.add(f1NodeIds.get(i));
|
|
||||||
}
|
|
||||||
if (i < f2Count)
|
|
||||||
{
|
|
||||||
idsSortedByNameDescCreatedAtAsc.add(f2NodeIds.get(i));
|
|
||||||
}
|
|
||||||
if (i < f3Count)
|
|
||||||
{
|
|
||||||
idsSortedByNameDescCreatedAtAsc.add(f3NodeIds.get(i));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
allIds.addAll(idNameMap.keySet());
|
allIds.addAll(idNameMap.keySet());
|
||||||
|
|
||||||
//
|
//
|
||||||
@@ -263,6 +253,28 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
checkNodeIds(nodes, allIds, null);
|
checkNodeIds(nodes, allIds, null);
|
||||||
|
for (Node node : nodes)
|
||||||
|
{
|
||||||
|
assertNull(node.getAspectNames());
|
||||||
|
assertNull(node.getProperties());
|
||||||
|
assertNull(node.getPath());
|
||||||
|
assertNull(node.getIsLink());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Search - include optional fields - eg. aspectNames, properties, path, isLink
|
||||||
|
params = new HashMap<>(2);
|
||||||
|
params.put(Queries.PARAM_TERM, testTerm);
|
||||||
|
params.put("include", "aspectNames,properties,path,isLink");
|
||||||
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
|
checkNodeIds(nodes, allIds, null);
|
||||||
|
for (Node node : nodes)
|
||||||
|
{
|
||||||
|
assertNotNull(node.getAspectNames());
|
||||||
|
assertNotNull(node.getProperties());
|
||||||
|
assertNotNull(node.getPath());
|
||||||
|
assertNotNull(node.getIsLink());
|
||||||
|
}
|
||||||
|
|
||||||
// Search hits restricted by node type
|
// Search hits restricted by node type
|
||||||
params = new HashMap<>(2);
|
params = new HashMap<>(2);
|
||||||
@@ -309,31 +321,163 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
|
|
||||||
// Search hits based on cm:title
|
// Search hits based on cm:title
|
||||||
term = title+String.format("%05d", 2)+title;
|
term = title+String.format("%05d", 2)+title;
|
||||||
params = new HashMap<>(1);
|
params = new HashMap<>(2);
|
||||||
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
||||||
|
params.put("include", "properties");
|
||||||
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
assertEquals(2, nodes.size());
|
assertEquals(3, nodes.size());
|
||||||
assertEquals(term, nodes.get(0).getProperties().get("cm:title"));
|
assertEquals(term, nodes.get(0).getProperties().get("cm:title"));
|
||||||
assertEquals(term, nodes.get(1).getProperties().get("cm:title"));
|
assertEquals(term, nodes.get(1).getProperties().get("cm:title"));
|
||||||
|
assertEquals(term, nodes.get(2).getProperties().get("cm:title"));
|
||||||
|
|
||||||
// Search hits based on cm:description
|
// Search hits based on cm:description
|
||||||
term = descrip+String.format("%05d", 3)+descrip;
|
term = descrip+String.format("%05d", 3)+descrip;
|
||||||
params = new HashMap<>(1);
|
params = new HashMap<>(2);
|
||||||
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
||||||
|
params.put("include", "properties");
|
||||||
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
assertEquals(2, nodes.size());
|
assertEquals(3, nodes.size());
|
||||||
assertEquals(term, nodes.get(0).getProperties().get("cm:description"));
|
assertEquals(term, nodes.get(0).getProperties().get("cm:description"));
|
||||||
assertEquals(term, nodes.get(1).getProperties().get("cm:description"));
|
assertEquals(term, nodes.get(1).getProperties().get("cm:description"));
|
||||||
|
assertEquals(term, nodes.get(2).getProperties().get("cm:description"));
|
||||||
|
|
||||||
|
// TODO sanity check tag search
|
||||||
|
|
||||||
|
// -ve test - no params (ie. no term)
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, null, 400);
|
||||||
|
|
||||||
|
// -ve test - no term
|
||||||
|
params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_ROOT_NODE_ID, f1Id);
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
||||||
|
|
||||||
|
// -ve test - unknown root node id
|
||||||
|
params = new HashMap<>(2);
|
||||||
|
params.put(Queries.PARAM_TERM, "abc");
|
||||||
|
params.put(Queries.PARAM_ROOT_NODE_ID, "dummy");
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, params, 404);
|
||||||
|
|
||||||
|
// -ve test - unknown node type
|
||||||
|
params = new HashMap<>(2);
|
||||||
|
params.put(Queries.PARAM_TERM, "abc");
|
||||||
|
params.put(Queries.PARAM_NODE_TYPE, "cm:dummy");
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
||||||
|
|
||||||
|
// -ve test - term too short
|
||||||
|
params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, "ab");
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
||||||
|
|
||||||
|
// -ve test - term is still too short
|
||||||
|
params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, " \"a b *\" ");
|
||||||
|
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
||||||
|
|
||||||
|
// -ve test - unauthenticated - belts-and-braces ;-)
|
||||||
|
getAll(URL_QUERIES_LSN, null, paging, params, 401);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
// some cleanup
|
||||||
|
for (String docId : allIds)
|
||||||
|
{
|
||||||
|
delete(URL_NODES, user1, docId, 204);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLiveSearchNodes_SortPage() throws Exception
|
||||||
|
{
|
||||||
|
int f1Count = 5;
|
||||||
|
List<String> f1NodeIds = new ArrayList<>(f1Count);
|
||||||
|
|
||||||
|
int f2Count = 3;
|
||||||
|
List<String> f2NodeIds = new ArrayList<>(f2Count);
|
||||||
|
|
||||||
|
int totalCount = f1Count + f2Count;
|
||||||
|
List<String> allIds = new ArrayList<>(totalCount);
|
||||||
|
|
||||||
|
String testTerm = "def456sortpage";
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// As user 1 ...
|
||||||
|
|
||||||
|
Paging paging = getPaging(0, 100);
|
||||||
|
|
||||||
|
Map<String, String> params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, testTerm);
|
||||||
|
|
||||||
|
String myFolderNodeId = getMyNodeId(user1);
|
||||||
|
|
||||||
|
String f1Id = createFolder(user1, myFolderNodeId, "folder sort 1").getId();
|
||||||
|
String f2Id = createFolder(user1, myFolderNodeId, "folder sort 2").getId();
|
||||||
|
|
||||||
|
String name = "name";
|
||||||
|
|
||||||
|
Map<String,String> idNameMap = new HashMap<>();
|
||||||
|
|
||||||
|
int nameIdx = f1Count;
|
||||||
|
for (int i = 1; i <= f1Count; i++)
|
||||||
|
{
|
||||||
|
// create doc - in folder 1
|
||||||
|
String contentText = "f1 " + testTerm + " test document " + user1 + " document " + i;
|
||||||
|
|
||||||
|
String num = String.format("%05d", nameIdx);
|
||||||
|
String docName = name+num+name;
|
||||||
|
|
||||||
|
Document doc = createTextFile(user1, f1Id, docName, contentText, "UTF-8", null);
|
||||||
|
|
||||||
|
f1NodeIds.add(doc.getId());
|
||||||
|
idNameMap.put(doc.getId(), docName);
|
||||||
|
|
||||||
|
nameIdx--;
|
||||||
|
}
|
||||||
|
|
||||||
|
nameIdx = f2Count;
|
||||||
|
for (int i = 1; i <= f2Count; i++)
|
||||||
|
{
|
||||||
|
// create doc - in folder 2
|
||||||
|
String contentText = "f2 " + testTerm + " test document";
|
||||||
|
|
||||||
|
String num = String.format("%05d", nameIdx);
|
||||||
|
String docName = name+num+name;
|
||||||
|
|
||||||
|
Document doc = createTextFile(user1, f2Id, docName, contentText, "UTF-8", null);
|
||||||
|
|
||||||
|
f2NodeIds.add(doc.getId());
|
||||||
|
idNameMap.put(doc.getId(), docName);
|
||||||
|
|
||||||
|
nameIdx--;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<String> idsSortedByNameAsc = new ArrayList<>(sortByValue(idNameMap).keySet());
|
||||||
|
|
||||||
|
List<String> idsSortedByNameDescCreatedAtAsc = new ArrayList<>(totalCount);
|
||||||
|
for (int i = 0; i < totalCount; i++)
|
||||||
|
{
|
||||||
|
if (i < f1Count)
|
||||||
|
{
|
||||||
|
idsSortedByNameDescCreatedAtAsc.add(f1NodeIds.get(i));
|
||||||
|
}
|
||||||
|
if (i < f2Count)
|
||||||
|
{
|
||||||
|
idsSortedByNameDescCreatedAtAsc.add(f2NodeIds.get(i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
allIds.addAll(idNameMap.keySet());
|
||||||
|
|
||||||
// test sort order
|
// test sort order
|
||||||
|
|
||||||
// default sort order (modifiedAt desc)
|
// default sort order (modifiedAt desc)
|
||||||
params = new HashMap<>(1);
|
params = new HashMap<>(1);
|
||||||
params.put(Queries.PARAM_TERM, testTerm);
|
params.put(Queries.PARAM_TERM, testTerm);
|
||||||
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
HttpResponse response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
List<Node> nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
checkNodeIds(nodes, allIds, false);
|
checkNodeIds(nodes, allIds, false);
|
||||||
|
|
||||||
// sort order - modifiedAt asc
|
// sort order - modifiedAt asc
|
||||||
@@ -424,46 +568,8 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
checkNodeIds(nodes, f2NodeIds, false);
|
checkNodeIds(nodes, f2NodeIds, false);
|
||||||
|
|
||||||
paging = getPaging(f2Count, f3Count);
|
|
||||||
params = new HashMap<>(1);
|
|
||||||
params.put(Queries.PARAM_TERM, testTerm);
|
|
||||||
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
|
||||||
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
||||||
checkNodeIds(nodes, f3NodeIds, false);
|
|
||||||
|
|
||||||
// TODO sanity check modifiedAt (for now modifiedAt=createdAt)
|
// TODO sanity check modifiedAt (for now modifiedAt=createdAt)
|
||||||
// TODO sanity check tag search
|
|
||||||
// TODO sanity check optional "include" ... eg. path
|
|
||||||
|
|
||||||
// -ve test - no params (ie. no term)
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, null, 400);
|
|
||||||
|
|
||||||
// -ve test - no term
|
|
||||||
params = new HashMap<>(1);
|
|
||||||
params.put(Queries.PARAM_ROOT_NODE_ID, f1Id);
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
|
||||||
|
|
||||||
// -ve test - unknown root node id
|
|
||||||
params = new HashMap<>(2);
|
|
||||||
params.put(Queries.PARAM_TERM, "abc");
|
|
||||||
params.put(Queries.PARAM_ROOT_NODE_ID, "dummy");
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, params, 404);
|
|
||||||
|
|
||||||
// -ve test - unknown node type
|
|
||||||
params = new HashMap<>(2);
|
|
||||||
params.put(Queries.PARAM_TERM, "abc");
|
|
||||||
params.put(Queries.PARAM_NODE_TYPE, "cm:dummy");
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
|
||||||
|
|
||||||
// -ve test - term too short
|
|
||||||
params = new HashMap<>(1);
|
|
||||||
params.put(Queries.PARAM_TERM, "ab");
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
|
||||||
|
|
||||||
// -ve test - term is still too short
|
|
||||||
params = new HashMap<>(1);
|
|
||||||
params.put(Queries.PARAM_TERM, " \"a b *\" ");
|
|
||||||
getAll(URL_QUERIES_LSN, user1, paging, params, 400);
|
|
||||||
|
|
||||||
// -ve test - invalid sort field
|
// -ve test - invalid sort field
|
||||||
params = new HashMap<>(2);
|
params = new HashMap<>(2);
|
||||||
@@ -484,6 +590,99 @@ public class QueriesApiTest extends AbstractBaseApiTest
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLiveSearchNodes_Tags() throws Exception
|
||||||
|
{
|
||||||
|
PublicApiClient.Nodes nodesProxy = publicApiClient.nodes();
|
||||||
|
|
||||||
|
int f1Count = 5;
|
||||||
|
List<String> f1NodeIds = new ArrayList<>(f1Count);
|
||||||
|
|
||||||
|
int f2Count = 3;
|
||||||
|
List<String> f2NodeIds = new ArrayList<>(f2Count);
|
||||||
|
|
||||||
|
int totalCount = f1Count + f2Count;
|
||||||
|
List<String> allIds = new ArrayList<>(totalCount);
|
||||||
|
|
||||||
|
String testTag = "ghi789tag";
|
||||||
|
String testFileTag = "ghi789file";
|
||||||
|
String testFolderTag = "ghi789folder";
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// As user 1 ...
|
||||||
|
|
||||||
|
Paging paging = getPaging(0, 100);
|
||||||
|
|
||||||
|
String f1Id = createFolder(user1, Nodes.PATH_MY, "folder tag 1").getId();
|
||||||
|
String f2Id = createFolder(user1, Nodes.PATH_MY, "folder tag 2").getId();
|
||||||
|
|
||||||
|
String name = "name";
|
||||||
|
|
||||||
|
for (int i = 1; i <= f1Count; i++)
|
||||||
|
{
|
||||||
|
// create doc - in folder 1
|
||||||
|
String contentText = "f1 test document " + user1 + " document " + i;
|
||||||
|
String docName = name+i;
|
||||||
|
|
||||||
|
Document doc = createTextFile(user1, f1Id, docName, contentText, "UTF-8", null);
|
||||||
|
|
||||||
|
publicApiClient.setRequestContext(new RequestContext("", user1));
|
||||||
|
|
||||||
|
nodesProxy.createNodeTag(doc.getId(), new Tag(testTag)); // ignore result
|
||||||
|
nodesProxy.createNodeTag(doc.getId(), new Tag(testFileTag)); // ignore result
|
||||||
|
|
||||||
|
f1NodeIds.add(doc.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 1; i <= f2Count; i++)
|
||||||
|
{
|
||||||
|
// create folder - in folder 2
|
||||||
|
String folderName = name+i;
|
||||||
|
|
||||||
|
Folder folder = createFolder(user1, f2Id, folderName, null);
|
||||||
|
|
||||||
|
publicApiClient.setRequestContext(new RequestContext("", user1));
|
||||||
|
|
||||||
|
nodesProxy.createNodeTag(folder.getId(), new Tag(testTag)); // ignore result
|
||||||
|
nodesProxy.createNodeTag(folder.getId(), new Tag(testFolderTag)); // ignore result
|
||||||
|
|
||||||
|
f2NodeIds.add(folder.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
allIds.addAll(f1NodeIds);
|
||||||
|
allIds.addAll(f2NodeIds);
|
||||||
|
|
||||||
|
// Search hits based on tag
|
||||||
|
|
||||||
|
Map<String, String> params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, testTag);
|
||||||
|
HttpResponse response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
|
List<Node> nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
|
checkNodeIds(nodes, allIds, null);
|
||||||
|
|
||||||
|
params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, testFileTag);
|
||||||
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
|
checkNodeIds(nodes, f1NodeIds, null);
|
||||||
|
|
||||||
|
params = new HashMap<>(1);
|
||||||
|
params.put(Queries.PARAM_TERM, testFolderTag);
|
||||||
|
response = getAll(URL_QUERIES_LSN, user1, paging, params, 200);
|
||||||
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
||||||
|
checkNodeIds(nodes, f2NodeIds, null);
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
// some cleanup
|
||||||
|
for (String nodeId : allIds)
|
||||||
|
{
|
||||||
|
delete(URL_NODES, user1, nodeId, 204);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void checkNodeIds(List<Node> nodes, List<String> nodeIds, Boolean asc)
|
private void checkNodeIds(List<Node> nodes, List<String> nodeIds, Boolean asc)
|
||||||
{
|
{
|
||||||
assertEquals(nodeIds.size(), nodes.size());
|
assertEquals(nodeIds.size(), nodes.size());
|
||||||
|
Reference in New Issue
Block a user