I am using EF4 in my application and I want to make test cases for DAL methods, which generally hit the database to get data. I am using the Typemock framework for Mocking. I want to mock database call and only want to test queries. E.g.:
ObjectContext.Where(u => u.code == Code)
For doing this, I need to make Fake ObjectContext
for EF Models and want to fill some fake data in Fake ObjectContext
so that we can execute our queries (LINQ) on fake ObjectContext
. Kindly suggest how can I can create fake object context(Using TypeMock framework) and fill data in the entities.
For example, I have the following method:
protected IObjectSet<T> CreateObjectSet<T>() where T : EntityBase
{
return _context.CreateObjectSet<T>();
}
And I am creating a test case to mock _context, however _context is null. My test case is:
var fakeInMemoryBlogs = GetUsers();
var fakeContext = Isolate.Fake.Instance<SecurityEntitiesUOW>();
var fakeGenericRepository = Isolate.Fake.Instance<GenericRepository>
(Members.CallOriginal, ConstructorWillBe.Called, fakeContext);
Isolate.WhenCalled(() => fakeContext.Context.CreateObjectSet<SecUser>())
.WillReturnCollectionValuesOf(fakeInMemoryBlogs.AsQueryable());