Debug into Entity Framework Code First
In the beginning, we might think it is not possible to debug our model configuration and seeding method in code first, since those codes cannot be running by clicking the debug button in Visual Studio.
Although the Package Manager Console
command update-database
DOES spit out some Exception info, it is difficult to dig into inner exceptions. For example,
Validation failed for one or more entities. See 'EntityValidationErrors' property for more details.
Here is how we can get more we need.
Inside the Seed
method of the Configuration
class, instead of calling context.SaveChanges()
, we call a method SaveChanges(context)
that wrap context.SaveChanges()
inside a try
:
private static void SaveChanges(DbContext context)
{
try
{
context.SaveChanges();
}
catch (DbEntityValidationException ex)
{
var sb = new StringBuilder();
foreach (var failure in ex.EntityValidationErrors)
{
sb.AppendFormat("{0} failed validation\n", failure.Entry.Entity.GetType());
foreach (var error in failure.ValidationErrors)
{
sb.AppendFormat("- {0} : {1}", error.PropertyName, error.ErrorMessage);
sb.AppendLine();
}
}
throw new DbEntityValidationException(
"Entity Validation Failed - errors follow:\n" +
sb.ToString(), ex
);
}
}
Run update-database
this time, we can see all the inner exceptions:
The field XXX must be a string or array type with a maximum length of '25'.
Written by Blaise Liu
Related protips
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Entity framework
Authors
blaiseliu
9.993K
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#