RM-5416: REST API Tests for Folder Classification - removing the v0 search

This commit is contained in:
jcule
2017-09-22 14:50:19 +01:00
parent 51135a83c0
commit d11d477d04

View File

@@ -27,14 +27,11 @@
package org.alfresco.rest.v0; package org.alfresco.rest.v0;
import java.io.IOException;
import java.nio.charset.Charset;
import java.text.MessageFormat; import java.text.MessageFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import org.alfresco.dataprep.AlfrescoHttpClient;
import org.alfresco.dataprep.AlfrescoHttpClientFactory; import org.alfresco.dataprep.AlfrescoHttpClientFactory;
import org.alfresco.rest.core.v0.BaseAPI; import org.alfresco.rest.core.v0.BaseAPI;
import org.apache.http.NameValuePair; import org.apache.http.NameValuePair;
@@ -54,10 +51,8 @@ import org.springframework.stereotype.Component;
public class SearchAPI extends BaseAPI public class SearchAPI extends BaseAPI
{ {
/** http client factory */ /** http client factory */
@Autowired private AlfrescoHttpClientFactory alfrescoHttpClientFactory; @Autowired
private AlfrescoHttpClientFactory alfrescoHttpClientFactory;
/** search API endpoint */
private static final String SEARCH_ENDPOINT = "{0}alfresco/s/slingshot/search?{1}";
/** faceted search API endpoint */ /** faceted search API endpoint */
private static final String FACETED_SEARCH_ENDPOINT = "{0}alfresco/s/slingshot/rmsearch/faceted/rmsearch?{1}"; private static final String FACETED_SEARCH_ENDPOINT = "{0}alfresco/s/slingshot/rmsearch/faceted/rmsearch?{1}";
@@ -66,28 +61,26 @@ public class SearchAPI extends BaseAPI
private static final String RM_SEARCH_ENDPOINT = "{0}alfresco/s/slingshot/rmsearch/{1}?{2}"; private static final String RM_SEARCH_ENDPOINT = "{0}alfresco/s/slingshot/rmsearch/{1}?{2}";
/** RM document search filters */ /** RM document search filters */
private static final String RM_DEFAULT_RECORD_FILTERS = private static final String RM_DEFAULT_RECORD_FILTERS = "records/true,undeclared/true,vital/false,folders/false,categories/false,frozen/false,cutoff/false";
"records/true,undeclared/true,vital/false,folders/false,categories/false,frozen/false,cutoff/false";
/** /**
* Perform search request on search endpoint as a user. * Perform search request on search endpoint as a user.
* <p> * <p>
* This method is applicable only to endpoints that support HTTP GET requests and return JSON body as response. * This method is applicable only to endpoints that support HTTP GET requests and return JSON body as response.
*
* @param searchEndpoint * @param searchEndpoint
* @param searchUser * @param searchUser
* @param searchPassword * @param searchPassword
* @return search results as a {@link JSONObject}, please refer to API documentation for details * @return search results as a {@link JSONObject}, please refer to API documentation for details
*/ */
private JSONObject doSearch( private JSONObject doSearch(String searchEndpoint, String searchUser, String searchPassword)
String searchEndpoint,
String searchUser,
String searchPassword)
{ {
return facetedRequest(searchUser, searchPassword, null, searchEndpoint); return facetedRequest(searchUser, searchPassword, null, searchEndpoint);
} }
/** /**
* Generic rm search. * Generic rm search.
*
* @param username * @param username
* @param password * @param password
* @param site * @param site
@@ -95,45 +88,36 @@ public class SearchAPI extends BaseAPI
* @param filters * @param filters
* @return search results (see API reference for more details), null for any errors * @return search results (see API reference for more details), null for any errors
*/ */
public JSONObject rmSearch( public JSONObject rmSearch(String username, String password, String site, String query, String filters)
String username,
String password,
String site,
String query,
String filters)
{ {
List<BasicNameValuePair> searchParameters = new ArrayList<BasicNameValuePair>(); List<BasicNameValuePair> searchParameters = new ArrayList<BasicNameValuePair>();
searchParameters.add(new BasicNameValuePair("query", query)); searchParameters.add(new BasicNameValuePair("query", query));
searchParameters.add(new BasicNameValuePair("filters", filters)); searchParameters.add(new BasicNameValuePair("filters", filters));
String requestURL = MessageFormat.format( String requestURL = MessageFormat.format(RM_SEARCH_ENDPOINT,
RM_SEARCH_ENDPOINT, alfrescoHttpClientFactory.getObject().getAlfrescoUrl(), (site != null) ? site : RM_SITE_ID,
alfrescoHttpClientFactory.getObject().getAlfrescoUrl(),
(site != null) ? site : RM_SITE_ID,
URLEncodedUtils.format(searchParameters, "UTF-8")); URLEncodedUtils.format(searchParameters, "UTF-8"));
return doSearch(requestURL, username, password); return doSearch(requestURL, username, password);
} }
/** /**
* Search as a user for records on site "rm" matching query, using SearchAPI.RM_DEFAULT_RECORD_FILTERS * Search as a user for records on site "rm" matching query, using SearchAPI.RM_DEFAULT_RECORD_FILTERS <br>
* <br>
* If more fine-grained control of search parameters is required, use rmSearch() directly. * If more fine-grained control of search parameters is required, use rmSearch() directly.
*
* @param username * @param username
* @param password * @param password
* @param query * @param query
* @return list of record names * @return list of record names
*/ */
public List<String> searchForRecordsAsUser( public List<String> searchForRecordsAsUser(String username, String password, String query)
String username,
String password,
String query)
{ {
return getItemNames(rmSearch(username, password, "rm", query, RM_DEFAULT_RECORD_FILTERS)); return getItemNames(rmSearch(username, password, "rm", query, RM_DEFAULT_RECORD_FILTERS));
} }
/** /**
* Generic faceted search. * Generic faceted search.
*
* @param username * @param username
* @param password * @param password
* @param parameters * @param parameters
@@ -146,6 +130,7 @@ public class SearchAPI extends BaseAPI
/** /**
* Execute faceted search for term. * Execute faceted search for term.
*
* @param searchUser * @param searchUser
* @param searchPassword * @param searchPassword
* @param searchTerm * @param searchTerm
@@ -153,14 +138,12 @@ public class SearchAPI extends BaseAPI
*/ */
public JSONObject facetedSearchForTerm(String searchUser, String searchPassword, String searchTerm) public JSONObject facetedSearchForTerm(String searchUser, String searchPassword, String searchTerm)
{ {
return facetedSearch( return facetedSearch(searchUser, searchPassword, Arrays.asList(new BasicNameValuePair("term", searchTerm)));
searchUser,
searchPassword,
Arrays.asList(new BasicNameValuePair("term", searchTerm)));
} }
/** /**
* Helper method to search for documents as a user using faceted search. * Helper method to search for documents as a user using faceted search.
*
* @param username to search as * @param username to search as
* @param password for username * @param password for username
* @param term search term * @param term search term
@@ -171,34 +154,9 @@ public class SearchAPI extends BaseAPI
return getItemNames(facetedSearchForTerm(username, password, term)); return getItemNames(facetedSearchForTerm(username, password, term));
} }
/**
* Helper method to search for documents or folders as a user using search.
*
* @param username to search as
* @param password for username
* @param term search term
* @return list of document names found
* @throws IOException
*/
public List<String> searchForContentAsUser(String username, String password, String... searchParameters)
throws Exception
{
AlfrescoHttpClient client = alfrescoHttpClientFactory.getObject();
String requestURL = MessageFormat.format(SEARCH_ENDPOINT, client.getAlfrescoUrl());
List<BasicNameValuePair> nameValuePairs = new ArrayList<BasicNameValuePair>();
for (String searchParameter : searchParameters)
{
nameValuePairs.add(new BasicNameValuePair("term", searchParameter));
}
requestURL = MessageFormat.format(SEARCH_ENDPOINT, client.getAlfrescoUrl(),
URLEncodedUtils.format(nameValuePairs, Charset.forName("UTF-8")));
Thread.sleep(15000);
return getItemNames(doGetRequest(username, password, requestURL));
}
/** /**
* Helper method to extract list of names from search result. * Helper method to extract list of names from search result.
*
* @param searchResult * @param searchResult
* @return list of document or record names in search result * @return list of document or record names in search result
* @throws RuntimeException for malformed search response * @throws RuntimeException for malformed search response