2017-09-17 208 views
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 
+2

“不会编译”是没有问题的一个很好的说明。 –

+0

我认为你需要取消两个级别的最后一行。您显然希望它是该函数的返回值,但现在它在inner for循环内。 –

+0

仍然不起作用我想测试它10次,但它仍然不起作用 –

回答

0

这工作在Visual Studio 2017年编译和测试,它与府中

// random test cases... 
open Fuchu 
open System 
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 = Assert.Equal("expected == actual?", OpenOrSenior expected, actual) 
type _testcases = {_expected : int list list ; _actual : string list} 
let mutable testCasesList = [] 

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 
     testCasesList <- {_expected = expected; _actual = actual} :: testCasesList 

[<Tests>] 
let __suite = 
    testList "Random Tests!" [testCase "Should return test results.." <| (fun _ -> 
      for i in testCasesList do 
       Randomtests i._expected i._actual) 
       ]