我希望我只是在看一些非常简单的东西...

由于我没有访问我的个人MSDN(专业)的Fakes的事实,因此我必须提供一个使用Moq的测试。只有高级版和旗舰版才能使用伪造品。单元测试必须能够在不访问任何外部资源的情况下运行。无法使用 Entity Framework DbContext连接到SQL数据库。

public static string ToDetailedString(this Exception ex)
{
    var builder = new StringBuilder();
    AddExceptionToBuilder(builder, ex);
    return builder.ToString();
}

private static void AddExceptionToBuilder(StringBuilder builder, Exception ex)
{
    builder.Append(builder.Length > 0 ? "\r\n" + ex.Message : ex.Message);

    var validationException = ex as DbEntityValidationException;
    if (validationException != null)
    {
        foreach (var detail in validationException.EntityValidationErrors.SelectMany(error => error.ValidationErrors))
        {
            builder.Append("\r\n" + detail.PropertyName + " : " + detail.ErrorMessage);
        }
    }

    if (ex.InnerException != null)
    {
        AddExceptionToBuilder(builder, ex.InnerException);
    }
}

这就是为什么如此难以测试的原因。它不只是创建一个新的DbEntityValidationException那样简单,因为您必须传递DbEntityValidationResult的列表。如果不提供DbEntityEntry,则无法实例化DbEntityValidationResult。我发现创建DbEntityEntry的唯一方法是从DbContext.Entry()获取它。这意味着您必须具有需要访问数据库的有效DbContext。

这是我唯一能够执行的代码,但是它需要访问数据库。
/// <summary>
/// This test method must be ran against the database. I cannot figure out a way to create an entry without
/// a valid context to a real database?
/// </summary>
[TestMethod]
public void ToDetailStringForDbEntityValiditionException()
{
    if (!TestHelper.RunUnitTestAgainstDatabase)
    {
        return;
    }

    var errors = new List<DbValidationError>();
    errors.Add(new DbValidationError("Username", Constants.UsernameLengthError));

    var context = new EntityFrameworkRepository();
    var entry = context.Entry(new User());
    var results = new List<DbEntityValidationResult>();
    var result = new DbEntityValidationResult(entry, errors);
    results.Add(result);

    var exception = new DbEntityValidationException("Registration Failed.", results);

    var expected = "Registration Failed.\r\nUsername : " + Constants.UsernameLengthError;
    var actual = exception.ToDetailedString();

    Assert.AreEqual(expected, actual);
}

最佳答案

这对我有用,使用了我已经设置的实体模型和连接:

var context = new DbContext("name = JobManagerConnection");
var entry = context.Entry(new Models.JobManager.Job());
var errInner = new System.Data.Entity.Validation.DbValidationError("Test Property", "Test Message");
var lstErrInner = new List<System.Data.Entity.Validation.DbValidationError> { errInner };
var errOuter = new System.Data.Entity.Validation.DbEntityValidationResult (entry, lstErrInner);
var lstErrOuter = new List<System.Data.Entity.Validation.DbEntityValidationResult> { errOuter };
throw new System.Data.Entity.Validation.DbEntityValidationException("Test Data Exception", lstErrOuter);

关于c# - 如何测试使用DbEntityValidationException的Exception扩展方法?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/20157579/

10-14 16:07
查看更多