Query_AsyncMethods_Test.cs 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  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_AsyncMethods_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. [TestMethod]
  104. public async Task Test_First()
  105. {
  106. using var dbContext = DataSource.CreateDbContext();
  107. var userQuery = dbContext.Query<User>();
  108. {
  109. var user = await userQuery.OrderBy(m => m.id).FirstAsync();
  110. Assert.AreEqual(1, user?.id);
  111. }
  112. {
  113. var user = await userQuery.FirstAsync(user => user.id == 3);
  114. Assert.AreEqual(3, user?.id);
  115. }
  116. {
  117. try
  118. {
  119. var user = await userQuery.FirstAsync(user => user.id == 13);
  120. Assert.Fail("IQueryable.First should throw Exception");
  121. }
  122. catch (Exception ex) when (ex is not AssertFailedException)
  123. {
  124. }
  125. }
  126. }
  127. [TestMethod]
  128. public async Task Test_LastOrDefault()
  129. {
  130. using var dbContext = DataSource.CreateDbContext();
  131. var userQuery = dbContext.Query<User>();
  132. {
  133. var id = await userQuery.OrderBy(m => m.id).Select(u => u.id).FirstOrDefaultAsync();
  134. Assert.AreEqual(1, id);
  135. }
  136. {
  137. var user = await userQuery.OrderBy(m => m.id).LastOrDefaultAsync();
  138. Assert.AreEqual(6, user?.id);
  139. }
  140. {
  141. var user = await userQuery.LastOrDefaultAsync(user => user.id == 3);
  142. Assert.AreEqual(3, user?.id);
  143. }
  144. {
  145. var user = await userQuery.LastOrDefaultAsync(user => user.id == 13);
  146. Assert.AreEqual(null, user?.id);
  147. }
  148. {
  149. var user = await userQuery.OrderByDescending(m => m.id).LastOrDefaultAsync();
  150. Assert.AreEqual(1, user?.id);
  151. }
  152. }
  153. [TestMethod]
  154. public async Task Test_Last()
  155. {
  156. using var dbContext = DataSource.CreateDbContext();
  157. var userQuery = dbContext.Query<User>();
  158. {
  159. var user = await userQuery.OrderBy(m => m.id).LastAsync();
  160. Assert.AreEqual(6, user?.id);
  161. }
  162. {
  163. var user = await userQuery.LastAsync(user => user.id == 3);
  164. Assert.AreEqual(3, user?.id);
  165. }
  166. {
  167. try
  168. {
  169. var user = await userQuery.LastAsync(user => user.id == 13);
  170. Assert.Fail("IQueryable.Last should throw Exception");
  171. }
  172. catch (Exception ex) when (ex is not AssertFailedException)
  173. {
  174. }
  175. }
  176. }
  177. }
  178. }