使用Play应用程序中的两个线程执行异步功能

时间:2016-03-07 21:00:39

标签: multithreading scala playframework future

我正在构建一个假设构建CSV文件的服务方法。文件和结果的标题来自不同的线程。

def buildCsv(template: Template) : Future[TemporaryFile] = {

        val schemaFuture = dbViewSchemaRepository.findOneByTemplateId(template.id)
        val resultsFuture = checklistResultRepository.findAllByTemplateId(template.id)

        schemaFuture flatMap { optSchema =>
            val schema = optSchema match {
                case Some(sch : Schema) => sch
                case _ => throw UnexpectedException("Schema not found")
            }

            //get the titles
            val titles = buildTitles(schema)
            // create temp file
            val tempFile = TemporaryFile("test", ".csv")
            logger.info("Absolute path: " + tempFile.file.getAbsolutePath)

            // start writing results
            resultsFuture map { results =>
                results foreach { result =>
                    val resultRow = buildResultRow(result, schema)

                    tempFile.file.writeCsv(List(resultRow), ',', titles)
                }

                tempFile
            }

        }
    }

我已经构建了一个非常简单的测试:

var dbViewSchemaRepo = mock[DbViewSchemaRepository]
            doReturn(Future(schema)).when(dbViewSchemaRepo).findOneByTemplateId(schema.templateId)

            var checklistResultRepo = mock[ChecklistResultRepository]
            doReturn(Future(List(result))).when(checklistResultRepo).findAllByTemplateId(schema.templateId)

            val template = mock[Template]
            template.id returns schema.templateId

            var srv = new ChecklistResultsExportService(dbViewSchemaRepo, checklistResultRepo)

当我运行它时出现错误:

  

[error] services.data.model.ChecklistSchema $ Schema无法强制转换   to scala.Option(ChecklistResultsExportService.scala:38)[错误]   services.data.ChecklistResultsExportService $$ anonfun $ $ buildCsv 1.适用(ChecklistResultsExportService.scala:38)

第38行是:

schemaFuture flatMap { optSchema

我错过了什么?

感谢。

1 个答案:

答案 0 :(得分:0)

我的问题是我嘲笑存储库对象的响应。我应该这样做:

doReturn(Future.successful(Some(schema))).when(dbViewSchemaRepo).findOneByTemplateId(schema.templateId)     
   doReturn(Future.successful(List(result))).when(checklistResultRepo).findAllByTemplateId(schema.templateId)

现在似乎正在工作。

感谢。