Mocking LINQ to SQL (Continued…) using OpenAccess
After making the post on mocking LINQ to SQL, this morning i was having a chat with Stephen forte and come to know that Telerik has a new product named Visual Entity Designer that enables you to define your domain model very easily through just few clicks and builds a nice LINQ to SQL model that mimics model similar to Entity framework / MS LINQ to SQL. Being curious, i thought of giving a spin with it and try to mock OpenAccess LINQ to SQL implementation using JustMock.
Now, before i start, i also found that OpenAccess has a free / express version that works on top express databases (Ex. SqlExpress) but supports all the features that full version offers. I will be using the free version here. The download is provided at the end of the post along with a link pointing to Steve's introduction of the designer.
Once you have downloaded OpenAccess Q2, you first need to create a class library project and inside the add item dialog you need to choose “Telerik OpenAccess Domain Model” option . Actually, it looks to me same as creating an entity framework edmx just the extension is rlinq.
Next, it will give you an option to choose an empty model or populating it from your database. I would rather choose to populate it from my Northwind database in SqlExpress. That prompts me up with this screen
Here to note that i actually first found the “New Connection” option disabled [may be due to express version] and set my target database using the “Server Explorer” inside visual studio and found it populated as shown above.
Next, i have to choose a model name and by default it suggests “NorthwithEntityDiagram1” but i prefer to choose “NorthwindDataContext” since things are more with data than with diagram.
Once everything is set. I am off to the main topic. I will use the same example from previous post. Accordingly, i created the EmployeeRepository class:
- public class EmployeeRepository
- {
- public EmployeeRepository(NorthwindDataContext context)
- {
- this.context = context;
- }
- public IQueryable<Employee> GetEmployeesByHire(DateTime frm, DateTime to)
- {
- return from emp in context.Employees
- where emp.HireDate >= frm && emp.HireDate <= to
- select emp;
- }
- private readonly NorthwindDataContext context;
- }
This is plan and simple. There is only method that returns list of employees by hire for a date range. The goal is [those who have missed my previous post] to run the LINQ query into my fake collection to assert the expected behavior of this method.
Therefore, i will be creating a fake data context and for context.Employees i will return my custom collection and finally assert the expected behavior.
- [TestMethod]
- public void ShouldAssertGetEmployeesByHireDate()
- {
- var context = Mock.Create<NorthwindDataContext>();
- var repository = new EmployeeRepository(context);
- Mock.Arrange(() => context.Employees).ReturnsCollection(GetFakeEmployees());
- var employees = repository.GetEmployeesByHire(new DateTime(2008, 1, 1), DateTime.Now);
- Assert.AreEqual(1, employees.Count());
- Assert.AreEqual(3, employees.FirstOrDefault().EmployeeID);
- }
- private static IList<Employee> GetFakeEmployees()
- {
- return new List<Employee>
- {
- new Employee {EmployeeID = 1, HireDate = new DateTime(2004, 12, 1)},
- new Employee {EmployeeID = 2, HireDate = new DateTime(2006, 7, 1)},
- new Employee {EmployeeID = 3, HireDate = new DateTime(2009, 3, 1)}
- };
- }
That’s it. As “ReturnsCollection” does a number of tasks on behalf of the developer and which is not required for all cases except for IQueryable / IEnumerable implementations, having few feedbacks from my last post, we have made this as an extension method. The reason is not to pull it up every time for mocking members where you don’t need it. Therefore, when you need it you just have to include the following line on top your class:
- using Telerik.JustMock.Helpers;
The helpers extension[from SP1] also gives an opportunity to add more domain specific methods like “ReturnsCollection” without ever cluttering the core API.
----
You can check the introductory post from Steve of Visual Entity Designer here:
http://www.stephenforte.net/PermaLink,guid,734374ef-65ac-442c-a8f1-571ca9084729.aspx
The free version of OpenAccess ORM can be found here (there are other free and interesting tools as well):
http://www.telerik.com/community/free-products.aspx
OpenAccess version of the sample can be downloaded from: Here
-----
Enjoy!!
Update : RLINQ is not a product on its own rather a extension that Visual entity designer generates [Pardon my ignorance].