mirror of https://github.com/apache/lucene.git
SOLR-8164: fix parsedquery debug output double-parens, add tests
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1710106 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
ab3c1a48cd
commit
8d2a0a135e
|
@ -507,23 +507,9 @@ public class QueryParsing {
|
||||||
out.append('+');
|
out.append('+');
|
||||||
}
|
}
|
||||||
Query subQuery = c.getQuery();
|
Query subQuery = c.getQuery();
|
||||||
boolean wrapQuery = false;
|
|
||||||
|
|
||||||
// TODO: may need to put parens around other types
|
|
||||||
// of queries too, depending on future syntax.
|
|
||||||
if (subQuery instanceof BooleanQuery) {
|
|
||||||
wrapQuery = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (wrapQuery) {
|
|
||||||
out.append('(');
|
|
||||||
}
|
|
||||||
|
|
||||||
toString(subQuery, schema, out, subflag | FLAG_IS_CLAUSE);
|
toString(subQuery, schema, out, subflag | FLAG_IS_CLAUSE);
|
||||||
|
|
||||||
if (wrapQuery) {
|
|
||||||
out.append(')');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (needParens) {
|
if (needParens) {
|
||||||
|
|
|
@ -243,4 +243,39 @@ public class DebugComponentTest extends SolrTestCaseJ4 {
|
||||||
//RID must be added to the toLog, so that it's included in the main request log
|
//RID must be added to the toLog, so that it's included in the main request log
|
||||||
assertEquals(rid, resp.getToLog().get(CommonParams.REQUEST_ID));
|
assertEquals(rid, resp.getToLog().get(CommonParams.REQUEST_ID));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// NOTE: String representations are not meant to be exact or backward compatible.
|
||||||
|
// For example, foo:bar^3, foo:bar^3.0 and (foo:bar)^3 are equivalent. Use your
|
||||||
|
// judgement when modifying these tests.
|
||||||
|
//
|
||||||
|
@Test
|
||||||
|
public void testQueryToString() throws Exception {
|
||||||
|
|
||||||
|
// test that both boosts are represented in a double-boost scenario
|
||||||
|
assertQ(req("debugQuery", "true", "indent","true", "rows","0", "q", "(foo_s:aaa^3)^4"),
|
||||||
|
"//str[@name='parsedquery'][.='foo_s:aaa^3.0^4.0']"
|
||||||
|
);
|
||||||
|
|
||||||
|
// test to see that extra parens are avoided
|
||||||
|
assertQ(req("debugQuery", "true", "indent","true", "rows","0", "q", "+foo_s:aaa^3 -bar_s:bbb^0"),
|
||||||
|
"//str[@name='parsedquery'][.='+foo_s:aaa^3.0 -bar_s:bbb^0.0']"
|
||||||
|
);
|
||||||
|
|
||||||
|
// test that parens are added when needed
|
||||||
|
assertQ(req("debugQuery", "true", "indent", "true", "rows", "0", "q", "foo_s:aaa (bar_s:bbb baz_s:ccc)"),
|
||||||
|
"//str[@name='parsedquery'][.='foo_s:aaa (bar_s:bbb baz_s:ccc)']"
|
||||||
|
);
|
||||||
|
|
||||||
|
// test boosts on subqueries
|
||||||
|
assertQ(req("debugQuery", "true", "indent", "true", "rows", "0", "q", "foo_s:aaa^3 (bar_s:bbb baz_s:ccc)^4"),
|
||||||
|
"//str[@name='parsedquery'][.='foo_s:aaa^3.0 (bar_s:bbb baz_s:ccc)^4.0']"
|
||||||
|
);
|
||||||
|
|
||||||
|
// test constant score query boost exists
|
||||||
|
assertQ(req("debugQuery", "true", "indent", "true", "rows", "0", "q", "foo_s:aaa^=3"),
|
||||||
|
"//str[@name='parsedquery'][contains(.,'3.0')]"
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -151,14 +151,12 @@ public class TestSolrQueryParser extends SolrTestCaseJ4 {
|
||||||
,"/response/docs/[0]/id=='1'"
|
,"/response/docs/[0]/id=='1'"
|
||||||
);
|
);
|
||||||
|
|
||||||
// boost should multiply
|
|
||||||
assertJQ(req("fq","id:1", "fl","id,score", "q", subqq+"^3", "qq","text:x^2"
|
assertJQ(req("fq","id:1", "fl","id,score", "q", subqq+"^3", "qq","text:x^2"
|
||||||
, "debug","query"
|
, "debug","query"
|
||||||
)
|
)
|
||||||
,"/debug/parsedquery_toString=='((text:x)^2.0)^3.0'"
|
,"/debug/parsedquery_toString=='((text:x)^2.0)^3.0'"
|
||||||
);
|
);
|
||||||
|
|
||||||
// boost should multiply
|
|
||||||
assertJQ(req("fq","id:1", "fl","id,score", "q", " {!v=$qq}^3", "qq","text:x^2"
|
assertJQ(req("fq","id:1", "fl","id,score", "q", " {!v=$qq}^3", "qq","text:x^2"
|
||||||
, "debug","query"
|
, "debug","query"
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in New Issue