use of com.yahoo.search.result.HitGroup in project vespa by vespa-engine.
the class MultipleResultsTestCase method testNoHitsForResultSet.
@Test
public void testNoHitsForResultSet() {
Query query = createQuery();
Result originalResult = new Result(query);
int n1 = 20;
int n2 = 100;
addHits(originalResult, "music", n1);
addHits(originalResult, "other", n2);
originalResult.setTotalHitCount(n1 + n2);
docSource.addResult(query, originalResult);
query.setWindow(0, 30);
Result result = new Execution(chain, Execution.Context.createContextStub()).search(query);
HitGroup musicGroup = (HitGroup) result.hits().get("music");
HitGroup moviesGroup = (HitGroup) result.hits().get("movies");
assertEquals(15, musicGroup.size());
assertEquals(0, moviesGroup.size());
}
use of com.yahoo.search.result.HitGroup in project vespa by vespa-engine.
the class MultipleResultsTestCase method testRetrieveHitsForGroup.
@Test
public void testRetrieveHitsForGroup() {
Query query = createQuery();
Result originalResult = new Result(query);
int n1 = 200, n2 = 30;
addHits(originalResult, "music", n1, 1000);
addHits(originalResult, "movies", n2, 100);
originalResult.setTotalHitCount(n1 + n2);
docSource.addResult(query, originalResult);
Query restrictedQuery = createQuery("movies");
Result restrictedResult = new Result(restrictedQuery);
addHits(restrictedResult, "movies", n2, 100);
restrictedResult.setTotalHitCount(n2);
docSource.addResult(restrictedQuery, restrictedResult);
query.setWindow(0, 30);
Result result = new Execution(chain, Execution.Context.createContextStub()).search(query);
HitGroup musicGroup = (HitGroup) result.hits().get("music");
HitGroup moviesGroup = (HitGroup) result.hits().get("movies");
assertEquals(15, musicGroup.size());
assertEquals(15, moviesGroup.size());
}
use of com.yahoo.search.result.HitGroup in project vespa by vespa-engine.
the class AnySourceTestCase method testExecution.
@Test
public void testExecution() {
// Create the page template
Choice page = Choice.createSingleton(importPage("AnySource.xml"));
// Create a federated result
Query query = new Query();
Result result = new Result(query);
result.hits().add(createHits("source1", 3));
result.hits().add(createHits("source2", 3));
result.hits().add(createHits("source3", 3));
// Resolve (noop here)
Resolver resolver = new DeterministicResolver();
Resolution resolution = resolver.resolve(page, query, result);
// Execute
Organizer organizer = new Organizer();
organizer.organize(page, resolution, result);
// Check execution:
// all three sources, ordered by relevance, source 3 first in each relevance group
HitGroup hits = result.hits();
assertEquals(9, hits.size());
assertEquals("source3-1", hits.get(0).getId().stringValue());
assertEquals("source1-1", hits.get(1).getId().stringValue());
assertEquals("source2-1", hits.get(2).getId().stringValue());
assertEquals("source3-2", hits.get(3).getId().stringValue());
assertEquals("source1-2", hits.get(4).getId().stringValue());
assertEquals("source2-2", hits.get(5).getId().stringValue());
assertEquals("source3-3", hits.get(6).getId().stringValue());
assertEquals("source1-3", hits.get(7).getId().stringValue());
assertEquals("source2-3", hits.get(8).getId().stringValue());
// Check rendering
assertRendered(result, "AnySourceResult.xml");
}
use of com.yahoo.search.result.HitGroup in project vespa by vespa-engine.
the class MapSectionsToSectionsTestCase method testExecution.
@Test
public void testExecution() {
// Create the page template
Choice page = Choice.createSingleton(importPage("MapSectionsToSections.xml"));
// Create a federated result
Query query = new Query();
Result result = new Result(query);
result.hits().add(createHits("source1", 3));
result.hits().add(createHits("source2", 4));
result.hits().add(createHits("source3", 5));
result.hits().add(createHits("source4", 6));
result.hits().add(createHits("source5", 7));
// Resolve
Resolver resolver = new DeterministicResolverAssertingMethod();
Resolution resolution = resolver.resolve(page, query, result);
Map<String, List<PageElement>> mapping = resolution.getResolution((MapChoice) ((PageTemplate) page.get(0).get(0)).getSection().elements().get(2));
assertNotNull(mapping);
assertEquals("box1", ((Section) mapping.get("box1holder").get(0)).getId());
assertEquals("box2", ((Section) mapping.get("box2holder").get(0)).getId());
assertEquals("box3", ((Section) mapping.get("box3holder").get(0)).getId());
assertEquals("box4", ((Section) mapping.get("box4holder").get(0)).getId());
// Execute
Organizer organizer = new Organizer();
organizer.organize(page, resolution, result);
// Check execution:
// Two subsections, each containing two sub-subsections with one source each
assertEquals(2, result.hits().size());
HitGroup row1 = (HitGroup) result.hits().get(0);
HitGroup column11 = (HitGroup) row1.get(0);
HitGroup column12 = (HitGroup) row1.get(1);
HitGroup row2 = (HitGroup) result.hits().get(1);
HitGroup column21a = (HitGroup) row2.get(0);
HitGroup column21b = (HitGroup) row2.get(1);
HitGroup column22 = (HitGroup) row2.get(2);
assertEqualHitGroups(createHits("source1", 3), column11);
assertEqualHitGroups(createHits("source2", 4), column12);
assertEqualHitGroups(createHits("source3", 5), column21a);
assertEqualHitGroups(createHits("source5", 7), column21b);
assertEqualHitGroups(createHits("source4", 6), column22);
// Check rendering
assertRendered(result, "MapSectionsToSectionsResult.xml");
}
use of com.yahoo.search.result.HitGroup in project vespa by vespa-engine.
the class ExecutionAbstractTestCase method createHits.
protected HitGroup createHits(String sourceName, int hitCount) {
HitGroup source = new HitGroup("source:" + sourceName);
for (int i = 1; i <= hitCount; i++) {
Hit hit = new Hit(sourceName + "-" + i, 1 / (double) i);
hit.setSource(sourceName);
source.add(hit);
}
return source;
}
Aggregations