繁体   English   中英

ScalaTest PlayFramework

[英]ScalaTest PlayFramework

在学习游戏框架时尝试做一些TDD:

class ContentFetching extends PlaySpec with BeforeAndAfter with MockFactory
{
  private val service = ContentService

  private val languages = List(Language(Some(1), "en", "English", "Placeholder"),
                               Language(Some(2), "de", "Deutsch", "Platzhalter")
                              )

  "find" must
  {
    "fail if languageCode is invalid" in
    {
      val fakeRepository = mock[LanguageRepositoryTrait]
      (fakeRepository.get _).expects().returning(languages)

      fakeRepository.get must have length 3

      service.find("fr") must be Result.NotFound

    }
  }
}

ContentService将调用:

def fourOhFour() = NotFound(s"Oops, content could not be found")

但断言service.find("fr") must be Result.NotFound不会编译。 为什么会这样,然后如何测试呢? 这是整个contentService(根据要求)可悲的是,它目前正在扩展Controller,因为我发现没有其他方法可以返回Action。 实际上,我使用MVC,但也使用Service +存储库层:

class ContentServiceComponent(languageRepository: LanguageRepositoryTrait, nodeRepository: NodeRepositoryTrait) extends Controller
{
  def find(language: String) = Action
  {
    languageRepository.get().map(l => l.code).contains(language) match
    {
      case true => Ok(s"Homepage for $language")
      case false => fourOhFour()
    }
  }

  def fourOhFour() = NotFound(s"Oops, content could not be found")
}

object ContentService extends ContentServiceComponent(LanguageRepository, NodeRepository)

find代替返回Action可以返回Option

def find(language: String): Option[String] =
  {
    languageRepository.get().map(l => l.code).contains(language) match
    {
      case true => Some(s"Homepage for $language")
      case _ => None
    }
  }

因此,您可以按照以下说明在Controller处处理该问题:

def index(language:String) = Action{

ContentService.find(language) match{
  case Some(content) => Ok(content)
  case _ => NotFound(s"Oops, content could not be found")
}

}

你可以做这样的测试用例:

class ContentFetching extends PlaySpec with BeforeAndAfter with MockFactory
{


  val languages = List(Language(Some(1), "en", "English",Placeholder"),Language(Some(2), "de", "Deutsch", "Platzhalter")
                              )

val languagesRepositoryMockHere = new LanguageRepositoryTrait{ 
    override def get =  languages  //I don't  know the implementations
}

  "find" must
  {
    "fail if languageCode is invalid" in
    {
       private val service = new ContentServiceComponent(languagesRepositoryMockHere,nodeRepositoryMockHere)


      service.find("fr") shouldBe None

    }
  }
}

这未经测试,但可以帮助参考。

干杯。

播放控制器中的service.find(“ fr”)返回结果

也许您正在将Result与Result.Status类型进行比较?

您可以使用play.api.helper吗?

status(of: Future[Result]) = Await.result(of, timeout.duration).header.status

代替

service.find("fr") must be Result.NotFound

尝试这样的事情?

status(service.find("fr")) must be NOT_FOUND

NOT_FOUNDplay.api.http.Status值,仅映射到标准HTTP状态代码404

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM