我有这个绑定来配置我的应用程序中的 Logger[IO] (具有此行的模块在 guice.conf 文件中):
class CatsEffectModule extends AbstractModule with ScalaModule {
override def configure(): Unit = {
bind[Logger[IO]].toInstance(Slf4jLogger.getLogger[IO])
}
}
然后在应用程序中我可以这样做:
@Singleton
class MyClass @Inject()(implicit logger: Logger[IO]) { ... }
这在应用程序中运行良好。
GuiceInjectorBuilder
但是在(用于测试)中使用时它将不起作用:
import play.api.inject.guice.GuiceInjectorBuilder
private val application: Injector = new GuiceInjectorBuilder()
.bindings(bind[ExecutionContext].to(ExecutionContext.global))
.bindings(bind[ApplicationLifecycle].to[DefaultApplicationLifecycle])
.bindings(new CatsEffectModule())
.build()
application.instanceOf[MyClass]
它给了我一个错误:
No implementation for io.chrisdavenport.log4cats.Logger was bound.
[info] Did you mean?
[info] io.chrisdavenport.log4cats.Logger<cats.effect.IO> bound at guice.CatsEffectModule.configure(CatsEffectModule.scala:21) (via modules: com.google.inject.util.Modules$OverrideModule -> guice.CatsEffectModule)
测试中的每个 TF 实体注入都会像这样失败。Akka Play 如何运行 Guice 和 GuiceInjectorBuilder 的工作方式有什么区别吗?