|
@@ -1,6 +1,7 @@
|
|
|
package controllers;
|
|
|
|
|
|
import models.World;
|
|
|
+import play.libs.Akka;
|
|
|
import play.libs.F;
|
|
|
import play.libs.Json;
|
|
|
|
|
@@ -10,6 +11,7 @@ import org.codehaus.jackson.node.ObjectNode;
|
|
|
import org.codehaus.jackson.map.ObjectMapper;
|
|
|
import play.mvc.Controller;
|
|
|
import play.mvc.Result;
|
|
|
+import scala.concurrent.ExecutionContext;
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
@@ -24,6 +26,8 @@ public class Application extends Controller {
|
|
|
//http://stackoverflow.com/questions/3907929/should-i-make-jacksons-objectmapper-as-static-final
|
|
|
private static final ObjectMapper objectMapper = new ObjectMapper();
|
|
|
|
|
|
+ private static final ExecutionContext dbEc = Akka.system().dispatchers().lookup("db");
|
|
|
+
|
|
|
public static Result json() {
|
|
|
final ObjectNode result = objectMapper.createObjectNode();
|
|
|
result.put("message", "Hello World!");
|
|
@@ -38,6 +42,7 @@ public class Application extends Controller {
|
|
|
final Random random = ThreadLocalRandom.current();
|
|
|
final List<F.Promise<? extends World>> promises = new ArrayList<F.Promise<? extends World>>(queries);
|
|
|
for (int i = 0; i < queries; ++i) {
|
|
|
+ //FIXME: How do we express the use of dbEc here?
|
|
|
promises.add(future(findWorld(Long.valueOf(random.nextInt(TEST_DATABASE_ROWS) + 1))));
|
|
|
}
|
|
|
final List<World> worlds = F.Promise.sequence(promises).get(5L * queries, TimeUnit.SECONDS);
|