Application.scala 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. package controllers
  2. import play.api.Play.current
  3. import play.api.mvc._
  4. import play.api.libs.json._
  5. import scala.concurrent.forkjoin.ThreadLocalRandom
  6. import scala.concurrent.Future
  7. import play.modules.reactivemongo.ReactiveMongoPlugin
  8. import play.modules.reactivemongo.json.collection.JSONCollection
  9. import play.api.libs.concurrent.Execution.Implicits._
  10. object Application extends Controller {
  11. private val TestDatabaseRows = 10000
  12. private val database = ReactiveMongoPlugin.db
  13. private def collection: JSONCollection = database.collection[JSONCollection]("world")
  14. private val projection = Json.obj("_id" -> 0)
  15. def db(queries: Int) = Action {
  16. import scala.concurrent.ExecutionContext.Implicits.global
  17. Async {
  18. val random = ThreadLocalRandom.current()
  19. val futureWorlds = Future.sequence((for {
  20. _ <- 1 to queries
  21. } yield { collection
  22. .find(Json.obj("id" -> (random.nextInt(TestDatabaseRows) + 1)), projection)
  23. .cursor[JsValue]
  24. .toList
  25. }))
  26. futureWorlds.map { worlds =>
  27. Ok(Json.toJson(worlds))
  28. }
  29. }
  30. }
  31. }