SOLR-9287: Including 'score' in the 'fl' param when doing an RTG no longer causes an NPE

(cherry picked from commit 462dc04cb6)
This commit is contained in:
Chris Hostetter 2016-07-11 14:35:06 -07:00
parent 268021af9c
commit b3cc4b3111
3 changed files with 16 additions and 8 deletions

View File

@ -107,6 +107,9 @@ Bug Fixes
* SOLR-9291: ZkSolrResourceLoader should not retry fetching resources if the server has been shutdown. * SOLR-9291: ZkSolrResourceLoader should not retry fetching resources if the server has been shutdown.
(shalin) (shalin)
* SOLR-9287: Including 'score' in the 'fl' param when doing an RTG no longer causes an NPE
(hossman, Ishan Chattopadhyaya)
Optimizations Optimizations
---------------------- ----------------------

View File

@ -48,7 +48,7 @@ public abstract class ResultContext {
public abstract SolrQueryRequest getRequest(); public abstract SolrQueryRequest getRequest();
public boolean wantsScores() { public boolean wantsScores() {
return getReturnFields().wantsScore() && getDocList().hasScores(); return getReturnFields() != null && getReturnFields().wantsScore() && getDocList() != null && getDocList().hasScores();
} }
public Iterator<SolrDocument> getProcessedDocuments() { public Iterator<SolrDocument> getProcessedDocuments() {

View File

@ -162,7 +162,6 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
} }
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287")
public void testScoreAndAllRealFieldsRTG() throws Exception { public void testScoreAndAllRealFieldsRTG() throws Exception {
// if we use RTG (committed or otherwise) score should be ignored // if we use RTG (committed or otherwise) score should be ignored
@ -209,7 +208,6 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
); );
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287")
public void testScoreAndExplicitRealFieldsRTG() throws Exception { public void testScoreAndExplicitRealFieldsRTG() throws Exception {
// if we use RTG (committed or otherwise) score should be ignored // if we use RTG (committed or otherwise) score should be ignored
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
@ -348,8 +346,9 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287") @AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9285")
public void testFunctionsAndScoreRTG() throws Exception { public void testFunctionsAndScoreRTG() throws Exception {
// NOTE: once this test is fixed to pass, testAugmentersRTG should also be updated to test a abs(val_i)
// if we use RTG (committed or otherwise) score should be ignored // if we use RTG (committed or otherwise) score should be ignored
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
@ -492,7 +491,6 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
} }
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287")
public void testGlobsAndScoreRTG() throws Exception { public void testGlobsAndScoreRTG() throws Exception {
// behavior shouldn't matter if we are committed or uncommitted, score should be ignored // behavior shouldn't matter if we are committed or uncommitted, score should be ignored
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
@ -563,6 +561,7 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
// behavior shouldn't matter if we are committed or uncommitted // behavior shouldn't matter if we are committed or uncommitted
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
// NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well. // NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well.
// NOTE: once testFunctionsAndScoreRTG can pass, abs(val_i) should be tested here as well
for (SolrParams p : Arrays.asList(params("fl","[shard],[explain],x_alias:[value v=10 t=int]"), for (SolrParams p : Arrays.asList(params("fl","[shard],[explain],x_alias:[value v=10 t=int]"),
params("fl","[shard]","fl","[explain],x_alias:[value v=10 t=int]"), params("fl","[shard]","fl","[explain],x_alias:[value v=10 t=int]"),
params("fl","[shard]","fl","[explain]","fl","x_alias:[value v=10 t=int]"))) { params("fl","[shard]","fl","[explain]","fl","x_alias:[value v=10 t=int]"))) {
@ -570,6 +569,7 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
req(p, "qt","/get","id",id, "wt","xml") req(p, "qt","/get","id",id, "wt","xml")
,"count(//doc)=1" ,"count(//doc)=1"
// ,"//doc/int[@name='[docid]']" // TODO // ,"//doc/int[@name='[docid]']" // TODO
// ,"//doc/gloat[@name='abs(val_i)']" // TODO
,"//doc/str[@name='[shard]'][.='[not a shard request]']" ,"//doc/str[@name='[shard]'][.='[not a shard request]']"
// RTG: [explain] should be missing (ignored) // RTG: [explain] should be missing (ignored)
,"//doc/int[@name='x_alias'][.=10]" ,"//doc/int[@name='x_alias'][.=10]"
@ -601,6 +601,7 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
// behavior shouldn't matter if we are committed or uncommitted // behavior shouldn't matter if we are committed or uncommitted
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
// NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well. // NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well.
// NOTE: once testFunctionsAndScoreRTG can pass, abs(val_i) should be tested here as well
for (SolrParams p : Arrays.asList(params("fl","id,[explain],x_alias:[value v=10 t=int]"), for (SolrParams p : Arrays.asList(params("fl","id,[explain],x_alias:[value v=10 t=int]"),
params("fl","id","fl","[explain],x_alias:[value v=10 t=int]"), params("fl","id","fl","[explain],x_alias:[value v=10 t=int]"),
params("fl","id","fl","[explain]","fl","x_alias:[value v=10 t=int]"))) { params("fl","id","fl","[explain]","fl","x_alias:[value v=10 t=int]"))) {
@ -609,6 +610,7 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
,"count(//doc)=1" ,"count(//doc)=1"
,"//doc/str[@name='id']" ,"//doc/str[@name='id']"
// ,"//doc/int[@name='[docid]']" // TODO // ,"//doc/int[@name='[docid]']" // TODO
// ,"//doc/gloat[@name='abs(val_i)']" // TODO
// RTG: [explain] should be missing (ignored) // RTG: [explain] should be missing (ignored)
,"//doc/int[@name='x_alias'][.=10]" ,"//doc/int[@name='x_alias'][.=10]"
@ -646,15 +648,16 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
} }
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287")
public void testAugmentersAndScoreRTG() throws Exception { public void testAugmentersAndScoreRTG() throws Exception {
// if we use RTG (committed or otherwise) score should be ignored // if we use RTG (committed or otherwise) score should be ignored
for (String id : Arrays.asList("42","99")) { for (String id : Arrays.asList("42","99")) {
// NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well. // NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well.
// NOTE: once testFunctionsAndScoreRTG can pass, abs(val_i) should be tested here as well
assertQ(id, assertQ(id,
req("qt","/get","id",id, "wt","xml", req("qt","/get","id",id, "wt","xml",
"fl","x_alias:[value v=10 t=int],score") "fl","x_alias:[value v=10 t=int],score")
// ,"//doc/int[@name='[docid]']" // TODO // ,"//doc/int[@name='[docid]']" // TODO
// ,"//doc/gloat[@name='abs(val_i)']" // TODO
,"//doc/int[@name='x_alias'][.=10]" ,"//doc/int[@name='x_alias'][.=10]"
,"//doc[count(*)=1]" ,"//doc[count(*)=1]"
@ -667,6 +670,7 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
req(p, "qt","/get","id",id, "wt","xml") req(p, "qt","/get","id",id, "wt","xml")
// ,"//doc/int[@name='[docid]']" // TODO // ,"//doc/int[@name='[docid]']" // TODO
// ,"//doc/gloat[@name='abs(val_i)']" // TODO
,"//doc/int[@name='x_alias'][.=10]" ,"//doc/int[@name='x_alias'][.=10]"
// RTG: [explain] and score should be missing (ignored) // RTG: [explain] and score should be missing (ignored)
@ -710,13 +714,13 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
} }
} }
@AwaitsFix(bugUrl="https://issues.apache.org/jira/browse/SOLR-9287")
public void testAugmentersGlobsExplicitAndScoreOhMyRTG() throws Exception { public void testAugmentersGlobsExplicitAndScoreOhMyRTG() throws Exception {
Random random = random(); Random random = random();
// NOTE: 'ssto' is the missing one // NOTE: 'ssto' is the missing one
final List<String> fl = Arrays.asList final List<String> fl = Arrays.asList
// NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well. // NOTE: once testDocIdAugmenterRTG can pass, [docid] should be tested here as well.
// NOTE: once testFunctionsAndScoreRTG can pass, abs(val_i) should be tested here as well
("id","[explain]","score","val_*","subj*"); ("id","[explain]","score","val_*","subj*");
final int iters = atLeast(random, 10); final int iters = atLeast(random, 10);
@ -738,10 +742,11 @@ public class TestPseudoReturnFields extends SolrTestCaseJ4 {
,"count(//doc)=1" ,"count(//doc)=1"
,"//doc/str[@name='id']" ,"//doc/str[@name='id']"
// ,"//doc/int[@name='[docid]']" // TODO // ,"//doc/int[@name='[docid]']" // TODO
// ,"//doc/gloat[@name='abs(val_i)']" // TODO
// RTG: [explain] and score should be missing (ignored) // RTG: [explain] and score should be missing (ignored)
,"//doc/int[@name='val_i'][.=1]" ,"//doc/int[@name='val_i'][.=1]"
,"//doc/str[@name='subject']" ,"//doc/str[@name='subject']"
,"//result/doc[count(*)=3]" ,"//doc[count(*)=3]"
); );
} }
} }