Query_MethodAsync_Test.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. using System.Data;
  2. using Microsoft.VisualStudio.TestTools.UnitTesting;
  3. using Vit.Linq;
  4. namespace Vitorm.MsTest.CommonTest
  5. {
  6. [TestClass]
  7. public class Query_MethodAsync_Test
  8. {
  9. [TestMethod]
  10. public async Task Test_PlainQuery()
  11. {
  12. using var dbContext = DataSource.CreateDbContext();
  13. var userQuery = dbContext.Query<User>();
  14. {
  15. var userList = await userQuery.OrderBy(m => m.id).ToListAsync();
  16. Assert.AreEqual(6, userList.Count);
  17. Assert.AreEqual(1, userList.First().id);
  18. Assert.AreEqual(6, userList.Last().id);
  19. }
  20. {
  21. var userList = await userQuery.OrderBy(m => m.id).Select(u => u.id).ToListAsync();
  22. Assert.AreEqual(6, userList.Count);
  23. Assert.AreEqual(1, userList.First());
  24. Assert.AreEqual(6, userList.Last());
  25. }
  26. }
  27. [TestMethod]
  28. public async Task Test_Count()
  29. {
  30. using var dbContext = DataSource.CreateDbContext();
  31. var userQuery = dbContext.Query<User>();
  32. // Count
  33. {
  34. var query = userQuery.Where(user => user.id > 2);
  35. var count = await query.CountAsync();
  36. Assert.AreEqual(4, count);
  37. }
  38. // Skip Take Count
  39. {
  40. var query = userQuery.Where(user => user.id > 2);
  41. query = query.Skip(1).Take(10);
  42. var count = await query.CountAsync();
  43. Assert.AreEqual(3, count);
  44. }
  45. }
  46. [TestMethod]
  47. public async Task Test_TotalCount()
  48. {
  49. using var dbContext = DataSource.CreateDbContext();
  50. var userQuery = dbContext.Query<User>();
  51. // TotalCountAsync
  52. {
  53. var query = userQuery.Where(user => user.id > 2);
  54. var count = await query.TotalCountAsync();
  55. Assert.AreEqual(4, count);
  56. }
  57. // Skip Take TotalCountAsync
  58. {
  59. var query = userQuery.Where(user => user.id > 2);
  60. query = query.Skip(1).Take(10);
  61. var count = await query.TotalCountAsync();
  62. Assert.AreEqual(4, count);
  63. }
  64. }
  65. [TestMethod]
  66. public async Task Test_ToListAndTotal()
  67. {
  68. using var dbContext = DataSource.CreateDbContext();
  69. // ToListAndTotalCount
  70. {
  71. var query = dbContext.Query<User>().Where(user => user.id > 2).Skip(1).Take(2);
  72. var (list, totalCount) = await query.ToListAndTotalCountAsync();
  73. Assert.AreEqual(2, list.Count);
  74. Assert.AreEqual(4, totalCount);
  75. }
  76. }
  77. [TestMethod]
  78. public async Task Test_FirstOrDefault()
  79. {
  80. using var dbContext = DataSource.CreateDbContext();
  81. var userQuery = dbContext.Query<User>();
  82. {
  83. var id = await userQuery.OrderBy(m => m.id).Select(u => u.id).FirstOrDefaultAsync();
  84. Assert.AreEqual(1, id);
  85. }
  86. {
  87. var user = await userQuery.OrderBy(m => m.id).FirstOrDefaultAsync();
  88. Assert.AreEqual(1, user?.id);
  89. }
  90. {
  91. var user = await userQuery.FirstOrDefaultAsync(user => user.id == 3);
  92. Assert.AreEqual(3, user?.id);
  93. }
  94. {
  95. var user = await userQuery.FirstOrDefaultAsync(user => user.id == 13);
  96. Assert.AreEqual(null, user?.id);
  97. }
  98. {
  99. var user = await userQuery.OrderByDescending(m => m.id).FirstOrDefaultAsync();
  100. Assert.AreEqual(6, user?.id);
  101. }
  102. {
  103. var user = await userQuery.OrderBy(m => m.id).Skip(1).Take(2).FirstOrDefaultAsync();
  104. Assert.AreEqual(2, user?.id);
  105. }
  106. }
  107. [TestMethod]
  108. public async Task Test_First()
  109. {
  110. using var dbContext = DataSource.CreateDbContext();
  111. var userQuery = dbContext.Query<User>();
  112. {
  113. var user = await userQuery.OrderBy(m => m.id).FirstAsync();
  114. Assert.AreEqual(1, user?.id);
  115. }
  116. {
  117. var user = await userQuery.FirstAsync(user => user.id == 3);
  118. Assert.AreEqual(3, user?.id);
  119. }
  120. {
  121. try
  122. {
  123. var user = await userQuery.FirstAsync(user => user.id == 13);
  124. Assert.Fail("IQueryable.First should throw Exception");
  125. }
  126. catch (Exception ex) when (ex is not AssertFailedException)
  127. {
  128. }
  129. }
  130. {
  131. var user = await userQuery.OrderBy(m => m.id).Skip(1).Take(2).FirstAsync();
  132. Assert.AreEqual(2, user?.id);
  133. }
  134. }
  135. [TestMethod]
  136. public async Task Test_LastOrDefault()
  137. {
  138. using var dbContext = DataSource.CreateDbContext();
  139. var userQuery = dbContext.Query<User>();
  140. {
  141. var id = await userQuery.OrderBy(m => m.id).Select(u => u.id).FirstOrDefaultAsync();
  142. Assert.AreEqual(1, id);
  143. }
  144. {
  145. var user = await userQuery.OrderBy(m => m.id).LastOrDefaultAsync();
  146. Assert.AreEqual(6, user?.id);
  147. }
  148. {
  149. var user = await userQuery.LastOrDefaultAsync(user => user.id == 3);
  150. Assert.AreEqual(3, user?.id);
  151. }
  152. {
  153. var user = await userQuery.LastOrDefaultAsync(user => user.id == 13);
  154. Assert.AreEqual(null, user?.id);
  155. }
  156. {
  157. var user = await userQuery.OrderByDescending(m => m.id).LastOrDefaultAsync();
  158. Assert.AreEqual(1, user?.id);
  159. }
  160. {
  161. var user = await userQuery.OrderBy(m => m.id).Skip(1).Take(2).LastOrDefaultAsync();
  162. Assert.AreEqual(3, user?.id);
  163. }
  164. }
  165. [TestMethod]
  166. public async Task Test_Last()
  167. {
  168. using var dbContext = DataSource.CreateDbContext();
  169. var userQuery = dbContext.Query<User>();
  170. {
  171. var user = await userQuery.OrderBy(m => m.id).LastAsync();
  172. Assert.AreEqual(6, user?.id);
  173. }
  174. {
  175. var user = await userQuery.LastAsync(user => user.id == 3);
  176. Assert.AreEqual(3, user?.id);
  177. }
  178. {
  179. try
  180. {
  181. var user = await userQuery.LastAsync(user => user.id == 13);
  182. Assert.Fail("IQueryable.Last should throw Exception");
  183. }
  184. catch (Exception ex) when (ex is not AssertFailedException)
  185. {
  186. }
  187. }
  188. {
  189. var user = await userQuery.OrderBy(m => m.id).Skip(1).Take(2).LastAsync();
  190. Assert.AreEqual(3, user?.id);
  191. }
  192. }
  193. }
  194. }