Я пытаюсь написать следующую спецификацию, используя Specs2, но не могу заставить ее работать, компилятор всегда жалуется на то, что «неявное представление не доступно из Unit => org.specs2.execute.Result».
Вот источник теста:
"generate the correct output when merging an extraction" in {
val source = new File("src/test/resources/sample-docs/text-and-image-on-page-2.pdf")
val output = this.extractor.extract(source)
val pdfGenerator = new ITextPdfGenerator()
val processor = new ExecutableProcessor()
val ocrInput = IOUtils.createTempFile("ocr_input", "pdf")
val ocrOutput = IOUtils.createTempFile("ocr_output", "pdf")
deleteWhenDone[MatchResult[Any]](output.getFullTextFile, ocrInput, ocrOutput) ( {
pdfGenerator.generatePdf(source, ocrInput, output.getPagesWithImages)
processor.process(ocrInput, ocrOutput)
this.extractor.mergeExtraction(output, ocrOutput)
IOUtils.readFile(output.getFullTextFile) === """sample text on line 1 page 1 sample text on line 2 page 1 sample text on line 1 page 3 sample text on line 2 page 3 """
})
}
И функция удаления после завершения выглядит следующим образом:
def deleteWhenDone[T]( files : File* ) ( fn : => T ) {
try {
fn
} finally {
IOUtils.deleteFiles( files )
}
}
Если эта строка находится в конце спецификации, она делаетработа:
IOUtils.readFile(output.getFullTextFile) === "sample text on line 1 page 1 sample text on line 2 page 1 sample text on line 1 page 3 sample text on line 2 page 3 "
Почему бы это не сработало, как это, и что я могу сделать, чтобы по-прежнему использовать замыкание и получить тест для компиляции?
РЕДАКТИРОВАТЬ
Изменен вызов deleteWhenDone:
deleteWhenDone[Result](output.getFullTextFile, ocrInput, ocrOutput) ( {
pdfGenerator.generatePdf(source, ocrInput, output.getPagesWithImages)
processor.process(ocrInput, ocrOutput)
this.extractor.mergeExtraction(output, ocrOutput)
IOUtils.readFile(output.getFullTextFile) === "sample text on line 1 page 1 sample text on line 2 page 1 sample text on line 1 page 3 sample text on line 2 page 3 "
})
Но все равно не работает.
РЕДАКТИРОВАТЬ 2
Благодаря ответу Рафаэляокончательный код, который заставил его работать, был:
def deleteWhenDone[T]( files : File* ) ( fn : => T ) : T = {
try {
fn
} finally {
IOUtils.deleteFiles( files )
}
}
Я пропустил тип возврата метода.Спасибо!