mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
- Changes to end points to reflect the rename of: /queries/live-search-nodes to /queries/nodes /queries/live-search-people to /queries/people /queries/live-search-sites to /queries/sites git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@129252 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
730 lines
28 KiB
Java
730 lines
28 KiB
Java
/*
|
|
* #%L
|
|
* Alfresco Remote API
|
|
* %%
|
|
* Copyright (C) 2005 - 2016 Alfresco Software Limited
|
|
* %%
|
|
* This file is part of the Alfresco software.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
* #L%
|
|
*/
|
|
package org.alfresco.rest.api.tests;
|
|
|
|
import org.alfresco.rest.AbstractSingleNetworkSiteTest;
|
|
import org.alfresco.rest.api.Nodes;
|
|
import org.alfresco.rest.api.Queries;
|
|
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.RequestContext;
|
|
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.Tag;
|
|
import org.alfresco.rest.api.tests.util.RestApiUtil;
|
|
import org.junit.Test;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
import java.util.Comparator;
|
|
import java.util.HashMap;
|
|
import java.util.LinkedHashMap;
|
|
import java.util.LinkedList;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
import static org.junit.Assert.*;
|
|
|
|
/**
|
|
* V1 REST API tests for pre-defined 'live' search Queries on Nodes
|
|
*
|
|
* <ul>
|
|
* <li> {@literal <host>:<port>/alfresco/api/<networkId>/public/alfresco/versions/1/queries/nodes} </li>
|
|
* </ul>
|
|
*
|
|
* @author janv
|
|
*/
|
|
public class QueriesNodesApiTest extends AbstractSingleNetworkSiteTest
|
|
{
|
|
private static final String URL_QUERIES_LSN = "queries/nodes";
|
|
|
|
public static <K, V extends Comparable<? super V>> Map<K, V> sortByValue( Map<K, V> map )
|
|
{
|
|
List<Map.Entry<K, V>> list =
|
|
new LinkedList<>( map.entrySet() );
|
|
Collections.sort( list, new Comparator<Map.Entry<K, V>>()
|
|
{
|
|
public int compare( Map.Entry<K, V> o1, Map.Entry<K, V> o2 )
|
|
{
|
|
return (o1.getValue()).compareTo( o2.getValue() );
|
|
}
|
|
} );
|
|
|
|
Map<K, V> result = new LinkedHashMap<>();
|
|
for (Map.Entry<K, V> entry : list)
|
|
{
|
|
result.put( entry.getKey(), entry.getValue() );
|
|
}
|
|
return result;
|
|
}
|
|
|
|
/**
|
|
* Tests basic api for nodes live search - metadata (name, title, description) &/or full text search of file/content
|
|
*
|
|
* <p>GET:</p>
|
|
* {@literal <host>:<port>/alfresco/api/<networkId>/public/alfresco/versions/1/queries/nodes}
|
|
*/
|
|
@Test
|
|
public void testLiveSearchNodes_FTS_and_Metadata() throws Exception
|
|
{
|
|
setRequestContext(user1);
|
|
|
|
int f1Count = 5;
|
|
List<String> f1NodeIds = new ArrayList<>(f1Count);
|
|
|
|
int f2Count = 3;
|
|
List<String> f2NodeIds = new ArrayList<>(f2Count);
|
|
|
|
int f3Count = 4;
|
|
List<String> f3NodeIds = new ArrayList<>(f3Count);
|
|
|
|
int totalCount = f1Count + f2Count + f3Count;
|
|
List<String> allIds = new ArrayList<>(totalCount);
|
|
|
|
String testTerm = "abc123basic";
|
|
|
|
try
|
|
{
|
|
// As user 1 ...
|
|
|
|
Paging paging = getPaging(0, 100);
|
|
|
|
Map<String, String> params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
|
|
// Try to get nodes with search term 'abc123' - assume clean repo (ie. none to start with)
|
|
HttpResponse response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
List<Node> nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(0, nodes.size());
|
|
|
|
String myFolderNodeId = getMyNodeId();
|
|
|
|
String f1Id = createFolder(myFolderNodeId, "folder 1").getId();
|
|
String f2Id = createFolder(myFolderNodeId, "folder 2").getId();
|
|
|
|
String name = "name";
|
|
String title = "title";
|
|
String descrip = "descrip";
|
|
|
|
String folderNameSuffix = " "+testTerm+" folder";
|
|
String txtSuffix = ".txt";
|
|
|
|
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+txtSuffix;
|
|
|
|
Map<String,String> docProps = new HashMap<>(2);
|
|
docProps.put("cm:title", title+num+title);
|
|
docProps.put("cm:description", descrip+num+descrip);
|
|
|
|
Document doc = createTextFile(f1Id, docName, contentText, "UTF-8", docProps);
|
|
|
|
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+txtSuffix;
|
|
|
|
Map<String, String> props = new HashMap<>(2);
|
|
props.put("cm:title", title+num+title);
|
|
props.put("cm:description", descrip+num+descrip);
|
|
|
|
Document doc = createTextFile(f2Id, docName, contentText, "UTF-8", props);
|
|
|
|
f2NodeIds.add(doc.getId());
|
|
idNameMap.put(doc.getId(), docName);
|
|
|
|
nameIdx--;
|
|
}
|
|
|
|
nameIdx = f3Count;
|
|
for (int i = 1; i <= f3Count; i++)
|
|
{
|
|
// create folders - in folder 3
|
|
String num = String.format("%05d", nameIdx);
|
|
String folderName = name+num+name+folderNameSuffix;
|
|
|
|
Map<String, Object> props = new HashMap<>(2);
|
|
props.put("cm:title", title+num+title);
|
|
props.put("cm:description", descrip+num+descrip);
|
|
|
|
Node node = createFolder(myFolderNodeId, folderName, props);
|
|
|
|
f3NodeIds.add(node.getId());
|
|
idNameMap.put(node.getId(), folderName);
|
|
|
|
nameIdx--;
|
|
}
|
|
|
|
allIds.addAll(idNameMap.keySet());
|
|
|
|
//
|
|
// find nodes
|
|
//
|
|
|
|
// Search hits based on FTS (content) and also name (in case of folder nodes)
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
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(Queries.PARAM_INCLUDE, "aspectNames,properties,path,isLink");
|
|
response = getAll(URL_QUERIES_LSN, 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
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_NODE_TYPE, "cm:folder");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f3NodeIds, null);
|
|
|
|
// Search - with -root- as the root node (for path-based / in-tree search)
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, Nodes.PATH_ROOT);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, null);
|
|
|
|
// Search - with -shared- as the root node (for path-based / in-tree search)
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, Nodes.PATH_SHARED);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(0, nodes.size());
|
|
|
|
// Search - with folder 1 as root node (for path-based / in-tree search)
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, f1Id);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f1NodeIds, null);
|
|
|
|
// Search - with folder 2 as the root node (for path-based / in-tree search)
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, f2Id);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f2NodeIds, null);
|
|
|
|
// Search - with -my- as the root node (for path-based / in-tree search)
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, name+"*");
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, Nodes.PATH_MY);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, null);
|
|
|
|
// Search hits based on cm:name
|
|
String term = name+String.format("%05d", 1)+name;
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(3, nodes.size());
|
|
for (Node node : nodes)
|
|
{
|
|
if (node.getIsFolder())
|
|
{
|
|
assertEquals(term+folderNameSuffix, node.getName());
|
|
}
|
|
else
|
|
{
|
|
assertEquals(term+txtSuffix, node.getName());
|
|
}
|
|
}
|
|
|
|
// search for name with . (eg. ".txt") without double quotes
|
|
term = name+String.format("%05d", 1)+name+txtSuffix;
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, term);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(2, nodes.size());
|
|
|
|
// search for name with . (eg. ".txt") with double quotes
|
|
term = name+String.format("%05d", 1)+name+txtSuffix;
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(2, nodes.size());
|
|
|
|
// Search hits based on cm:title
|
|
term = title+String.format("%05d", 2)+title;
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
|
params.put(Queries.PARAM_INCLUDE, "properties");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(3, nodes.size());
|
|
assertEquals(term, nodes.get(0).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
|
|
term = descrip+String.format("%05d", 3)+descrip;
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, "\""+term+"\"");
|
|
params.put(Queries.PARAM_INCLUDE, "properties");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
assertEquals(3, nodes.size());
|
|
assertEquals(term, nodes.get(0).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, paging, null, 400);
|
|
|
|
// -ve test - no term
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_ROOT_NODE_ID, f1Id);
|
|
getAll(URL_QUERIES_LSN, 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, 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, paging, params, 400);
|
|
|
|
// -ve test - term too short
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, "ab");
|
|
getAll(URL_QUERIES_LSN, 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, paging, params, 400);
|
|
|
|
// -ve test - unauthenticated - belts-and-braces ;-)
|
|
setRequestContext(null);
|
|
getAll(URL_QUERIES_LSN, paging, params, 401);
|
|
}
|
|
finally
|
|
{
|
|
// some cleanup
|
|
setRequestContext(user1);
|
|
for (String docId : allIds)
|
|
{
|
|
deleteNode(docId, true, 204);
|
|
}
|
|
}
|
|
}
|
|
|
|
@Test
|
|
public void testLiveSearchNodes_SortPage() throws Exception
|
|
{
|
|
setRequestContext(user1);
|
|
|
|
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();
|
|
|
|
String f1Id = createFolder(myFolderNodeId, "folder sort 1").getId();
|
|
String f2Id = createFolder(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+".txt";
|
|
|
|
Document doc = createTextFile(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+".txt";
|
|
|
|
Document doc = createTextFile(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
|
|
|
|
// default sort order (modifiedAt desc)
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
HttpResponse response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
List<Node> nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, false);
|
|
|
|
// sort order - modifiedAt asc
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "modifiedAt asc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, false);
|
|
|
|
// sort order - modifiedAt desc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "modifiedAt desc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, true);
|
|
|
|
// sort order - createdAt asc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "createdAt asc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, true);
|
|
|
|
// sort order - createdAt desc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "createdAt desc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, false);
|
|
|
|
// sort order - name asc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "name asc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, idsSortedByNameAsc, true);
|
|
|
|
// sort order - name desc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "name desc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, idsSortedByNameAsc, false);
|
|
|
|
// sort order - name desc, createdAt asc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "name desc, createdAt asc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, idsSortedByNameDescCreatedAtAsc, false);
|
|
|
|
// sort order - name asc, createdAt asc
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "name asc, createdAt desc");
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, idsSortedByNameDescCreatedAtAsc, true);
|
|
|
|
// basic paging test
|
|
|
|
paging = getPaging(0, 100);
|
|
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, allIds, false);
|
|
|
|
paging = getPaging(0, f1Count);
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f1NodeIds, false);
|
|
|
|
paging = getPaging(f1Count, f2Count);
|
|
params = new HashMap<>(1);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
response = getAll(URL_QUERIES_LSN, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f2NodeIds, false);
|
|
|
|
|
|
// TODO sanity check modifiedAt (for now modifiedAt=createdAt)
|
|
|
|
// -ve test - invalid sort field
|
|
params = new HashMap<>(2);
|
|
params.put(Queries.PARAM_TERM, testTerm);
|
|
params.put(Queries.PARAM_ORDERBY, "invalid asc");
|
|
getAll(URL_QUERIES_LSN, paging, params, 400);
|
|
|
|
// -ve test - unauthenticated - belts-and-braces ;-)
|
|
setRequestContext(null);
|
|
getAll(URL_QUERIES_LSN, paging, params, 401);
|
|
}
|
|
finally
|
|
{
|
|
// some cleanup
|
|
setRequestContext(user1);
|
|
for (String docId : allIds)
|
|
{
|
|
deleteNode(docId, true, 204);
|
|
}
|
|
}
|
|
}
|
|
|
|
@Test
|
|
public void testLiveSearchNodes_Tags() throws Exception
|
|
{
|
|
setRequestContext(user1);
|
|
|
|
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(Nodes.PATH_MY, "folder tag 1").getId();
|
|
String f2Id = createFolder(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(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(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, 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, 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, paging, params, 200);
|
|
nodes = RestApiUtil.parseRestApiEntries(response.getJsonResponse(), Node.class);
|
|
checkNodeIds(nodes, f2NodeIds, null);
|
|
}
|
|
finally
|
|
{
|
|
// some cleanup
|
|
setRequestContext(user1);
|
|
for (String nodeId : allIds)
|
|
{
|
|
deleteNode(nodeId, true, 204);
|
|
}
|
|
}
|
|
}
|
|
|
|
private void checkNodeIds(List<Node> nodes, List<String> nodeIds, Boolean asc)
|
|
{
|
|
assertEquals(nodeIds.size(), nodes.size());
|
|
|
|
if (asc == null)
|
|
{
|
|
// ignore order
|
|
for (Node node : nodes)
|
|
{
|
|
assertTrue(nodeIds.contains(node.getId()));
|
|
}
|
|
}
|
|
else if (asc)
|
|
{
|
|
int i = 0;
|
|
for (Node node : nodes)
|
|
{
|
|
nodeIds.get(i).equals(node.getId());
|
|
i++;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
int i = nodeIds.size() - 1;
|
|
for (Node node : nodes)
|
|
{
|
|
nodeIds.get(i).equals(node.getId());
|
|
i--;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
@Override
|
|
public String getScope()
|
|
{
|
|
return "public";
|
|
}
|
|
}
|