mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
Merged 5.2.N (5.2.2) to HEAD (5.2)
137080 gjames: Merged searchrep (5.2.1) to 5.2.N (5.2.1) 136989 gjames: SEARCH-430: Combining pivot with range git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@137595 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -53,16 +53,6 @@ public class SearchRequestContext
|
|||||||
this.includeRequest = includeRequest;
|
this.includeRequest = includeRequest;
|
||||||
this.pivotKeys = new HashMap<>();
|
this.pivotKeys = new HashMap<>();
|
||||||
this.stores = new HashSet<>();
|
this.stores = new HashSet<>();
|
||||||
|
|
||||||
/**
|
|
||||||
this.facetQueries = facetQueries!=null?Collections.unmodifiableList(facetQueries): Collections.emptyList();
|
|
||||||
this.facetFields = new FacetFields(facetFields!=null?Collections.unmodifiableList(facetFields.getFacets()):Collections.emptyList());
|
|
||||||
this.facetIntervals = facetIntervals!=null?
|
|
||||||
new IntervalParameters(Collections.unmodifiableList(facetIntervals.getSets()),
|
|
||||||
Collections.unmodifiableList(facetIntervals.getIntervals()))
|
|
||||||
:
|
|
||||||
new IntervalParameters(Collections.emptyList(),Collections.emptyList());
|
|
||||||
this.pivots = pivots!=null?Collections.unmodifiableList(pivots): Collections.emptyList();**/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final SearchRequestContext from(SearchQuery searchQuery)
|
public static final SearchRequestContext from(SearchQuery searchQuery)
|
||||||
|
@@ -1,133 +0,0 @@
|
|||||||
/*-
|
|
||||||
* #%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.search.impl;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Map.Entry;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericBucket;
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericFacetResponse;
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericFacetResponse.FACET_TYPE;
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric;
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric.METRIC_TYPE;
|
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.SimpleMetric;
|
|
||||||
import org.alfresco.rest.api.search.model.SearchQuery;
|
|
||||||
import org.alfresco.service.cmr.search.RangeParameters;
|
|
||||||
|
|
||||||
/**Helper to map range results.
|
|
||||||
*
|
|
||||||
* @author Michael Suzuki
|
|
||||||
*/
|
|
||||||
public class RangeResultMapper
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Transforms the facet range response into generic facet response.
|
|
||||||
* @param facetFields
|
|
||||||
* @param searchQuery
|
|
||||||
* @return GenericFacetResponse
|
|
||||||
*/
|
|
||||||
public static List<GenericFacetResponse> getGenericFacetsForRanges( Map<String,List<Map<String,String>>> facetFields, SearchQuery searchQuery)
|
|
||||||
{
|
|
||||||
List<GenericFacetResponse> ffcs = new ArrayList<>(facetFields.size());
|
|
||||||
if (facetFields != null && !facetFields.isEmpty() && searchQuery.getQuery() != null)
|
|
||||||
{
|
|
||||||
for (Entry<String, List<Map<String, String>>> facet : facetFields.entrySet())
|
|
||||||
{
|
|
||||||
List<GenericBucket> buckets = new ArrayList<>();
|
|
||||||
facet.getValue().forEach(action -> buckets.add(buildGenericBucketFromRange(facet.getKey(),
|
|
||||||
(Map<String, String>) action,
|
|
||||||
searchQuery.getFacetRanges())));
|
|
||||||
ffcs.add(new GenericFacetResponse(FACET_TYPE.range, facet.getKey(), buckets));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ffcs;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Builds the generic facet response out of range results.
|
|
||||||
* @param facetField
|
|
||||||
* @param facet
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
private static GenericBucket buildGenericBucketFromRange(String facetField, Map<String,String> facet, List<RangeParameters> ranges)
|
|
||||||
{
|
|
||||||
String start = facet.get(GenericFacetResponse.START);
|
|
||||||
String end = facet.get(GenericFacetResponse.END);
|
|
||||||
boolean startInclusive = true;
|
|
||||||
boolean endInclusive = false;
|
|
||||||
|
|
||||||
for(RangeParameters range : ranges)
|
|
||||||
{
|
|
||||||
if(range.getField().equalsIgnoreCase(facetField))
|
|
||||||
{
|
|
||||||
List<String> includes = range.getInclude();
|
|
||||||
if(includes != null && !includes.isEmpty())
|
|
||||||
{
|
|
||||||
startInclusive = range.isRangeStartInclusive();
|
|
||||||
endInclusive = range.isRangeEndInclusive();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
facet.put(GenericFacetResponse.START_INC.toString(), Boolean.toString(startInclusive));
|
|
||||||
facet.put(GenericFacetResponse.END_INC.toString(), Boolean.toString(endInclusive));
|
|
||||||
|
|
||||||
facet.remove(GenericFacetResponse.LABEL);
|
|
||||||
StringBuilder filterQ = new StringBuilder();
|
|
||||||
filterQ.append(facetField).append(":")
|
|
||||||
.append(startInclusive ? "[" :"<")
|
|
||||||
.append(start).append(" TO ")
|
|
||||||
.append(end)
|
|
||||||
.append(endInclusive ? "]" :">");
|
|
||||||
|
|
||||||
Set<Metric> metrics = new HashSet<Metric>(
|
|
||||||
Arrays.asList(new SimpleMetric(
|
|
||||||
METRIC_TYPE.count,facet.get(
|
|
||||||
GenericFacetResponse.COUNT))));
|
|
||||||
facet.remove("count");
|
|
||||||
|
|
||||||
StringBuilder label = new StringBuilder();
|
|
||||||
label.append(startInclusive ? "[" :"(")
|
|
||||||
.append(start)
|
|
||||||
.append(" - ")
|
|
||||||
.append(end)
|
|
||||||
.append(endInclusive ? "]" :")");
|
|
||||||
|
|
||||||
return new GenericBucket(label.toString(),
|
|
||||||
filterQ.toString(),
|
|
||||||
null,
|
|
||||||
metrics,
|
|
||||||
null,
|
|
||||||
facet);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@@ -50,6 +50,7 @@ import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericFacetRespo
|
|||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericFacetResponse.FACET_TYPE;
|
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.GenericFacetResponse.FACET_TYPE;
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric;
|
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric;
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric.METRIC_TYPE;
|
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.Metric.METRIC_TYPE;
|
||||||
|
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.RangeResultMapper;
|
||||||
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.SimpleMetric;
|
import org.alfresco.repo.search.impl.solr.facet.facetsresponse.SimpleMetric;
|
||||||
import org.alfresco.repo.security.permissions.impl.acegi.FilteringResultSet;
|
import org.alfresco.repo.security.permissions.impl.acegi.FilteringResultSet;
|
||||||
import org.alfresco.repo.version.Version2Model;
|
import org.alfresco.repo.version.Version2Model;
|
||||||
@@ -340,7 +341,7 @@ public class ResultMapper
|
|||||||
facets.addAll(getGenericFacetsForIntervals(facetInterval, searchQuery));
|
facets.addAll(getGenericFacetsForIntervals(facetInterval, searchQuery));
|
||||||
|
|
||||||
Map<String,List<Map<String,String>>> facetRanges = solrResultSet.getFacetRanges();
|
Map<String,List<Map<String,String>>> facetRanges = solrResultSet.getFacetRanges();
|
||||||
facets.addAll(RangeResultMapper.getGenericFacetsForRanges(facetRanges, searchQuery));
|
facets.addAll(RangeResultMapper.getGenericFacetsForRanges(facetRanges, searchQuery.getFacetRanges()));
|
||||||
|
|
||||||
List<GenericFacetResponse> stats = getFieldStats(searchRequestContext, solrResultSet.getStats());
|
List<GenericFacetResponse> stats = getFieldStats(searchRequestContext, solrResultSet.getStats());
|
||||||
List<GenericFacetResponse> pimped = getPivots(searchRequestContext, solrResultSet.getPivotFacets(), stats);
|
List<GenericFacetResponse> pimped = getPivots(searchRequestContext, solrResultSet.getPivotFacets(), stats);
|
||||||
|
@@ -78,9 +78,7 @@ import java.time.ZoneId;
|
|||||||
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 java.util.ListIterator;
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Locale.Builder;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@@ -126,7 +124,7 @@ public class SearchMapper
|
|||||||
fromDefault(sp, searchQuery.getDefaults());
|
fromDefault(sp, searchQuery.getDefaults());
|
||||||
fromFilterQuery(sp, searchQuery.getFilterQueries());
|
fromFilterQuery(sp, searchQuery.getFilterQueries());
|
||||||
fromFacetQuery(sp, searchQuery.getFacetQueries());
|
fromFacetQuery(sp, searchQuery.getFacetQueries());
|
||||||
fromPivot(sp, searchQuery.getStats(), searchQuery.getFacetFields(), searchQuery.getPivots(), searchRequestContext);
|
fromPivot(sp, searchQuery.getStats(), searchQuery.getFacetFields(), searchQuery.getFacetRanges(), searchQuery.getPivots(), searchRequestContext);
|
||||||
fromStats(sp, searchQuery.getStats());
|
fromStats(sp, searchQuery.getStats());
|
||||||
fromFacetFields(sp, searchQuery.getFacetFields());
|
fromFacetFields(sp, searchQuery.getFacetFields());
|
||||||
fromSpellCheck(sp, searchQuery.getSpellcheck());
|
fromSpellCheck(sp, searchQuery.getSpellcheck());
|
||||||
@@ -576,20 +574,22 @@ public class SearchMapper
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void fromPivot(SearchParameters sp, List<StatsRequestParameters> stats, FacetFields facetFields, List<Pivot> multiplePivots, SearchRequestContext searchRequestContext)
|
public void fromPivot(SearchParameters sp, List<StatsRequestParameters> stats, FacetFields facetFields, List<RangeParameters> ranges, List<Pivot> multiplePivots,
|
||||||
|
SearchRequestContext searchRequestContext)
|
||||||
{
|
{
|
||||||
if (multiplePivots != null && !multiplePivots.isEmpty())
|
if (multiplePivots != null && !multiplePivots.isEmpty())
|
||||||
{
|
{
|
||||||
multiplePivots.forEach(aPivot -> {
|
multiplePivots.forEach(aPivot -> {
|
||||||
List<String> pivotKeys = new ArrayList<>();
|
List<String> pivotKeys = new ArrayList<>();
|
||||||
buildPivotKeys(pivotKeys, aPivot, stats,facetFields, searchRequestContext);
|
buildPivotKeys(pivotKeys, aPivot, stats, facetFields, ranges, searchRequestContext);
|
||||||
sp.addPivots(pivotKeys);
|
sp.addPivots(pivotKeys);
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void buildPivotKeys(List<String> pivotKeys, Pivot aPivot, List<StatsRequestParameters> stats, FacetFields facetFields, SearchRequestContext searchRequestContext)
|
protected void buildPivotKeys(List<String> pivotKeys, Pivot aPivot, List<StatsRequestParameters> stats, FacetFields facetFields,
|
||||||
|
List<RangeParameters> ranges, SearchRequestContext searchRequestContext)
|
||||||
{
|
{
|
||||||
if (aPivot == null) return;
|
if (aPivot == null) return;
|
||||||
String pivotKey = null;
|
String pivotKey = null;
|
||||||
@@ -617,7 +617,7 @@ public class SearchMapper
|
|||||||
|
|
||||||
if (pivotKey == null && ((aPivot.getPivots() == null) || aPivot.getPivots().isEmpty()))
|
if (pivotKey == null && ((aPivot.getPivots() == null) || aPivot.getPivots().isEmpty()))
|
||||||
{
|
{
|
||||||
//It is the last one so it can reference stats
|
//It is the last one so it can reference stats or range
|
||||||
if (stats != null && !stats.isEmpty())
|
if (stats != null && !stats.isEmpty())
|
||||||
{
|
{
|
||||||
Optional<StatsRequestParameters> foundStat = stats.stream().filter(stas -> aPivot.getKey().equals(stas.getLabel()!=null?stas.getLabel():stas.getField())).findFirst();
|
Optional<StatsRequestParameters> foundStat = stats.stream().filter(stas -> aPivot.getKey().equals(stas.getLabel()!=null?stas.getLabel():stas.getField())).findFirst();
|
||||||
@@ -628,12 +628,25 @@ public class SearchMapper
|
|||||||
searchRequestContext.getPivotKeys().put(pivotKey, pivotKey);
|
searchRequestContext.getPivotKeys().put(pivotKey, pivotKey);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ranges != null && !ranges.isEmpty())
|
||||||
|
{
|
||||||
|
for (RangeParameters aRange:ranges)
|
||||||
|
{
|
||||||
|
if (aRange.getTags().contains(aPivot.getKey()))
|
||||||
|
{
|
||||||
|
pivotKey = aPivot.getKey();
|
||||||
|
pivotKeys.add(pivotKey);
|
||||||
|
searchRequestContext.getPivotKeys().put(pivotKey, pivotKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pivotKey == null)
|
if (pivotKey == null)
|
||||||
{
|
{
|
||||||
throw new InvalidArgumentException(InvalidArgumentException.DEFAULT_MESSAGE_ID,
|
throw new InvalidArgumentException(InvalidArgumentException.DEFAULT_MESSAGE_ID,
|
||||||
new Object[] { ": Pivot parameter " + aPivot.getKey() + " does not reference a facet Field or stats." });
|
new Object[] { ": Pivot parameter " + aPivot.getKey() + " does not reference a facet Field, range or stats." });
|
||||||
}
|
}
|
||||||
|
|
||||||
if (aPivot.getPivots() != null && !aPivot.getPivots().isEmpty() && aPivot.getPivots().size()>1)
|
if (aPivot.getPivots() != null && !aPivot.getPivots().isEmpty() && aPivot.getPivots().size()>1)
|
||||||
@@ -644,7 +657,7 @@ public class SearchMapper
|
|||||||
|
|
||||||
aPivot.getPivots().forEach(subPivot ->
|
aPivot.getPivots().forEach(subPivot ->
|
||||||
{
|
{
|
||||||
buildPivotKeys(pivotKeys, subPivot, stats, facetFields, searchRequestContext);
|
buildPivotKeys(pivotKeys, subPivot, stats, facetFields, ranges, searchRequestContext);
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -34,14 +34,6 @@ import static org.alfresco.service.cmr.search.SearchService.LANGUAGE_FTS_ALFRESC
|
|||||||
import static org.alfresco.service.cmr.search.SearchService.LANGUAGE_LUCENE;
|
import static org.alfresco.service.cmr.search.SearchService.LANGUAGE_LUCENE;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
import static org.junit.Assert.assertNull;
|
import static org.junit.Assert.assertNull;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.alfresco.rest.api.search.context.SearchRequestContext;
|
import org.alfresco.rest.api.search.context.SearchRequestContext;
|
||||||
import org.alfresco.rest.api.search.impl.SearchMapper;
|
import org.alfresco.rest.api.search.impl.SearchMapper;
|
||||||
import org.alfresco.rest.api.search.impl.StoreMapper;
|
import org.alfresco.rest.api.search.impl.StoreMapper;
|
||||||
@@ -77,6 +69,13 @@ import org.alfresco.service.cmr.search.StatsRequestParameters;
|
|||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the SearchMapper class
|
* Tests the SearchMapper class
|
||||||
*
|
*
|
||||||
@@ -827,13 +826,13 @@ public class SearchMapperTests
|
|||||||
public void fromPivot() throws Exception
|
public void fromPivot() throws Exception
|
||||||
{
|
{
|
||||||
SearchParameters searchParameters = new SearchParameters();
|
SearchParameters searchParameters = new SearchParameters();
|
||||||
searchMapper.fromPivot(searchParameters, null, null, null, null);
|
searchMapper.fromPivot(searchParameters, null, null, null, null, null);
|
||||||
|
|
||||||
List<FacetField> facets = new ArrayList<>(1);
|
List<FacetField> facets = new ArrayList<>(1);
|
||||||
facets.add(new FacetField("myfield",null,null,null,null,null,null,null,null,null,null));
|
facets.add(new FacetField("myfield",null,null,null,null,null,null,null,null,null,null));
|
||||||
FacetFields ff = new FacetFields(facets);
|
FacetFields ff = new FacetFields(facets);
|
||||||
searchMapper.fromFacetFields(searchParameters,ff);
|
searchMapper.fromFacetFields(searchParameters,ff);
|
||||||
searchMapper.fromPivot(searchParameters, null, ff, null, null);
|
searchMapper.fromPivot(searchParameters, null, ff, null, null, null);
|
||||||
assertEquals(1 ,searchParameters.getFieldFacets().size());
|
assertEquals(1 ,searchParameters.getFieldFacets().size());
|
||||||
assertEquals(0 ,searchParameters.getPivots().size());
|
assertEquals(0 ,searchParameters.getPivots().size());
|
||||||
|
|
||||||
@@ -842,7 +841,7 @@ public class SearchMapperTests
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
searchMapper.fromPivot(searchParameters, null, ff, Arrays.asList(new Pivot(null, null)), null);
|
searchMapper.fromPivot(searchParameters, null, ff, null, Arrays.asList(new Pivot(null, null)), null);
|
||||||
fail();
|
fail();
|
||||||
}
|
}
|
||||||
catch (IllegalArgumentException iae)
|
catch (IllegalArgumentException iae)
|
||||||
@@ -853,7 +852,7 @@ public class SearchMapperTests
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
searchMapper.fromPivot(searchParameters, null, ff, Arrays.asList(new Pivot("", null)), null);
|
searchMapper.fromPivot(searchParameters, null, ff, null, Arrays.asList(new Pivot("", null)), null);
|
||||||
fail();
|
fail();
|
||||||
}
|
}
|
||||||
catch (IllegalArgumentException iae)
|
catch (IllegalArgumentException iae)
|
||||||
@@ -866,16 +865,17 @@ public class SearchMapperTests
|
|||||||
//"bob" doesn't refer to a field facet but its the last one so needs to refer to a stat
|
//"bob" doesn't refer to a field facet but its the last one so needs to refer to a stat
|
||||||
StatsRequestParameters bobf = new StatsRequestParameters("bob", null, null, null,null, null, null, null,null, null, null, null,null, null, null, null);
|
StatsRequestParameters bobf = new StatsRequestParameters("bob", null, null, null,null, null, null, null,null, null, null, null,null, null, null, null);
|
||||||
StatsRequestParameters bobL = new StatsRequestParameters("creator", "bob", null, null,null, null, null, null,null, null, null, null,null, null, null, null);
|
StatsRequestParameters bobL = new StatsRequestParameters("creator", "bob", null, null,null, null, null, null,null, null, null, null,null, null, null, null);
|
||||||
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, Arrays.asList(new Pivot("bob", null)), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, null, Arrays.asList(new Pivot("bob", null)), searchRequestContext);
|
||||||
assertEquals(1 ,searchParameters.getPivots().size());
|
assertEquals(1 ,searchParameters.getPivots().size());
|
||||||
|
|
||||||
searchParameters = new SearchParameters();
|
searchParameters = new SearchParameters();
|
||||||
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, Arrays.asList(new Pivot("bob", null)), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, null, Arrays.asList(new Pivot("bob", null)), searchRequestContext);
|
||||||
assertEquals(1 ,searchParameters.getPivots().size());
|
assertEquals(1 ,searchParameters.getPivots().size());
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
searchMapper.fromPivot(searchParameters, null, ff, Arrays.asList(new Pivot("ken", null),new Pivot("bob", null)), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, null, ff, null,
|
||||||
|
Arrays.asList(new Pivot("ken", null),new Pivot("bob", null)), searchRequestContext);
|
||||||
fail();
|
fail();
|
||||||
}
|
}
|
||||||
catch (InvalidArgumentException iae)
|
catch (InvalidArgumentException iae)
|
||||||
@@ -886,7 +886,7 @@ public class SearchMapperTests
|
|||||||
|
|
||||||
searchParameters = new SearchParameters();
|
searchParameters = new SearchParameters();
|
||||||
|
|
||||||
searchMapper.fromPivot(searchParameters, null, ff, Arrays.asList(new Pivot("myfield", null)), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, null, ff, null, Arrays.asList(new Pivot("myfield", null)), searchRequestContext);
|
||||||
searchMapper.fromFacetFields(searchParameters,ff);
|
searchMapper.fromFacetFields(searchParameters,ff);
|
||||||
//Moved from a field facet to a pivot
|
//Moved from a field facet to a pivot
|
||||||
assertEquals(0 ,searchParameters.getFieldFacets().size());
|
assertEquals(0 ,searchParameters.getFieldFacets().size());
|
||||||
@@ -896,7 +896,8 @@ public class SearchMapperTests
|
|||||||
searchParameters = new SearchParameters();
|
searchParameters = new SearchParameters();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, Arrays.asList(new Pivot("bob", Arrays.asList(new Pivot("hope", null)))), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, null,
|
||||||
|
Arrays.asList(new Pivot("bob", Arrays.asList(new Pivot("hope", null)))), searchRequestContext);
|
||||||
fail();
|
fail();
|
||||||
}
|
}
|
||||||
catch (InvalidArgumentException iae)
|
catch (InvalidArgumentException iae)
|
||||||
@@ -909,7 +910,8 @@ public class SearchMapperTests
|
|||||||
facets = new ArrayList<>(1);
|
facets = new ArrayList<>(1);
|
||||||
facets.add(new FacetField("king",null,null,null,null,null,null,null,null,null,null));
|
facets.add(new FacetField("king",null,null,null,null,null,null,null,null,null,null));
|
||||||
ff = new FacetFields(facets);
|
ff = new FacetFields(facets);
|
||||||
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, Arrays.asList(new Pivot("king", Arrays.asList(new Pivot("bob", null)))), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, null,
|
||||||
|
Arrays.asList(new Pivot("king", Arrays.asList(new Pivot("bob", null)))), searchRequestContext);
|
||||||
assertEquals(1 ,searchParameters.getPivots().size());
|
assertEquals(1 ,searchParameters.getPivots().size());
|
||||||
assertEquals(2 ,searchParameters.getPivots().get(0).size());
|
assertEquals(2 ,searchParameters.getPivots().get(0).size());
|
||||||
assertEquals("king" ,searchParameters.getPivots().get(0).get(0));
|
assertEquals("king" ,searchParameters.getPivots().get(0).get(0));
|
||||||
@@ -922,13 +924,30 @@ public class SearchMapperTests
|
|||||||
facets.add(new FacetField("kong",null,null,null,null,null,null,null,null,null,null));
|
facets.add(new FacetField("kong",null,null,null,null,null,null,null,null,null,null));
|
||||||
facets.add(new FacetField("kang",null,null,null,null,null,null,null,null,null,null));
|
facets.add(new FacetField("kang",null,null,null,null,null,null,null,null,null,null));
|
||||||
ff = new FacetFields(facets);
|
ff = new FacetFields(facets);
|
||||||
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, Arrays.asList(new Pivot("king", Arrays.asList(new Pivot("bob", null))), new Pivot("kong", null)), searchRequestContext);
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, null,
|
||||||
|
Arrays.asList(new Pivot("king", Arrays.asList(new Pivot("bob", null))), new Pivot("kong", null)), searchRequestContext);
|
||||||
assertEquals(2 ,searchParameters.getPivots().size());
|
assertEquals(2 ,searchParameters.getPivots().size());
|
||||||
assertEquals(2 ,searchParameters.getPivots().get(0).size());
|
assertEquals(2 ,searchParameters.getPivots().get(0).size());
|
||||||
assertEquals("king" ,searchParameters.getPivots().get(0).get(0));
|
assertEquals("king" ,searchParameters.getPivots().get(0).get(0));
|
||||||
assertEquals("bob" ,searchParameters.getPivots().get(0).get(1));
|
assertEquals("bob" ,searchParameters.getPivots().get(0).get(1));
|
||||||
assertEquals("kong" ,searchParameters.getPivots().get(1).get(0));
|
assertEquals("kong" ,searchParameters.getPivots().get(1).get(0));
|
||||||
|
|
||||||
|
searchRequestContext = SearchRequestContext.from(minimalQuery());
|
||||||
|
searchParameters = new SearchParameters();
|
||||||
|
List<RangeParameters> rangeParams = new ArrayList<RangeParameters>();
|
||||||
|
facets = new ArrayList<>(2);
|
||||||
|
facets.add(new FacetField("king",null,null,null,null,null,null,null,null,null,null));
|
||||||
|
facets.add(new FacetField("kong",null,null,null,null,null,null,null,null,null,null));
|
||||||
|
ff = new FacetFields(facets);
|
||||||
|
rangeParams.add(new RangeParameters("content.size", "0", "100000", "1000",true,null,null,Arrays.asList("hope"),null));
|
||||||
|
searchMapper.fromPivot(searchParameters, Arrays.asList(bobf), ff, rangeParams,
|
||||||
|
Arrays.asList(new Pivot("king", Arrays.asList(new Pivot("bob", null))), new Pivot("hope", null)), searchRequestContext);
|
||||||
|
assertEquals(2 ,searchParameters.getPivots().size());
|
||||||
|
assertEquals(2 ,searchParameters.getPivots().get(0).size());
|
||||||
|
assertEquals("king" ,searchParameters.getPivots().get(0).get(0));
|
||||||
|
assertEquals("bob" ,searchParameters.getPivots().get(0).get(1));
|
||||||
|
assertEquals("hope" ,searchParameters.getPivots().get(1).get(0));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -1021,7 +1040,7 @@ public class SearchMapperTests
|
|||||||
SearchQuery sq = new SearchQuery(query, null, null, null, null, null, null, null,
|
SearchQuery sq = new SearchQuery(query, null, null, null, null, null, null, null,
|
||||||
null, null, null, null, null, null, null, null,
|
null, null, null, null, null, null, null, null,
|
||||||
null, null,null, null,FacetFormat.V2);
|
null, null,null, null,FacetFormat.V2);
|
||||||
|
|
||||||
SearchRequestContext searchRequestContext = SearchRequestContext.from(sq);
|
SearchRequestContext searchRequestContext = SearchRequestContext.from(sq);
|
||||||
SearchParameters searchParameters = searchMapper.toSearchParameters(ResultMapperTests.EMPTY_PARAMS, sq, searchRequestContext);
|
SearchParameters searchParameters = searchMapper.toSearchParameters(ResultMapperTests.EMPTY_PARAMS, sq, searchRequestContext);
|
||||||
assertNotNull(searchParameters);
|
assertNotNull(searchParameters);
|
||||||
@@ -1031,9 +1050,10 @@ public class SearchMapperTests
|
|||||||
assertEquals("workspaces store is the default", StoreRef.STORE_REF_WORKSPACE_SPACESSTORE, searchParameters.getStores().get(0));
|
assertEquals("workspaces store is the default", StoreRef.STORE_REF_WORKSPACE_SPACESSTORE, searchParameters.getStores().get(0));
|
||||||
assertEquals(LimitBy.FINAL_SIZE, searchParameters.getLimitBy());
|
assertEquals(LimitBy.FINAL_SIZE, searchParameters.getLimitBy());
|
||||||
assertEquals(100, searchParameters.getLimit());
|
assertEquals(100, searchParameters.getLimit());
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void facetRange()
|
public void facetRange()
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user