Query_MethodAsync_Test.cs 7.1 KB

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