You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

LuEfCreateDataAccessTest.cs 18KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Luticate2.Utils.Dbo;
  5. using Test.Utils.DataAccess;
  6. using Test.Utils.Dbo.PkBigSerial;
  7. using Test.Utils.Dbo.PkGuid;
  8. using Xunit;
  9. namespace Test.Utils.EfCrubDataAccess
  10. {
  11. public class LuEfCreateDataAccessTest
  12. {
  13. [Fact]
  14. public void TestAddMultiple1()
  15. {
  16. Tests.TestRealDb(context =>
  17. {
  18. var dbos = new List<PkBigSerialAddDbo>
  19. {
  20. new PkBigSerialAddDbo
  21. {
  22. SomeInt = 42,
  23. SomeText = "42"
  24. },
  25. new PkBigSerialAddDbo
  26. {
  27. SomeInt = 21,
  28. SomeText = "24"
  29. }
  30. };
  31. var service = new LuUtilsPkBigSerialDataAccess(context);
  32. var res = service.Add(dbos, enumerable => enumerable);
  33. Assert.Equal(LuStatus.Success, res.Status);
  34. foreach (var dbo in dbos.Zip(res.Data, (dbo, serialDbo) => new KeyValuePair<PkBigSerialAddDbo, PkBigSerialDbo>(dbo, serialDbo)))
  35. {
  36. Assert.NotNull(dbo.Key);
  37. Assert.NotNull(dbo.Value);
  38. Assert.NotEqual(0, dbo.Value.Id);
  39. Assert.Equal(dbo.Key.SomeText, dbo.Value.SomeText);
  40. Assert.Equal(dbo.Key.SomeInt, dbo.Value.SomeInt);
  41. var get = service.GetSingleById(dbo.Value.Id);
  42. Assert.Equal(LuStatus.Success, get.Status);
  43. Assert.Equal(dbo.Key.SomeText, get.Data.SomeText);
  44. Assert.Equal(dbo.Key.SomeInt, get.Data.SomeInt);
  45. Assert.Equal(dbo.Value.Id, get.Data.Id);
  46. }
  47. });
  48. }
  49. [Fact]
  50. public void TestAddMultiple2()
  51. {
  52. Tests.TestRealDb(context =>
  53. {
  54. var dbos = new List<PkBigSerialAddDbo>
  55. {
  56. new PkBigSerialAddDbo
  57. {
  58. SomeInt = 42,
  59. SomeText = "42"
  60. },
  61. new PkBigSerialAddDbo
  62. {
  63. SomeInt = 21,
  64. SomeText = "24"
  65. }
  66. };
  67. var service = new LuUtilsPkBigSerialDataAccess(context);
  68. var res = service.Add(dbos, enumerable => enumerable.Select(dbo => dbo.Id));
  69. Assert.Equal(LuStatus.Success, res.Status);
  70. foreach (var dbo in dbos.Zip(res.Data, (dbo, serialDbo) => new KeyValuePair<PkBigSerialAddDbo, long>(dbo, serialDbo)))
  71. {
  72. Assert.NotNull(dbo.Key);
  73. Assert.NotNull(dbo.Value);
  74. Assert.NotEqual(0, dbo.Value);
  75. var get = service.GetSingleById(dbo.Value);
  76. Assert.Equal(LuStatus.Success, get.Status);
  77. Assert.Equal(dbo.Key.SomeText, get.Data.SomeText);
  78. Assert.Equal(dbo.Key.SomeInt, get.Data.SomeInt);
  79. Assert.Equal(dbo.Value, get.Data.Id);
  80. }
  81. });
  82. }
  83. [Fact]
  84. public void TestAddMultiple3()
  85. {
  86. Tests.TestRealDb(context =>
  87. {
  88. var dbos = new List<PkBigSerialAddDbo>
  89. {
  90. new PkBigSerialAddDbo
  91. {
  92. SomeInt = 42,
  93. SomeText = "42"
  94. },
  95. new PkBigSerialAddDbo
  96. {
  97. SomeInt = 21,
  98. SomeText = "24"
  99. }
  100. };
  101. var service = new LuUtilsPkBigSerialDataAccess(context);
  102. var res = service.Add(dbos, enumerable => enumerable.Select(dbo => dbo.CreatedAt));
  103. Assert.Equal(LuStatus.Success, res.Status);
  104. foreach (var dbo in res.Data)
  105. {
  106. Assert.NotEqual(default(DateTime), dbo);
  107. }
  108. });
  109. }
  110. [Fact]
  111. public void TestAddSingle1()
  112. {
  113. Tests.TestRealDb(context =>
  114. {
  115. var service = new LuUtilsPkBigSerialDataAccess(context);
  116. var res = service.Add(new PkBigSerialAddDbo
  117. {
  118. SomeInt = 42,
  119. SomeText = "42"
  120. }, dbo => dbo);
  121. Assert.Equal(LuStatus.Success, res.Status);
  122. Assert.NotEqual(0, res.Data.Id);
  123. Assert.Equal("42", res.Data.SomeText);
  124. Assert.Equal(42, res.Data.SomeInt);
  125. var get = service.GetSingleById(res.Data.Id);
  126. Assert.Equal(LuStatus.Success, get.Status);
  127. Assert.Equal("42", get.Data.SomeText);
  128. Assert.Equal(42, get.Data.SomeInt);
  129. Assert.Equal(res.Data.Id, get.Data.Id);
  130. });
  131. }
  132. [Fact]
  133. public void TestAddSingle2()
  134. {
  135. Tests.TestRealDb(context =>
  136. {
  137. var service = new LuUtilsPkBigSerialDataAccess(context);
  138. var res = service.Add(new PkBigSerialAddDbo
  139. {
  140. SomeInt = 42,
  141. SomeText = "42"
  142. }, dbo => dbo.Id);
  143. Assert.Equal(LuStatus.Success, res.Status);
  144. Assert.NotEqual(0, res.Data);
  145. var get = service.GetSingleById(res.Data);
  146. Assert.Equal(LuStatus.Success, get.Status);
  147. Assert.Equal("42", get.Data.SomeText);
  148. Assert.Equal(42, get.Data.SomeInt);
  149. Assert.Equal(res.Data, get.Data.Id);
  150. });
  151. }
  152. [Fact]
  153. public void TestAddSingle3()
  154. {
  155. Tests.TestRealDb(context =>
  156. {
  157. var service = new LuUtilsPkBigSerialDataAccess(context);
  158. var res = service.Add(new PkBigSerialAddDbo
  159. {
  160. SomeInt = 42,
  161. SomeText = "42"
  162. }, dbo => dbo.CreatedAt);
  163. Assert.Equal(LuStatus.Success, res.Status);
  164. Assert.NotEqual(default(DateTime), res.Data);
  165. });
  166. }
  167. [Fact]
  168. public void TestAddGuidMultiple1()
  169. {
  170. Tests.TestRealDb(context =>
  171. {
  172. var dbos = new List<PkGuidAddDbo>
  173. {
  174. new PkGuidAddDbo
  175. {
  176. SomeInt = 42,
  177. SomeText = "42"
  178. },
  179. new PkGuidAddDbo
  180. {
  181. SomeInt = 21,
  182. SomeText = "24"
  183. }
  184. };
  185. var service = new LuUtilsPkGuidDataAccess(context);
  186. var res = service.AddGuid(dbos);
  187. Assert.Equal(LuStatus.Success, res.Status);
  188. foreach (var dbo in dbos.Zip(res.Data, (dbo, serialDbo) => new KeyValuePair<PkGuidAddDbo, string>(dbo, serialDbo)))
  189. {
  190. Assert.NotNull(dbo.Key);
  191. Assert.NotNull(dbo.Value);
  192. Assert.NotEqual(new Guid().ToString(), dbo.Value);
  193. var get = service.GetSingleById(dbo.Value);
  194. Assert.Equal(LuStatus.Success, get.Status);
  195. Assert.Equal(dbo.Key.SomeText, get.Data.SomeText);
  196. Assert.Equal(dbo.Key.SomeInt, get.Data.SomeInt);
  197. Assert.Equal(dbo.Value, get.Data.Id);
  198. }
  199. });
  200. }
  201. [Fact]
  202. public void TestAddGuidSingle1()
  203. {
  204. Tests.TestRealDb(context =>
  205. {
  206. var service = new LuUtilsPkGuidDataAccess(context);
  207. var res = service.AddGuid(new PkGuidAddDbo
  208. {
  209. SomeInt = 42,
  210. SomeText = "42"
  211. });
  212. Assert.Equal(LuStatus.Success, res.Status);
  213. Assert.NotEqual(new Guid().ToString(), res.Data);
  214. var get = service.GetSingleById(res.Data);
  215. Assert.Equal(LuStatus.Success, get.Status);
  216. Assert.Equal("42", get.Data.SomeText);
  217. Assert.Equal(42, get.Data.SomeInt);
  218. Assert.Equal(res.Data, get.Data.Id);
  219. });
  220. }
  221. [Fact]
  222. public void TestAddIdMultiple1()
  223. {
  224. Tests.TestRealDb(context =>
  225. {
  226. var dbos = new List<PkBigSerialAddDbo>
  227. {
  228. new PkBigSerialAddDbo
  229. {
  230. SomeInt = 42,
  231. SomeText = "42"
  232. },
  233. new PkBigSerialAddDbo
  234. {
  235. SomeInt = 21,
  236. SomeText = "24"
  237. }
  238. };
  239. var service = new LuUtilsPkBigSerialDataAccess(context);
  240. var res = service.AddId(dbos);
  241. Assert.Equal(LuStatus.Success, res.Status);
  242. foreach (var dbo in dbos.Zip(res.Data, (dbo, serialDbo) => new KeyValuePair<PkBigSerialAddDbo, long>(dbo, serialDbo)))
  243. {
  244. Assert.NotNull(dbo.Key);
  245. Assert.NotNull(dbo.Value);
  246. Assert.NotEqual(0, dbo.Value);
  247. var get = service.GetSingleById(dbo.Value);
  248. Assert.Equal(LuStatus.Success, get.Status);
  249. Assert.Equal(dbo.Key.SomeText, get.Data.SomeText);
  250. Assert.Equal(dbo.Key.SomeInt, get.Data.SomeInt);
  251. Assert.Equal(dbo.Value, get.Data.Id);
  252. }
  253. });
  254. }
  255. [Fact]
  256. public void TestAddIdSingle1()
  257. {
  258. Tests.TestRealDb(context =>
  259. {
  260. var service = new LuUtilsPkBigSerialDataAccess(context);
  261. var res = service.AddId(new PkBigSerialAddDbo
  262. {
  263. SomeInt = 42,
  264. SomeText = "42"
  265. });
  266. Assert.Equal(LuStatus.Success, res.Status);
  267. Assert.NotEqual(0, res.Data);
  268. var get = service.GetSingleById(res.Data);
  269. Assert.Equal(LuStatus.Success, get.Status);
  270. Assert.Equal("42", get.Data.SomeText);
  271. Assert.Equal(42, get.Data.SomeInt);
  272. Assert.Equal(res.Data, get.Data.Id);
  273. });
  274. }
  275. [Fact]
  276. public void TestAddDboMultiple1()
  277. {
  278. Tests.TestRealDb(context =>
  279. {
  280. var dbos = new List<PkBigSerialAddDbo>
  281. {
  282. new PkBigSerialAddDbo
  283. {
  284. SomeInt = 42,
  285. SomeText = "42"
  286. },
  287. new PkBigSerialAddDbo
  288. {
  289. SomeInt = 21,
  290. SomeText = "24"
  291. }
  292. };
  293. var service = new LuUtilsPkBigSerialDataAccess(context);
  294. var res = service.AddDbo(dbos);
  295. Assert.Equal(LuStatus.Success, res.Status);
  296. foreach (var dbo in dbos.Zip(res.Data, (dbo, serialDbo) => new KeyValuePair<PkBigSerialAddDbo, PkBigSerialDbo>(dbo, serialDbo)))
  297. {
  298. Assert.NotNull(dbo.Key);
  299. Assert.NotNull(dbo.Value);
  300. Assert.NotEqual(0, dbo.Value.Id);
  301. var get = service.GetSingleById(dbo.Value.Id);
  302. Assert.Equal(LuStatus.Success, get.Status);
  303. Assert.Equal(dbo.Key.SomeText, get.Data.SomeText);
  304. Assert.Equal(dbo.Key.SomeInt, get.Data.SomeInt);
  305. Assert.Equal(dbo.Value.Id, get.Data.Id);
  306. }
  307. });
  308. }
  309. [Fact]
  310. public void TestAddDboSingle1()
  311. {
  312. Tests.TestRealDb(context =>
  313. {
  314. var service = new LuUtilsPkBigSerialDataAccess(context);
  315. var res = service.AddDbo(new PkBigSerialAddDbo
  316. {
  317. SomeInt = 42,
  318. SomeText = "42"
  319. });
  320. Assert.Equal(LuStatus.Success, res.Status);
  321. Assert.NotEqual(0, res.Data.Id);
  322. var get = service.GetSingleById(res.Data.Id);
  323. Assert.Equal(LuStatus.Success, get.Status);
  324. Assert.Equal("42", get.Data.SomeText);
  325. Assert.Equal(42, get.Data.SomeInt);
  326. Assert.Equal(res.Data.Id, get.Data.Id);
  327. });
  328. }
  329. [Fact]
  330. public void TestGetSingle1()
  331. {
  332. Tests.TestRealDb(context =>
  333. {
  334. var service = new LuUtilsPkBigSerialDataAccess(context);
  335. var res = service.AddDbo(new PkBigSerialAddDbo
  336. {
  337. SomeInt = 42,
  338. SomeText = "42"
  339. });
  340. Assert.Equal(LuStatus.Success, res.Status);
  341. Assert.NotEqual(0, res.Data.Id);
  342. var get = service.GetSingle(bigserial => bigserial.some_int == 42);
  343. Assert.Equal(LuStatus.Success, get.Status);
  344. Assert.Equal("42", get.Data.SomeText);
  345. Assert.Equal(42, get.Data.SomeInt);
  346. Assert.Equal(res.Data.Id, get.Data.Id);
  347. });
  348. }
  349. [Fact]
  350. public void TestGetSingle2()
  351. {
  352. Tests.TestRealDb(context =>
  353. {
  354. var service = new LuUtilsPkBigSerialDataAccess(context);
  355. var res = service.AddDbo(new PkBigSerialAddDbo
  356. {
  357. SomeInt = 42,
  358. SomeText = "42"
  359. });
  360. Assert.Equal(LuStatus.Success, res.Status);
  361. Assert.NotEqual(0, res.Data.Id);
  362. var get = service.GetSingle(bigserial => bigserial.some_int == 24);
  363. Assert.Equal(LuStatus.NotFound, get.Status);
  364. });
  365. }
  366. [Fact]
  367. public void TestGetSingleByKeys1()
  368. {
  369. Tests.TestRealDb(context =>
  370. {
  371. var service = new LuUtilsPkBigSerialDataAccess(context);
  372. var res = service.AddDbo(new PkBigSerialAddDbo
  373. {
  374. SomeInt = 42,
  375. SomeText = "42"
  376. });
  377. Assert.Equal(LuStatus.Success, res.Status);
  378. Assert.NotEqual(0, res.Data.Id);
  379. var get = service.GetSingleByKeys(new KeyValuePair<string, object>("some_text", "42"));
  380. Assert.Equal(LuStatus.Success, get.Status);
  381. Assert.Equal("42", get.Data.SomeText);
  382. Assert.Equal(42, get.Data.SomeInt);
  383. Assert.Equal(res.Data.Id, get.Data.Id);
  384. });
  385. }
  386. [Fact]
  387. public void TestGetSingleByKeys2()
  388. {
  389. Tests.TestRealDb(context =>
  390. {
  391. var service = new LuUtilsPkBigSerialDataAccess(context);
  392. var res = service.AddDbo(new PkBigSerialAddDbo
  393. {
  394. SomeInt = 42,
  395. SomeText = "42"
  396. });
  397. Assert.Equal(LuStatus.Success, res.Status);
  398. Assert.NotEqual(0, res.Data.Id);
  399. var get = service.GetSingleByKeys(new KeyValuePair<string, object>("some_text", "24"));
  400. Assert.Equal(LuStatus.NotFound, get.Status);
  401. });
  402. }
  403. [Fact]
  404. public void TestGetSingleById1()
  405. {
  406. Tests.TestRealDb(context =>
  407. {
  408. var service = new LuUtilsPkBigSerialDataAccess(context);
  409. var res = service.AddId(new PkBigSerialAddDbo
  410. {
  411. SomeInt = 42,
  412. SomeText = "42"
  413. });
  414. Assert.Equal(LuStatus.Success, res.Status);
  415. Assert.NotEqual(0, res.Data);
  416. var get = service.GetSingleById(res.Data);
  417. Assert.Equal(LuStatus.Success, get.Status);
  418. Assert.Equal("42", get.Data.SomeText);
  419. Assert.Equal(42, get.Data.SomeInt);
  420. Assert.Equal(res.Data, get.Data.Id);
  421. });
  422. }
  423. [Fact]
  424. public void TestGetSingleById2()
  425. {
  426. Tests.TestRealDb(context =>
  427. {
  428. var service = new LuUtilsPkBigSerialDataAccess(context);
  429. var res = service.AddId(new PkBigSerialAddDbo
  430. {
  431. SomeInt = 42,
  432. SomeText = "42"
  433. });
  434. Assert.Equal(LuStatus.Success, res.Status);
  435. Assert.NotEqual(0, res.Data);
  436. var get = service.GetSingle(bigserial => bigserial.some_int == 24);
  437. Assert.Equal(LuStatus.NotFound, get.Status);
  438. });
  439. }
  440. [Fact]
  441. public void TestGetSingleById3()
  442. {
  443. Tests.TestRealDb(context =>
  444. {
  445. var service = new LuUtilsPkGuidDataAccess(context);
  446. var res = service.AddGuid(new PkGuidAddDbo
  447. {
  448. SomeInt = 42,
  449. SomeText = "42"
  450. });
  451. Assert.Equal(LuStatus.Success, res.Status);
  452. Assert.NotEqual(new Guid().ToString(), res.Data);
  453. var get = service.GetSingleById(res.Data);
  454. Assert.Equal(LuStatus.Success, get.Status);
  455. Assert.Equal("42", get.Data.SomeText);
  456. Assert.Equal(42, get.Data.SomeInt);
  457. Assert.Equal(res.Data, get.Data.Id);
  458. });
  459. }
  460. [Fact]
  461. public void TestGetSingleById4()
  462. {
  463. Tests.TestRealDb(context =>
  464. {
  465. var service = new LuUtilsPkGuidDataAccess(context);
  466. var res = service.AddGuid(new PkGuidAddDbo
  467. {
  468. SomeInt = 42,
  469. SomeText = "42"
  470. });
  471. Assert.Equal(LuStatus.Success, res.Status);
  472. Assert.NotEqual(new Guid().ToString(), res.Data);
  473. var get = service.GetSingle(bigserial => bigserial.some_int == 24);
  474. Assert.Equal(LuStatus.NotFound, get.Status);
  475. });
  476. }
  477. }
  478. }