gpt4 book ai didi

f# - FsUnit.Xunit 列表应该包含一个 x 使得 f x

转载 作者:行者123 更新时间:2023-12-04 08:08:29 26 4
gpt4 key购买 nike

我不确定如何在 FsUnit.Xunit 中编写我的测试。

我想检查列表中至少有一个元素满足谓词。我知道如何使用 should be True 编写此代码,但通常您可以通过使用专门的函数获得更好的错误消息。

希望这段代码能清楚地说明我要实现的目标:

open Xunit
open FsUnit.Xunit

type Foo =
{
X : int
}

[<Fact>]
let ``squares`` () =
let xs =
[ { X = 1 }; { X = 2 }; { X = 3 } ]
|> List.map (fun foo -> { X = foo.X * foo.X })

actual
|> should exists (satisfies (fun foo -> foo.X = 9)) // Not real code

最佳答案

我会这样做:

xs
|> Seq.map (fun foo -> foo.X)
|> should contain 9

错误输出很有用:

Expected: Contains 8
Actual: seq [1; 4; 9]

如果你想要更多上下文,你可以这样做:

open FsUnit.CustomMatchers

...

xs |> should containf (fun foo -> foo.X = 9)

错误输出为:

Expected: Contains <fun:squares@21-1>
Actual: [{ X = 1 }; { X = 4 }; { X = 9 }]

这种方法的唯一缺点是“预期”消息不再显示您要查找的特定值。

关于f# - FsUnit.Xunit 列表应该包含一个 x 使得 f x,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66099569/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com