1
我试图在F中用Fuchu生成随机单元测试。如何在for循环中生成府中单元测试用例
我正在用正常的控制台应用程序在Vs 2017中执行我的代码。
问题是GeneraterandomTests
不能编译。
open Fuchu
let OpenOrSenior xs =
[for (x:List<int>) in xs do
if x.[0] >= 55 && x.[1] > 7 then yield "Senior" else yield "Open"]
let rand = new Random()
type ClubMember = {Age:int;Handi:int}
let values = [
{Age = 10;Handi=2}
{Age=25;Handi=9}
{Age=75;Handi=2}
{Age=20;Handi=25}
{Age=1;Handi=1}
{Age=90;Handi=8}
{Age=79;Handi=12}
{Age=99;Handi=18}
{Age=75;Handi=8}
{Age=76;Handi=9}
]
let SelectMember (mem:ClubMember) =
match mem with
| x when (mem.Age >= 55) && (mem.Handi > 7) -> "Senior"
| _ -> "Open"
let PutAttributesInList (mem:ClubMember) =
match mem with
| _ -> [mem.Age; mem.Handi]
let Randomtests expected actual = testCase "Randomness" <|
fun _ -> Assert.Equal("expected == actual?", OpenOrSenior expected, actual)
[<Tests>]
let GeneraterandomTests =
for i in 1..10 do
let mutable expected:int list list = []
let mutable actual: string list = []
for _i in 1..5 do
let mutable rndNumb = rand.Next(0,9)
actual <- SelectMember values.[rndNumb] :: actual
expected <- PutAttributesInList values.[rndNumb] :: expected
Randomtests expected actual
“不会编译”是没有问题的一个很好的说明。 –
我认为你需要取消两个级别的最后一行。您显然希望它是该函数的返回值,但现在它在inner for循环内。 –
仍然不起作用我想测试它10次,但它仍然不起作用 –