SOLR-10383: reduce code duplication in TestOriginalScoreFeature

This commit is contained in:
Christine Poerschke 2017-04-03 12:10:09 +01:00
parent 99af830223
commit e875f135be
1 changed files with 56 additions and 57 deletions

View File

@ -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
} }
} }