mirror of https://github.com/apache/druid.git
add context serde tests and deprecate backwards compatible methods
This commit is contained in:
parent
bfb66691b9
commit
bae0fdf936
|
@ -75,11 +75,11 @@ public interface Query<T>
|
|||
public <ContextType> ContextType getContextValue(String key, ContextType defaultValue);
|
||||
|
||||
// For backwards compatibility
|
||||
public int getContextPriority(int defaultValue);
|
||||
public boolean getContextBySegment(boolean defaultValue);
|
||||
public boolean getContextPopulateCache(boolean defaultValue);
|
||||
public boolean getContextUseCache(boolean defaultValue);
|
||||
public boolean getContextFinalize(boolean defaultValue);
|
||||
@Deprecated public int getContextPriority(int defaultValue);
|
||||
@Deprecated public boolean getContextBySegment(boolean defaultValue);
|
||||
@Deprecated public boolean getContextPopulateCache(boolean defaultValue);
|
||||
@Deprecated public boolean getContextUseCache(boolean defaultValue);
|
||||
@Deprecated public boolean getContextFinalize(boolean defaultValue);
|
||||
|
||||
public Query<T> withOverriddenContext(Map<String, Object> contextOverride);
|
||||
|
||||
|
|
|
@ -22,6 +22,7 @@
|
|||
package io.druid.query.timeboundary;
|
||||
|
||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||
import com.google.common.collect.ImmutableMap;
|
||||
import io.druid.jackson.DefaultObjectMapper;
|
||||
import io.druid.query.Druids;
|
||||
import io.druid.query.Query;
|
||||
|
@ -47,4 +48,79 @@ public class TimeBoundaryQueryTest
|
|||
Assert.assertEquals(query, serdeQuery);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testContextSerde() throws Exception
|
||||
{
|
||||
final TimeBoundaryQuery query = Druids.newTimeBoundaryQueryBuilder()
|
||||
.dataSource("foo")
|
||||
.intervals("2013/2014")
|
||||
.context(
|
||||
ImmutableMap.<String, Object>of(
|
||||
"priority",
|
||||
1,
|
||||
"useCache",
|
||||
true,
|
||||
"populateCache",
|
||||
true,
|
||||
"finalize",
|
||||
true
|
||||
)
|
||||
).build();
|
||||
|
||||
final ObjectMapper mapper = new DefaultObjectMapper();
|
||||
|
||||
final TimeBoundaryQuery serdeQuery = mapper.readValue(
|
||||
mapper.writeValueAsBytes(
|
||||
mapper.readValue(
|
||||
mapper.writeValueAsString(
|
||||
query
|
||||
), TimeBoundaryQuery.class
|
||||
)
|
||||
), TimeBoundaryQuery.class
|
||||
);
|
||||
|
||||
|
||||
Assert.assertEquals(1, serdeQuery.getContextValue("priority"));
|
||||
Assert.assertEquals(true, serdeQuery.getContextValue("useCache"));
|
||||
Assert.assertEquals(true, serdeQuery.getContextValue("populateCache"));
|
||||
Assert.assertEquals(true, serdeQuery.getContextValue("finalize"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testContextSerde2() throws Exception
|
||||
{
|
||||
final TimeBoundaryQuery query = Druids.newTimeBoundaryQueryBuilder()
|
||||
.dataSource("foo")
|
||||
.intervals("2013/2014")
|
||||
.context(
|
||||
ImmutableMap.<String, Object>of(
|
||||
"priority",
|
||||
"1",
|
||||
"useCache",
|
||||
"true",
|
||||
"populateCache",
|
||||
"true",
|
||||
"finalize",
|
||||
"true"
|
||||
)
|
||||
).build();
|
||||
|
||||
final ObjectMapper mapper = new DefaultObjectMapper();
|
||||
|
||||
final TimeBoundaryQuery serdeQuery = mapper.readValue(
|
||||
mapper.writeValueAsBytes(
|
||||
mapper.readValue(
|
||||
mapper.writeValueAsString(
|
||||
query
|
||||
), TimeBoundaryQuery.class
|
||||
)
|
||||
), TimeBoundaryQuery.class
|
||||
);
|
||||
|
||||
|
||||
Assert.assertEquals("1", serdeQuery.getContextValue("priority"));
|
||||
Assert.assertEquals("true", serdeQuery.getContextValue("useCache"));
|
||||
Assert.assertEquals("true", serdeQuery.getContextValue("populateCache"));
|
||||
Assert.assertEquals("true", serdeQuery.getContextValue("finalize"));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue