Project is used for testing the performance of selected mapper. The aim is to map the data to the data layer (database) on POCO / DTO objects.
Various methods are used to test the most frequent scenarios in simpler information system.
This project uses the library Simple Injector as simple IoC container for autodiscover.
Used mappers:
- Vanila SqlDataReader
- Dapper
- Entity Framework (v. 6.1.3)
- Entity Framework, used as Unit of Work
- Entity Framework with Automapper
- Tiny Mapper
- Value Injector
- MS SQL Server 2014 Express
- AdventureWorks Sample Database 2014
/ | Load large table | Pagged result | Load one row | Load row with joined collection | Combined |
---|---|---|---|---|---|
Dapper | 174 ms | 54 ms | 3 ms | 12 ms | 30803 ms |
Date Reader | 161 ms | 40 ms | 1 ms | 1 ms | 30054 ms |
Date Reader - closing | 154 ms | 48 ms | 2 ms | 1 ms | 30672 ms |
Entity Framework | 648 ms | 88 ms | 24 ms | 57 ms | 39498 ms |
Entity Framework - AutoMapper | 166 ms | 45 ms | 16 ms | 31 ms | 35705 ms |
Entity Framework - UoF | 126 ms | 44 ms | 6 ms | 3 ms | 34842 ms |
Tiny Mapper | 2011 ms | 83 ms | 5 ms | 18 ms | 674694 ms |
Value Injector | 1995 ms | 80 ms | 6 ms | 4 ms | 636656 ms |
For Tiny Mapper and Value Injector results are not relevant, since in these cases need not take the valid mapping.
Added perfmace tests for .Net Core:
- Vanila SqlDataReader
- Dapper (.Net Core version)
- Entity Framework Core
- Entity Framework Core, used as Unit of Work
- Entity Framework Core with Automapper
The MIT License (MIT)
Copyright (c) 2016 harrison314
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.