mirror of https://github.com/apache/lucene.git
SOLR-10383: reduce code duplication in TestOriginalScoreFeature
This commit is contained in:
parent
99af830223
commit
e875f135be
|
@ -53,51 +53,10 @@ public class TestOriginalScoreFeature extends TestRerankBase {
|
||||||
@Test
|
@Test
|
||||||
public void testOriginalScore() throws Exception {
|
public void testOriginalScore() throws Exception {
|
||||||
loadFeature("score", OriginalScoreFeature.class.getCanonicalName(), "{}");
|
loadFeature("score", OriginalScoreFeature.class.getCanonicalName(), "{}");
|
||||||
|
|
||||||
loadModel("originalScore", LinearModel.class.getCanonicalName(),
|
loadModel("originalScore", LinearModel.class.getCanonicalName(),
|
||||||
new String[] {"score"}, "{\"weights\":{\"score\":1.0}}");
|
new String[] {"score"}, "{\"weights\":{\"score\":1.0}}");
|
||||||
|
|
||||||
final SolrQuery query = new SolrQuery();
|
implTestOriginalScoreResponseDocsCheck("originalScore", "score", null, null);
|
||||||
query.setQuery("title:w1");
|
|
||||||
query.add("fl", "*, score");
|
|
||||||
query.add("rows", "4");
|
|
||||||
query.add("wt", "json");
|
|
||||||
|
|
||||||
// Normal term match
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/numFound/==4");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/id=='1'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/id=='8'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/id=='6'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/id=='7'");
|
|
||||||
|
|
||||||
final String res = restTestHarness.query("/query" + query.toQueryString());
|
|
||||||
final Map<String,Object> jsonParse = (Map<String,Object>) ObjectBuilder
|
|
||||||
.fromJSON(res);
|
|
||||||
final String doc0Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
|
||||||
.get("response")).get("docs")).get(0)).get("score")).toString();
|
|
||||||
final String doc1Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
|
||||||
.get("response")).get("docs")).get(1)).get("score")).toString();
|
|
||||||
final String doc2Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
|
||||||
.get("response")).get("docs")).get(2)).get("score")).toString();
|
|
||||||
final String doc3Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
|
||||||
.get("response")).get("docs")).get(3)).get("score")).toString();
|
|
||||||
|
|
||||||
query.add("fl", "[fv]");
|
|
||||||
query.add("rq", "{!ltr model=originalScore reRankDocs=4}");
|
|
||||||
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/numFound/==4");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/id=='1'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/score=="
|
|
||||||
+ doc0Score);
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/id=='8'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/score=="
|
|
||||||
+ doc1Score);
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/id=='6'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/score=="
|
|
||||||
+ doc2Score);
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/id=='7'");
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/score=="
|
|
||||||
+ doc3Score);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -111,12 +70,29 @@ public class TestOriginalScoreFeature extends TestRerankBase {
|
||||||
new String[] {"origScore"}, "store2",
|
new String[] {"origScore"}, "store2",
|
||||||
"{\"weights\":{\"origScore\":1.0}}");
|
"{\"weights\":{\"origScore\":1.0}}");
|
||||||
|
|
||||||
|
implTestOriginalScoreResponseDocsCheck("origScore", "origScore", "c2", "2.0");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void implTestOriginalScoreResponseDocsCheck(String modelName,
|
||||||
|
String origScoreFeatureName,
|
||||||
|
String nonScoringFeatureName, String nonScoringFeatureValue) throws Exception {
|
||||||
|
|
||||||
final SolrQuery query = new SolrQuery();
|
final SolrQuery query = new SolrQuery();
|
||||||
query.setQuery("title:w1");
|
query.setQuery("title:w1");
|
||||||
query.add("fl", "*, score, fv:[fv]");
|
query.add("fl", "*, score");
|
||||||
query.add("rows", "4");
|
query.add("rows", "4");
|
||||||
query.add("wt", "json");
|
query.add("wt", "json");
|
||||||
query.add("rq", "{!ltr model=origScore reRankDocs=4}");
|
|
||||||
|
final int doc0Id = 1;
|
||||||
|
final int doc1Id = 8;
|
||||||
|
final int doc2Id = 6;
|
||||||
|
final int doc3Id = 7;
|
||||||
|
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/numFound/==4");
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/id=='"+doc0Id+"'");
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/id=='"+doc1Id+"'");
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/id=='"+doc2Id+"'");
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/id=='"+doc3Id+"'");
|
||||||
|
|
||||||
final String res = restTestHarness.query("/query" + query.toQueryString());
|
final String res = restTestHarness.query("/query" + query.toQueryString());
|
||||||
final Map<String,Object> jsonParse = (Map<String,Object>) ObjectBuilder
|
final Map<String,Object> jsonParse = (Map<String,Object>) ObjectBuilder
|
||||||
|
@ -130,20 +106,43 @@ public class TestOriginalScoreFeature extends TestRerankBase {
|
||||||
final String doc3Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
final String doc3Score = ((Double) ((Map<String,Object>) ((ArrayList<Object>) ((Map<String,Object>) jsonParse
|
||||||
.get("response")).get("docs")).get(3)).get("score")).toString();
|
.get("response")).get("docs")).get(3)).get("score")).toString();
|
||||||
|
|
||||||
|
final boolean debugQuery = false;
|
||||||
|
|
||||||
|
query.remove("fl");
|
||||||
|
query.add("fl", "*, score, fv:[fv]");
|
||||||
|
query.add("rq", "{!ltr model="+modelName+" reRankDocs=4}");
|
||||||
|
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/numFound/==4");
|
assertJQ("/query" + query.toQueryString(), "/response/numFound/==4");
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/id=='1'");
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[0]/id=='"+doc0Id+"'");
|
||||||
assertJQ("/query" + query.toQueryString(),
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/id=='"+doc1Id+"'");
|
||||||
"/response/docs/[0]/fv=='" + FeatureLoggerTestUtils.toFeatureVector("origScore", doc0Score, "c2", "2.0")+"'");
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/id=='"+doc2Id+"'");
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[1]/id=='8'");
|
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/id=='"+doc3Id+"'");
|
||||||
|
|
||||||
assertJQ("/query" + query.toQueryString(),
|
implTestOriginalScoreResponseDocsCheck(modelName, query, 0, doc0Id, origScoreFeatureName, doc0Score,
|
||||||
"/response/docs/[1]/fv=='" + FeatureLoggerTestUtils.toFeatureVector("origScore", doc1Score, "c2", "2.0")+"'");
|
nonScoringFeatureName, nonScoringFeatureValue, debugQuery);
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[2]/id=='6'");
|
implTestOriginalScoreResponseDocsCheck(modelName, query, 1, doc1Id, origScoreFeatureName, doc1Score,
|
||||||
assertJQ("/query" + query.toQueryString(),
|
nonScoringFeatureName, nonScoringFeatureValue, debugQuery);
|
||||||
"/response/docs/[2]/fv=='" + FeatureLoggerTestUtils.toFeatureVector("origScore", doc2Score, "c2", "2.0")+"'");
|
implTestOriginalScoreResponseDocsCheck(modelName, query, 2, doc2Id, origScoreFeatureName, doc2Score,
|
||||||
assertJQ("/query" + query.toQueryString(), "/response/docs/[3]/id=='7'");
|
nonScoringFeatureName, nonScoringFeatureValue, debugQuery);
|
||||||
assertJQ("/query" + query.toQueryString(),
|
implTestOriginalScoreResponseDocsCheck(modelName, query, 3, doc3Id, origScoreFeatureName, doc3Score,
|
||||||
"/response/docs/[3]/fv=='" + FeatureLoggerTestUtils.toFeatureVector("origScore", doc3Score, "c2", "2.0")+"'");
|
nonScoringFeatureName, nonScoringFeatureValue, debugQuery);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void implTestOriginalScoreResponseDocsCheck(String modelName,
|
||||||
|
SolrQuery query, int docIdx, int docId,
|
||||||
|
String origScoreFeatureName, String origScoreFeatureValue,
|
||||||
|
String nonScoringFeatureName, String nonScoringFeatureValue,
|
||||||
|
boolean debugQuery) throws Exception {
|
||||||
|
|
||||||
|
final String fv;
|
||||||
|
if (nonScoringFeatureName == null) {
|
||||||
|
fv = FeatureLoggerTestUtils.toFeatureVector(origScoreFeatureName, origScoreFeatureValue);
|
||||||
|
} else {
|
||||||
|
fv = FeatureLoggerTestUtils.toFeatureVector(origScoreFeatureName, origScoreFeatureValue, nonScoringFeatureName, nonScoringFeatureValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
assertJQ("/query" + query.toQueryString(), "/response/docs/["+docIdx+"]/fv=='"+fv+"'");
|
||||||
|
// TODO: use debugQuery
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue