2017-08-22 58 views
0

我有这个控制台应用程序生成一组伪造的数据/数据库信息进行测试。在mscorlib.dll中发生类型'System.ArgumentOutOfRangeException'的异常,但未在用户代码中处理

public List<LCS_ExchangeDataStaging> GenerateNewData(int count) 
      { 
       var newData = new List<LCS_ExchangeDataStaging>(); 
       var random = new Random(); 
       var branches = new LCSBranchContext().GetAllBranches(); 
       var schemeIds = new LCSSchemePortfolioContext().SchemePortfolios(); 

      var branchCount = branches.Count - 1; 
      var schemeCount = schemeIds.Count - 1; 

      Parallel.For(1, count + 1, i => 
      { 
       int gender = random.Next(0, 1); 

       var data = new LCS_ExchangeDataStaging 
       { 
        AccountNumber = (3000000000 + random.Next(999999999)).ToString(), 
        AccountStatement = random.Next(), 
        Address = Faker.Address.StreetAddress(), 
        AddressOfKeyContact = Faker.Address.StreetAddress(), 
        Age = RandomDate(DateTime.Now.AddYears(-70), DateTime.Now.AddYears(-18), random), 
        AmountDisbursed = Faker.RandomNumber.Next(20000000), 
        AmountOverdue = Faker.RandomNumber.Next(1000000), 
        BranchName = branches[random.Next(branchCount)].Name, 
        ClientId = $"R{(Faker.RandomNumber.Next(99999999) + 200000000).ToString()}", 
        ClientName = gender == 0 ? NameGenerator.Generate(Gender.Male) : NameGenerator.Generate(Gender.Female), 
        CompaniesMandate = "", 
        DateOfIncorporation = RandomDate(DateTime.Now.AddYears(-70), DateTime.Now, random), 
        DaysPastDue = 1, 
        DisbursmentDate = RandomDate(DateTime.Now.AddYears(-3), DateTime.Now, random), 
        Email = Faker.Internet.Email(), 
        EmergencyContact = Faker.Name.FullName(), 
        EmployeeContact = Faker.Name.FullName(), 
        EmployeeContactTelePhone = Faker.Phone.Number(), 
        EmployerAddress = Faker.Address.StreetAddress(), 
        EmployerName = Faker.Company.Name(), 
        EmployerTelephone = Faker.Phone.Number(), 
        ExpiryDate = RandomDate(DateTime.Now.AddYears(1), DateTime.Now.AddYears(7), random), 
        FeesOverdue = Faker.RandomNumber.Next(2000), 
        Gender = gender == 0 ? "M" : "F", 
        GuarantorAddress = Faker.Address.StreetAddress(), 
        GuarantorName = Faker.Name.FullName(), 
        GuarantorTelephone = Faker.Phone.Number(), 
        Income = random.Next(50000, 1000000), 
        InsuranceCompany = Faker.Company.Name(), 
        InsuredAmount = Faker.RandomNumber.Next(2000), 
        InterestRate = random.Next(3, 24), 
        IntrducerAddress = Faker.Address.StreetAddress(), 
        IntrestOverdue = Faker.RandomNumber.Next(2000), 
        IntroducerName = Faker.Name.FullName(), 
        IntroducerTelephone = Faker.Phone.Number(), 
        KeyContactPerson = Faker.Name.FullName(), 
        LastCrAmount = Faker.RandomNumber.Next(20000), 
        LastCrDate = RandomDate(DateTime.Now.AddYears(-1), DateTime.Now, random), 
        LienAmount = Faker.RandomNumber.Next(2000), 
        LoanRestructured = "No", 
        MissedPayin24MonthCount = random.Next(0, 15), 
        MonthlyInflow = Faker.RandomNumber.Next(1000000), 
        OperativeAccountNumber = $"01{random.Next(99999999)}", 
        OutstandingPrincipal = Faker.RandomNumber.Next(200000), 
        PenalChargeDue = Faker.RandomNumber.Next(2000), 
        PrincipalOverdue = Faker.RandomNumber.Next(2000), 
        ProductCategory = "", 
        ProductType = "LAA", 
        RelationshipYears = random.Next(0, 40), 
        RepaymentAmount = Faker.RandomNumber.Next(2000), 
        ReturnedChequeIn6MonthCount = random.Next(0, 3), 
        SchemeID = schemeIds[random.Next(schemeCount)].SchemeCode, 
        Telephone1 = Faker.Phone.Number(), 
        Telephone2 = Faker.Phone.Number(), 
        TelephoneOfKeyContact = Faker.Phone.Number(), 
        Tenor = random.Next(3, 124).ToString(), 
       }; 

       newData.Add(data); 
      }); 

      return newData; 
     } 

然而,当方法GenerateNewData运行时,我得到这个例外

类型“System.ArgumentOutOfRangeException”的异常出现在mscorlib.dll,但在用户代码中没有处理

附加信息:'maxValue'必须大于零。

System.ArgumentOutOfRangeException was unhandled by user code 
    HResult=-2146233086 
    Message='maxValue' must be greater than zero. 
Parameter name: maxValue 
    ParamName=maxValue 
    Source=mscorlib 
    StackTrace: 
     at System.Random.Next(Int32 maxValue) 
     at RLCS.Tasks.Data.DataGenerator.<>c__DisplayClass1_0.<GenerateNewData>b__0(Int32 i) in C:\Users\Solution Architect\Documents\WORK\lcs\lcs\RLCS.Tasks\Data\DataGenerator.cs:line 50 
     at System.Threading.Tasks.Parallel.<>c__DisplayClass17_0`1.<ForWorker>b__1() 
    InnerException: 

请帮助您对此有任何建议。 谢谢

+0

正如旁注'int gender = random.Next(0,1);'只会生成零,因为上限是排他性的。是否有'branches.Count'或'schemeIds.Count' 0任何机会? – Milster

+1

我认为这可能会导致问题:'SchemeID = schemeIds [random.Next(schemeCount)]。SchemeCode'。你在哪里设置'schemeCount'?错误清楚地说明了这个问题。也可以在'Faker'类中,因为你也使用'Random'对象。尝试调试您的代码。 –

+0

@MichałTurczyn谢谢..是由于'branchCount'和'schemeCount'中的数据不正确,我现在已经修复了这个问题 –

回答

2

很难说,没有运行或看到所有的代码,但问题是,您拨打random.Next(Int32 maxValue)的电话之一是提供Int32 maxValue 0或更少。其范围缩小到以下行之一 -

BranchName = branches[random.Next(branchCount)].Name,

SchemeID = schemeIds[random.Next(schemeCount)].SchemeCode,

所以重要的变量似乎是branchCountschemeCount。这些设置为其各自上下文方法结果的Count - 1

我猜想,无论是LCSBranchContext().GetAllBranches()LCSSchemePortfolioContext().SchemePortfolios()正在返回1或0的结果,我们可以让他们返回更多结果“修复”,但更好的办法是使用Faker.Random.ListItem()和C#6安全导航操作符(?)这样的 -

BranchName = Faker.Random.ListItem(branches)?.Name,

SchemeID = Faker.Random.ListItem(schemeIds)?.SchemeCode,

如果没有在提供的列表中的任何条目这将值设置为null

+0

谢谢@gamesmad。但是,** Faker.Random.ListItem(分支)?。名称,**未被识别。该错误是由于我已经排序的'branchCount'和'schemeCount'中的空/负数据。再次感谢 –

相关问题