use of com.yahoo.search.searchchain.Execution in project vespa by vespa-engine.
the class GetSearcherTestCase method testQueryOverridesDefaults.
@Test
public void testQueryOverridesDefaults() throws Exception {
DocumentSessionFactory factory = new DocumentSessionFactory(docType);
GetSearcher searcher = new GetSearcher(new FeedContext(new MessagePropertyProcessor(defFeedCfg, defLoadTypeCfg), factory, docMan, new ClusterList(), new NullFeedMetric()));
Chain<Searcher> searchChain = new Chain<>(searcher);
Result result = new Execution(searchChain, Execution.Context.createContextStub()).search(newQuery("?id[0]=userdoc:kittens:1:2&id[1]=userdoc:kittens:3:4&priority=LOW_2&route=highwaytohell&timeout=58"));
assertEquals(2, factory.messages.size());
long lastTimeout = 58000;
{
Message m = factory.messages.get(0);
assertEquals(DocumentProtocol.MESSAGE_GETDOCUMENT, m.getType());
GetDocumentMessage gdm = (GetDocumentMessage) m;
DocumentId d = gdm.getDocumentId();
assertEquals("userdoc:kittens:1:2", d.toString());
assertEquals("[all]", gdm.getFieldSet());
assertEquals(DocumentProtocol.Priority.LOW_2, gdm.getPriority());
assertEquals(Route.parse("highwaytohell"), gdm.getRoute());
assertTrue(lastTimeout >= gdm.getTimeRemaining());
lastTimeout = gdm.getTimeRemaining();
}
{
Message m = factory.messages.get(1);
assertEquals(DocumentProtocol.MESSAGE_GETDOCUMENT, m.getType());
GetDocumentMessage gdm = (GetDocumentMessage) m;
DocumentId d = gdm.getDocumentId();
assertEquals("userdoc:kittens:3:4", d.toString());
assertEquals("[all]", gdm.getFieldSet());
assertEquals(DocumentProtocol.Priority.LOW_2, gdm.getPriority());
assertEquals(Route.parse("highwaytohell"), gdm.getRoute());
assertTrue(lastTimeout >= gdm.getTimeRemaining());
}
}
use of com.yahoo.search.searchchain.Execution in project vespa by vespa-engine.
the class GetSearcherTestCase method testGetSingleDocumentQuery.
@Test
public void testGetSingleDocumentQuery() throws Exception {
// Needs auto-reply
DocumentSessionFactory factory = new DocumentSessionFactory(docType);
GetSearcher searcher = new GetSearcher(new FeedContext(new MessagePropertyProcessor(defFeedCfg, defLoadTypeCfg), factory, docMan, new ClusterList(), new NullFeedMetric()));
Chain<Searcher> searchChain = new Chain<>(searcher);
Result result = new Execution(searchChain, Execution.Context.createContextStub()).search(newQuery("?id=userdoc:kittens:1:2"));
System.out.println("HTTP request is " + result.getQuery().getHttpRequest());
assertEquals(1, factory.messages.size());
{
Message m = factory.messages.get(0);
assertEquals(DocumentProtocol.MESSAGE_GETDOCUMENT, m.getType());
GetDocumentMessage gdm = (GetDocumentMessage) m;
DocumentId d = gdm.getDocumentId();
assertEquals("userdoc:kittens:1:2", d.toString());
assertEquals("[all]", gdm.getFieldSet());
}
assertEquals(1, result.hits().size());
assertHits(result.hits(), "userdoc:kittens:1:2");
// By default, document hit should not have its hit fields set
DocumentHit hit = (DocumentHit) result.hits().get(0);
assertEquals(0, hit.fieldKeys().size());
}
use of com.yahoo.search.searchchain.Execution in project vespa by vespa-engine.
the class GetSearcherTestCase method testDocumentFieldWithDocumentNotFound.
@Test
public void testDocumentFieldWithDocumentNotFound() throws Exception {
DocumentSessionFactory factory = new DocumentSessionFactory(docType, null, true);
factory.setNullReply(true);
GetSearcher searcher = new GetSearcher(new FeedContext(new MessagePropertyProcessor(defFeedCfg, defLoadTypeCfg), factory, docMan, new ClusterList(), new NullFeedMetric()));
Chain<Searcher> searchChain = new Chain<>(searcher);
Result result = new Execution(searchChain, Execution.Context.createContextStub()).search(newQuery("?id=userdoc:kittens:1:2&field=name"));
assertNotNull(result.hits().getErrorHit());
assertRendered("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + "<result>\n" + "<errors>\n" + "<error type=\"searcher\" code=\"16\" message=\"Resource not found.: " + "Document not found, could not return field 'name'\"/>\n" + "</errors>\n" + "</result>\n", result);
}
use of com.yahoo.search.searchchain.Execution in project vespa by vespa-engine.
the class GetSearcherTestCase method testDocumentHitWithPopulatedHitFields.
@Test
public void testDocumentHitWithPopulatedHitFields() throws Exception {
Document doc1 = new Document(docType, new DocumentId("userdoc:kittens:1234:foo"));
doc1.setFieldValue("name", new StringFieldValue("megacat"));
doc1.setFieldValue("description", new StringFieldValue("supercat"));
doc1.setFieldValue("fluffiness", new IntegerFieldValue(10000));
GetDocumentReply[] replies = new GetDocumentReply[] { new GetDocumentReply(doc1) };
// Use a predefined reply list to ensure messages are answered out of order
Chain<Searcher> searchChain = createSearcherChain(replies);
Result result = new Execution(searchChain, Execution.Context.createContextStub()).search(newQuery("?id=userdoc:kittens:1234:foo&populatehitfields=true"));
assertEquals(1, result.hits().size());
assertHits(result.hits(), "userdoc:kittens:1234:foo");
DocumentHit hit = (DocumentHit) result.hits().get(0);
Iterator<Map.Entry<String, Object>> iter = hit.fieldIterator();
Set<String> fieldSet = new TreeSet<>();
while (iter.hasNext()) {
Map.Entry<String, Object> kv = iter.next();
StringBuilder field = new StringBuilder();
field.append(kv.getKey()).append(" -> ").append(kv.getValue());
fieldSet.add(field.toString());
}
StringBuilder fields = new StringBuilder();
for (String s : fieldSet) {
fields.append(s).append("\n");
}
assertEquals("description -> supercat\n" + "documentid -> userdoc:kittens:1234:foo\n" + "fluffiness -> 10000\n" + "name -> megacat\n", fields.toString());
}
use of com.yahoo.search.searchchain.Execution in project vespa by vespa-engine.
the class GetSearcherTestCase method deserializationExceptionsAreHandledGracefully.
@Test
public void deserializationExceptionsAreHandledGracefully() throws Exception {
Document doc1 = new Document(docType, new DocumentId("userdoc:kittens:5:1"));
GetDocumentReply[] replies = new GetDocumentReply[] { new MockFailingGetDocumentReply(doc1) };
Chain<Searcher> searchChain = createSearcherChain(replies);
Result result = new Execution(searchChain, Execution.Context.createContextStub()).search(newQuery("?id=userdoc:kittens:5:1"));
assertRendered("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + "<result>\n" + "<errors>\n" + "<error type=\"searcher\" code=\"18\" message=\"Internal server error.: " + "Got exception of type java.lang.RuntimeException during document " + "deserialization: epic dragon attack\"/>\n" + "</errors>\n" + "</result>\n", result);
}
Aggregations