这是先前问题的延续,在该问题中我看到我对在 FakeApplication 中使用插件有误解。
首先,我有一个作为特征创建的模型和一个实现它的对象。
trait UserModel extends ModelCompanion[User, ObjectId] {
// ...
}
object User extends UserModel
接下来,我有一个控制器,它被创建为一个接收 UserModel 实例的抽象类,以及它各自使用 User 对象的实现。
abstract class UsersController extends Controller {
val userModel: UserModel
def sayHello = Action(parse.json) { request =>
// return a play Action. It doesn't use userModel
}
// Other methods
}
object Users extends UsersController(User)
在测试目录中,我使用 UserModel 模拟创建了一个 UsersController 存根:
package controllers
import org.specs2.mock.Mockito
object UserControllersTest extends UsersController with Mockito {
val userModel = mock[models.UserModel]
}
现在我有我的 UsersControllers Spec 测试:
package controllers
import org.specs2.mutable.Specification
import play.api.libs.json.Json
import play.api.test._
import play.api.test.Helpers._
class UsersSayHelloSpec extends Specification {
running(FakeApplication()) {
"Users.SayHello" should {
def sendJson(jsonMap: Map[String, String], shouldBeCorrect: Boolean) = {
running(new FakeApplication(
additionalPlugins = Seq("controllers.UserControllersTest"))) {
// Preapration
val jsonRequisition = Json.toJson(jsonMap)
// ***************************************
// It will call UsersControllers.sayHello
val Some(result) = routeAndCall(FakeRequest(POST,
"/hello",
FakeHeaders(Map("Content-Type" -> Seq("application/json"))),
jsonRequisition))
// ***************************************
// ...
}
}
"Not process a empty String" in {
sendJson(Map.empty[String, String], false)
}
// Other tests calling sendJson ...
}
}
}
所以我的问题是:在 routeAndCall() 调用中,当调用“/hello”URL 时,我如何对 FakeApplication 说使用 UserControllersTest 而不是真正的 UserControllers 实现?