对于使用 Reader 在单元测试中不完全组合步骤的理解
For comprehension not composing steps fully in unit test using Reader
我有一个带有单元测试的无标记最终实现,当我 运行 单元测试时只调用第一步而不调用其余步骤。
这里是测试目标:
class NameThing[F[_]: Monad](implicit console: Console[F]) {
def program: F[Unit] = for {
_ <- console.prompt
rawName <- console.read
fullName = parse(rawName)
_ <- console.display(fullName)
} yield ()
def parse(rawName:String):FullName = {
val parts = rawName.split(" ")
FullName(parts(0), parts(1))
}
}
单元测试是:
implicit object TestConsole extends Console[Test] {
override def prompt: Test[Unit] = {
println("ok1")
Reader(TestEnv => TestEnv.prompt)
}
override def read: Test[String] = {
println("ok2")
Reader(TestEnv => TestEnv.read)
}
override def display(fullName: FullName): Test[Unit] = {
println("ok3")
Reader(TestEnv => TestEnv.display(fullName.toString))
}
}
val result = new NameThing[Test]().program.run
我只看到ok1显示。
完整代码在这里:https://bitbucket.org/jameskingconsulting/scala-effects
尝试
new NameThing[Test]().program.run(TestEnv())
new NameThing[Test]().program.run
只是一个 TestEnv => Unit
(其中 .run
是 Kleisli
的 run
),你应该在 [=16= 上调用它] 实际上 运行 程序。
我有一个带有单元测试的无标记最终实现,当我 运行 单元测试时只调用第一步而不调用其余步骤。
这里是测试目标:
class NameThing[F[_]: Monad](implicit console: Console[F]) {
def program: F[Unit] = for {
_ <- console.prompt
rawName <- console.read
fullName = parse(rawName)
_ <- console.display(fullName)
} yield ()
def parse(rawName:String):FullName = {
val parts = rawName.split(" ")
FullName(parts(0), parts(1))
}
}
单元测试是:
implicit object TestConsole extends Console[Test] {
override def prompt: Test[Unit] = {
println("ok1")
Reader(TestEnv => TestEnv.prompt)
}
override def read: Test[String] = {
println("ok2")
Reader(TestEnv => TestEnv.read)
}
override def display(fullName: FullName): Test[Unit] = {
println("ok3")
Reader(TestEnv => TestEnv.display(fullName.toString))
}
}
val result = new NameThing[Test]().program.run
我只看到ok1显示。
完整代码在这里:https://bitbucket.org/jameskingconsulting/scala-effects
尝试
new NameThing[Test]().program.run(TestEnv())
new NameThing[Test]().program.run
只是一个 TestEnv => Unit
(其中 .run
是 Kleisli
的 run
),你应该在 [=16= 上调用它] 实际上 运行 程序。