add a test for retrying multiple times

This commit is contained in:
jisookim0513 2014-06-20 13:15:46 -07:00
parent 1cb3fc250e
commit 3418291333
2 changed files with 97 additions and 0 deletions

View File

@ -25,6 +25,7 @@ public class RetryQueryRunnerConfig
{ {
@JsonProperty @JsonProperty
private int numTries = 0; private int numTries = 0;
@JsonProperty
private boolean returnPartialResults = false; private boolean returnPartialResults = false;
public int numTries() { return numTries; } public int numTries() { return numTries; }

View File

@ -117,6 +117,8 @@ public class RetryQueryRunnerTest
Assert.assertTrue("Should return an empty sequence as a result", ((List) actualResults).size() == 0); Assert.assertTrue("Should return an empty sequence as a result", ((List) actualResults).size() == 0);
} }
@Test @Test
public void testRetry() throws Exception public void testRetry() throws Exception
{ {
@ -210,6 +212,100 @@ public class RetryQueryRunnerTest
Assert.assertTrue("Should have nothing in missingSegment list", ((List) context.get(RetryQueryRunner.missingSegments)).size() == 0); Assert.assertTrue("Should have nothing in missingSegment list", ((List) context.get(RetryQueryRunner.missingSegments)).size() == 0);
} }
@Test
public void testRetryMultiple() throws Exception
{
Map<String, Object> context = new MapMaker().makeMap();
context.put("count", 0);
context.put(RetryQueryRunner.missingSegments, Lists.newArrayList());
RetryQueryRunner runner = new RetryQueryRunner(
new QueryRunner()
{
@Override
public Sequence run(Query query, Map context)
{
if ((int)context.get("count") < 3) {
((List) context.get(RetryQueryRunner.missingSegments)).add(
new SegmentDescriptor(
new Interval(
178888,
1999999
), "test", 1
)
);
context.put("count", (int)context.get("count") + 1);
return Sequences.empty();
} else {
ArrayList lst = new ArrayList();
lst.add("hello world");
return Sequences.simple(lst);
}
}
},
new QueryToolChest()
{
@Override
public QueryRunner mergeResults(QueryRunner runner)
{
return null;
}
@Override
public Sequence mergeSequences(Sequence seqOfSequences)
{
return new OrderedMergeSequence<Result<TimeseriesResultValue>>(getOrdering(), seqOfSequences);
}
@Override
public ServiceMetricEvent.Builder makeMetricBuilder(Query query)
{
return null;
}
@Override
public Function makePreComputeManipulatorFn(
Query query, MetricManipulationFn fn
)
{
return null;
}
@Override
public TypeReference getResultTypeReference()
{
return null;
}
public Ordering<Result<TimeseriesResultValue>> getOrdering()
{
return Ordering.natural();
}
},
new RetryQueryRunnerConfig()
{
private int numTries = 4;
private boolean returnPartialResults = true;
public int numTries() { return numTries; }
public boolean returnPartialResults() { return returnPartialResults; }
}
);
Iterable<Result<TimeseriesResultValue>> actualResults = Sequences.toList(
runner.run(query, context),
Lists.<Result<TimeseriesResultValue>>newArrayList()
);
actualResults = Sequences.toList(
runner.run(query, context),
Lists.<Result<TimeseriesResultValue>>newArrayList()
);
Assert.assertTrue("Should return a list with one element", ((List) actualResults).size() == 1);
Assert.assertTrue("Should have nothing in missingSegment list", ((List) context.get(RetryQueryRunner.missingSegments)).size() == 0);
}
@Test(expected= SegmentMissingException.class) @Test(expected= SegmentMissingException.class)
public void testException() throws Exception public void testException() throws Exception
{ {