@casekit/orm2 0.0.0-20250322230249

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (275) hide show
  1. package/build/builders/buildCount.d.ts +23 -0
  2. package/build/builders/buildCount.js +63 -0
  3. package/build/builders/buildCount.test.d.ts +1 -0
  4. package/build/builders/buildCount.test.js +144 -0
  5. package/build/builders/buildCreate.d.ts +5 -0
  6. package/build/builders/buildCreate.js +28 -0
  7. package/build/builders/buildCreate.test.d.ts +1 -0
  8. package/build/builders/buildCreate.test.js +47 -0
  9. package/build/builders/buildDelete.d.ts +5 -0
  10. package/build/builders/buildDelete.js +28 -0
  11. package/build/builders/buildDelete.test.d.ts +1 -0
  12. package/build/builders/buildDelete.test.js +108 -0
  13. package/build/builders/buildFind.d.ts +8 -0
  14. package/build/builders/buildFind.js +185 -0
  15. package/build/builders/buildFind.test.d.ts +1 -0
  16. package/build/builders/buildFind.test.js +263 -0
  17. package/build/builders/buildUpdate.d.ts +5 -0
  18. package/build/builders/buildUpdate.js +34 -0
  19. package/build/builders/buildUpdate.test.d.ts +1 -0
  20. package/build/builders/buildUpdate.test.js +130 -0
  21. package/build/builders/buildWhere.d.ts +6 -0
  22. package/build/builders/buildWhere.js +63 -0
  23. package/build/builders/buildWhere.test.d.ts +1 -0
  24. package/build/builders/buildWhere.test.js +154 -0
  25. package/build/builders/types.d.ts +87 -0
  26. package/build/builders/types.js +1 -0
  27. package/build/connection.d.ts +31 -0
  28. package/build/connection.js +206 -0
  29. package/build/index.d.ts +10 -0
  30. package/build/index.js +5 -0
  31. package/build/operators.d.ts +59 -0
  32. package/build/operators.js +44 -0
  33. package/build/orm.count.d.ts +14 -0
  34. package/build/orm.count.js +22 -0
  35. package/build/orm.createMany.d.ts +5 -0
  36. package/build/orm.createMany.js +26 -0
  37. package/build/orm.createOne.d.ts +5 -0
  38. package/build/orm.createOne.js +34 -0
  39. package/build/orm.d.ts +81 -0
  40. package/build/orm.deleteMany.d.ts +5 -0
  41. package/build/orm.deleteMany.js +26 -0
  42. package/build/orm.deleteOne.d.ts +5 -0
  43. package/build/orm.deleteOne.js +32 -0
  44. package/build/orm.findMany.d.ts +8 -0
  45. package/build/orm.findMany.js +64 -0
  46. package/build/orm.findOne.d.ts +5 -0
  47. package/build/orm.findOne.js +20 -0
  48. package/build/orm.js +243 -0
  49. package/build/orm.restrict.d.ts +6 -0
  50. package/build/orm.restrict.js +52 -0
  51. package/build/orm.updateMany.d.ts +5 -0
  52. package/build/orm.updateMany.js +29 -0
  53. package/build/orm.updateOne.d.ts +5 -0
  54. package/build/orm.updateOne.js +35 -0
  55. package/build/sql/countToSql.d.ts +3 -0
  56. package/build/sql/countToSql.js +11 -0
  57. package/build/sql/countToSql.test.d.ts +1 -0
  58. package/build/sql/countToSql.test.js +218 -0
  59. package/build/sql/createToSql.d.ts +3 -0
  60. package/build/sql/createToSql.js +27 -0
  61. package/build/sql/createToSql.test.d.ts +1 -0
  62. package/build/sql/createToSql.test.js +186 -0
  63. package/build/sql/deleteToSql.d.ts +3 -0
  64. package/build/sql/deleteToSql.js +15 -0
  65. package/build/sql/deleteToSql.test.d.ts +1 -0
  66. package/build/sql/deleteToSql.test.js +93 -0
  67. package/build/sql/findToSql.d.ts +3 -0
  68. package/build/sql/findToSql.js +33 -0
  69. package/build/sql/findToSql.test.d.ts +1 -0
  70. package/build/sql/findToSql.test.js +409 -0
  71. package/build/sql/updateToSql.d.ts +3 -0
  72. package/build/sql/updateToSql.js +16 -0
  73. package/build/sql/updateToSql.test.d.ts +1 -0
  74. package/build/sql/updateToSql.test.js +165 -0
  75. package/build/sql/util.d.ts +11 -0
  76. package/build/sql/util.js +36 -0
  77. package/build/sql/util.test.d.ts +1 -0
  78. package/build/sql/util.test.js +163 -0
  79. package/build/tests/connection.test.d.ts +1 -0
  80. package/build/tests/connection.test.js +304 -0
  81. package/build/tests/datatypes.test.d.ts +1 -0
  82. package/build/tests/datatypes.test.js +239 -0
  83. package/build/tests/operators.test.d.ts +1 -0
  84. package/build/tests/operators.test.js +125 -0
  85. package/build/tests/orm.count.middleware.test.d.ts +1 -0
  86. package/build/tests/orm.count.middleware.test.js +132 -0
  87. package/build/tests/orm.count.test-d.d.ts +1 -0
  88. package/build/tests/orm.count.test-d.js +60 -0
  89. package/build/tests/orm.count.test.d.ts +1 -0
  90. package/build/tests/orm.count.test.js +151 -0
  91. package/build/tests/orm.createMany.middleware.test.d.ts +1 -0
  92. package/build/tests/orm.createMany.middleware.test.js +63 -0
  93. package/build/tests/orm.createMany.test-d.d.ts +1 -0
  94. package/build/tests/orm.createMany.test-d.js +131 -0
  95. package/build/tests/orm.createMany.test.d.ts +1 -0
  96. package/build/tests/orm.createMany.test.js +392 -0
  97. package/build/tests/orm.createOne.middleware.test.d.ts +1 -0
  98. package/build/tests/orm.createOne.middleware.test.js +54 -0
  99. package/build/tests/orm.createOne.test-d.d.ts +1 -0
  100. package/build/tests/orm.createOne.test-d.js +113 -0
  101. package/build/tests/orm.createOne.test.d.ts +1 -0
  102. package/build/tests/orm.createOne.test.js +268 -0
  103. package/build/tests/orm.deleteMany.middleware.test.d.ts +1 -0
  104. package/build/tests/orm.deleteMany.middleware.test.js +77 -0
  105. package/build/tests/orm.deleteMany.test-d.d.ts +1 -0
  106. package/build/tests/orm.deleteMany.test-d.js +179 -0
  107. package/build/tests/orm.deleteMany.test.d.ts +1 -0
  108. package/build/tests/orm.deleteMany.test.js +394 -0
  109. package/build/tests/orm.deleteOne.middleware.test.d.ts +1 -0
  110. package/build/tests/orm.deleteOne.middleware.test.js +61 -0
  111. package/build/tests/orm.deleteOne.test-d.d.ts +1 -0
  112. package/build/tests/orm.deleteOne.test-d.js +179 -0
  113. package/build/tests/orm.deleteOne.test.d.ts +1 -0
  114. package/build/tests/orm.deleteOne.test.js +360 -0
  115. package/build/tests/orm.findMany.includeManyToMany.test.d.ts +1 -0
  116. package/build/tests/orm.findMany.includeManyToMany.test.js +335 -0
  117. package/build/tests/orm.findMany.includeManyToOne.test.d.ts +1 -0
  118. package/build/tests/orm.findMany.includeManyToOne.test.js +286 -0
  119. package/build/tests/orm.findMany.includeOneToMany.test.d.ts +1 -0
  120. package/build/tests/orm.findMany.includeOneToMany.test.js +530 -0
  121. package/build/tests/orm.findMany.middleware.test.d.ts +1 -0
  122. package/build/tests/orm.findMany.middleware.test.js +66 -0
  123. package/build/tests/orm.findMany.offsetLimit.test.d.ts +1 -0
  124. package/build/tests/orm.findMany.offsetLimit.test.js +108 -0
  125. package/build/tests/orm.findMany.orderBy.test.d.ts +1 -0
  126. package/build/tests/orm.findMany.orderBy.test.js +304 -0
  127. package/build/tests/orm.findMany.select.test.d.ts +1 -0
  128. package/build/tests/orm.findMany.select.test.js +278 -0
  129. package/build/tests/orm.findMany.test-d.d.ts +1 -0
  130. package/build/tests/orm.findMany.test-d.js +374 -0
  131. package/build/tests/orm.findMany.where.test.d.ts +1 -0
  132. package/build/tests/orm.findMany.where.test.js +383 -0
  133. package/build/tests/orm.findOne.middleware.test.d.ts +1 -0
  134. package/build/tests/orm.findOne.middleware.test.js +57 -0
  135. package/build/tests/orm.findOne.test-d.d.ts +1 -0
  136. package/build/tests/orm.findOne.test-d.js +377 -0
  137. package/build/tests/orm.findOne.test.d.ts +1 -0
  138. package/build/tests/orm.findOne.test.js +247 -0
  139. package/build/tests/orm.restrict.test-d.d.ts +1 -0
  140. package/build/tests/orm.restrict.test-d.js +105 -0
  141. package/build/tests/orm.restrict.test.d.ts +1 -0
  142. package/build/tests/orm.restrict.test.js +259 -0
  143. package/build/tests/orm.transact.test.d.ts +1 -0
  144. package/build/tests/orm.transact.test.js +48 -0
  145. package/build/tests/orm.updateMany.middleware.test.d.ts +1 -0
  146. package/build/tests/orm.updateMany.middleware.test.js +72 -0
  147. package/build/tests/orm.updateMany.test.d.ts +1 -0
  148. package/build/tests/orm.updateMany.test.js +210 -0
  149. package/build/tests/orm.updateOne.middleware.test.d.ts +1 -0
  150. package/build/tests/orm.updateOne.middleware.test.js +62 -0
  151. package/build/tests/orm.updateOne.test.d.ts +1 -0
  152. package/build/tests/orm.updateOne.test.js +209 -0
  153. package/build/tests/util/db.d.ts +1571 -0
  154. package/build/tests/util/db.js +10 -0
  155. package/build/tests/util/logger.d.ts +19 -0
  156. package/build/tests/util/logger.js +40 -0
  157. package/build/types/BaseFindParams.d.ts +1 -0
  158. package/build/types/BaseFindParams.js +1 -0
  159. package/build/types/CountParams.d.ts +16 -0
  160. package/build/types/CountParams.js +1 -0
  161. package/build/types/CountParams.test-d.d.ts +1 -0
  162. package/build/types/CountParams.test-d.js +89 -0
  163. package/build/types/CreateManyParams.d.ts +11 -0
  164. package/build/types/CreateManyParams.js +1 -0
  165. package/build/types/CreateManyParams.test-d.d.ts +1 -0
  166. package/build/types/CreateManyParams.test-d.js +83 -0
  167. package/build/types/CreateManyResult.d.ts +5 -0
  168. package/build/types/CreateManyResult.js +1 -0
  169. package/build/types/CreateManyResult.test-d.d.ts +1 -0
  170. package/build/types/CreateManyResult.test-d.js +22 -0
  171. package/build/types/CreateOneParams.d.ts +11 -0
  172. package/build/types/CreateOneParams.js +1 -0
  173. package/build/types/CreateOneParams.test-d.d.ts +1 -0
  174. package/build/types/CreateOneParams.test-d.js +56 -0
  175. package/build/types/CreateOneResult.d.ts +5 -0
  176. package/build/types/CreateOneResult.js +1 -0
  177. package/build/types/CreateOneResult.test-d.d.ts +1 -0
  178. package/build/types/CreateOneResult.test-d.js +23 -0
  179. package/build/types/CreateValues.d.ts +6 -0
  180. package/build/types/CreateValues.js +1 -0
  181. package/build/types/CreateValues.test-d.d.ts +1 -0
  182. package/build/types/CreateValues.test-d.js +60 -0
  183. package/build/types/DeleteManyResult.d.ts +5 -0
  184. package/build/types/DeleteManyResult.js +1 -0
  185. package/build/types/DeleteManyResult.test-d.d.ts +1 -0
  186. package/build/types/DeleteManyResult.test-d.js +23 -0
  187. package/build/types/DeleteOneResult.d.ts +5 -0
  188. package/build/types/DeleteOneResult.js +1 -0
  189. package/build/types/DeleteOneResult.test-d.d.ts +1 -0
  190. package/build/types/DeleteOneResult.test-d.js +23 -0
  191. package/build/types/DeleteParams.d.ts +7 -0
  192. package/build/types/DeleteParams.js +1 -0
  193. package/build/types/DeleteParams.test-d.d.ts +1 -0
  194. package/build/types/DeleteParams.test-d.js +46 -0
  195. package/build/types/FindParams.d.ts +22 -0
  196. package/build/types/FindParams.js +1 -0
  197. package/build/types/FindParams.test-d.d.ts +1 -0
  198. package/build/types/FindParams.test-d.js +107 -0
  199. package/build/types/FindResult.d.ts +13 -0
  200. package/build/types/FindResult.js +1 -0
  201. package/build/types/FindResult.test-d.d.ts +1 -0
  202. package/build/types/FindResult.test-d.js +30 -0
  203. package/build/types/IncludeClause.d.ts +5 -0
  204. package/build/types/IncludeClause.js +1 -0
  205. package/build/types/IncludeClause.test-d.d.ts +1 -0
  206. package/build/types/IncludeClause.test-d.js +69 -0
  207. package/build/types/Middleware.d.ts +51 -0
  208. package/build/types/Middleware.js +37 -0
  209. package/build/types/OptionalValues.d.ts +4 -0
  210. package/build/types/OptionalValues.js +1 -0
  211. package/build/types/OptionalValues.test-d.d.ts +1 -0
  212. package/build/types/OptionalValues.test-d.js +12 -0
  213. package/build/types/OrderByClause.d.ts +9 -0
  214. package/build/types/OrderByClause.js +1 -0
  215. package/build/types/OrderByClause.test-d.d.ts +1 -0
  216. package/build/types/OrderByClause.test-d.js +44 -0
  217. package/build/types/RequiredValues.d.ts +4 -0
  218. package/build/types/RequiredValues.js +1 -0
  219. package/build/types/RequiredValues.test-d.d.ts +1 -0
  220. package/build/types/RequiredValues.test-d.js +22 -0
  221. package/build/types/RestrictModels.d.ts +23 -0
  222. package/build/types/RestrictModels.js +1 -0
  223. package/build/types/RestrictModels.test-d.d.ts +1 -0
  224. package/build/types/RestrictModels.test-d.js +44 -0
  225. package/build/types/ReturningClause.d.ts +3 -0
  226. package/build/types/ReturningClause.js +1 -0
  227. package/build/types/ReturningClause.test-d.d.ts +1 -0
  228. package/build/types/ReturningClause.test-d.js +15 -0
  229. package/build/types/SelectClause.d.ts +3 -0
  230. package/build/types/SelectClause.js +1 -0
  231. package/build/types/SelectClause.test-d.d.ts +1 -0
  232. package/build/types/SelectClause.test-d.js +15 -0
  233. package/build/types/UpdateManyResult.d.ts +5 -0
  234. package/build/types/UpdateManyResult.js +1 -0
  235. package/build/types/UpdateManyResult.test-d.d.ts +1 -0
  236. package/build/types/UpdateManyResult.test-d.js +15 -0
  237. package/build/types/UpdateOneResult.d.ts +5 -0
  238. package/build/types/UpdateOneResult.js +1 -0
  239. package/build/types/UpdateOneResult.test-d.d.ts +1 -0
  240. package/build/types/UpdateOneResult.test-d.js +15 -0
  241. package/build/types/UpdateParams.d.ts +9 -0
  242. package/build/types/UpdateParams.js +1 -0
  243. package/build/types/UpdateParams.test-d.d.ts +1 -0
  244. package/build/types/UpdateParams.test-d.js +29 -0
  245. package/build/types/UpdateValues.d.ts +6 -0
  246. package/build/types/UpdateValues.js +1 -0
  247. package/build/types/UpdateValues.test-d.d.ts +1 -0
  248. package/build/types/UpdateValues.test-d.js +33 -0
  249. package/build/types/WhereClause.d.ts +29 -0
  250. package/build/types/WhereClause.js +1 -0
  251. package/build/types/WhereClause.test-d.d.ts +1 -0
  252. package/build/types/WhereClause.test-d.js +137 -0
  253. package/build/util/getIncludedToManySubqueries.d.ts +12 -0
  254. package/build/util/getIncludedToManySubqueries.js +63 -0
  255. package/build/util/getIncludedToManySubqueries.test.d.ts +1 -0
  256. package/build/util/getIncludedToManySubqueries.test.js +121 -0
  257. package/build/util/getLateralJoinValues.d.ts +4 -0
  258. package/build/util/getLateralJoinValues.js +30 -0
  259. package/build/util/getLateralJoinValues.test.d.ts +1 -0
  260. package/build/util/getLateralJoinValues.test.js +99 -0
  261. package/build/util/hasClauses.d.ts +1 -0
  262. package/build/util/hasClauses.js +9 -0
  263. package/build/util/hasClauses.test.d.ts +1 -0
  264. package/build/util/hasClauses.test.js +15 -0
  265. package/build/util/makeTableAlias.d.ts +1 -0
  266. package/build/util/makeTableAlias.js +10 -0
  267. package/build/util/makeTableAlias.test.d.ts +1 -0
  268. package/build/util/makeTableAlias.test.js +18 -0
  269. package/build/util/resultSchema.d.ts +10 -0
  270. package/build/util/resultSchema.js +42 -0
  271. package/build/util/rowToObject.d.ts +8 -0
  272. package/build/util/rowToObject.js +10 -0
  273. package/build/util/rowToObject.test.d.ts +1 -0
  274. package/build/util/rowToObject.test.js +68 -0
  275. package/package.json +67 -0
@@ -0,0 +1,530 @@
1
+ import { afterAll, beforeAll, beforeEach, describe, expect, test, } from "vitest";
2
+ import { $not } from "../operators.js";
3
+ import { createTestDB } from "./util/db.js";
4
+ describe("findMany: include oneToMany", () => {
5
+ const { db, logger, factory } = createTestDB();
6
+ beforeEach(() => {
7
+ logger.clear();
8
+ });
9
+ beforeAll(async () => {
10
+ await db.connect();
11
+ });
12
+ afterAll(async () => {
13
+ await db.close();
14
+ });
15
+ test("can include oneToMany relations", async () => {
16
+ await db.transact(async (db) => {
17
+ await db.createOne("user", {
18
+ values: factory.user({ id: 1, name: "User 1" }),
19
+ returning: ["id"],
20
+ });
21
+ await db.createOne("user", {
22
+ values: factory.user({ id: 2, name: "User 2" }),
23
+ returning: ["id"],
24
+ });
25
+ await db.createMany("post", {
26
+ values: [
27
+ factory.post({
28
+ id: 1,
29
+ authorId: 1,
30
+ title: "Post 1",
31
+ }),
32
+ factory.post({
33
+ id: 2,
34
+ authorId: 1,
35
+ title: "Post 2",
36
+ }),
37
+ factory.post({
38
+ id: 3,
39
+ authorId: 2,
40
+ title: "Post 3",
41
+ }),
42
+ ],
43
+ });
44
+ const users = await db.findMany("user", {
45
+ select: ["id", "name"],
46
+ include: {
47
+ posts: {
48
+ select: ["id", "title"],
49
+ orderBy: ["id"],
50
+ },
51
+ },
52
+ orderBy: ["id"],
53
+ });
54
+ expect(users).toEqual([
55
+ {
56
+ id: 1,
57
+ name: "User 1",
58
+ posts: [
59
+ { id: 1, title: "Post 1" },
60
+ { id: 2, title: "Post 2" },
61
+ ],
62
+ },
63
+ {
64
+ id: 2,
65
+ name: "User 2",
66
+ posts: [{ id: 3, title: "Post 3" }],
67
+ },
68
+ ]);
69
+ }, { rollback: true });
70
+ });
71
+ test("can filter included oneToMany relations", async () => {
72
+ await db.transact(async (db) => {
73
+ await db.createMany("user", {
74
+ values: [factory.user({ id: 1 }), factory.user({ id: 2 })],
75
+ });
76
+ await db.createMany("post", {
77
+ values: [
78
+ factory.post({
79
+ id: 1,
80
+ authorId: 1,
81
+ publishedAt: new Date("2024-01-01"),
82
+ }),
83
+ factory.post({
84
+ id: 2,
85
+ authorId: 1,
86
+ publishedAt: null,
87
+ }),
88
+ factory.post({
89
+ id: 3,
90
+ authorId: 2,
91
+ publishedAt: new Date("2024-01-02"),
92
+ }),
93
+ factory.post({
94
+ id: 4,
95
+ authorId: 1,
96
+ publishedAt: null,
97
+ }),
98
+ ],
99
+ });
100
+ const users = await db.findMany("user", {
101
+ select: ["id"],
102
+ include: {
103
+ posts: {
104
+ select: ["id", "publishedAt"],
105
+ where: {
106
+ publishedAt: { [$not]: null },
107
+ },
108
+ orderBy: ["id"],
109
+ },
110
+ },
111
+ orderBy: ["id"],
112
+ });
113
+ expect(users).toEqual([
114
+ {
115
+ id: 1,
116
+ posts: [{ id: 1, publishedAt: new Date("2024-01-01") }],
117
+ },
118
+ {
119
+ id: 2,
120
+ posts: [{ id: 3, publishedAt: new Date("2024-01-02") }],
121
+ },
122
+ ]);
123
+ }, { rollback: true });
124
+ });
125
+ test("can order included oneToMany relations", async () => {
126
+ await db.transact(async (db) => {
127
+ await db.createMany("user", {
128
+ values: [factory.user({ id: 1 }), factory.user({ id: 2 })],
129
+ });
130
+ // Create posts with overlapping creation dates
131
+ await db.createMany("post", {
132
+ values: [
133
+ factory.post({
134
+ id: 1,
135
+ authorId: 1,
136
+ createdAt: new Date("2024-01-01"),
137
+ }),
138
+ factory.post({
139
+ id: 2,
140
+ authorId: 1,
141
+ createdAt: new Date("2024-01-03"),
142
+ }),
143
+ factory.post({
144
+ id: 3,
145
+ authorId: 2,
146
+ createdAt: new Date("2024-01-02"),
147
+ }),
148
+ factory.post({
149
+ id: 4,
150
+ authorId: 2,
151
+ createdAt: new Date("2024-01-04"),
152
+ }),
153
+ ],
154
+ });
155
+ const users = await db.findMany("user", {
156
+ select: ["id"],
157
+ include: {
158
+ posts: {
159
+ select: ["id", "createdAt"],
160
+ orderBy: [["createdAt", "desc"]],
161
+ },
162
+ },
163
+ orderBy: ["id"],
164
+ });
165
+ expect(users).toEqual([
166
+ {
167
+ id: 1,
168
+ posts: [
169
+ { id: 2, createdAt: new Date("2024-01-03") },
170
+ { id: 1, createdAt: new Date("2024-01-01") },
171
+ ],
172
+ },
173
+ {
174
+ id: 2,
175
+ posts: [
176
+ { id: 4, createdAt: new Date("2024-01-04") },
177
+ { id: 3, createdAt: new Date("2024-01-02") },
178
+ ],
179
+ },
180
+ ]);
181
+ }, { rollback: true });
182
+ });
183
+ test("can limit and offset included oneToMany relations", async () => {
184
+ await db.transact(async (db) => {
185
+ await db.createMany("user", {
186
+ values: [factory.user({ id: 1 }), factory.user({ id: 2 })],
187
+ });
188
+ // Create multiple posts for each user
189
+ await db.createMany("post", {
190
+ values: [
191
+ factory.post({
192
+ id: 1,
193
+ authorId: 1,
194
+ }),
195
+ factory.post({
196
+ id: 2,
197
+ authorId: 1,
198
+ }),
199
+ factory.post({
200
+ id: 3,
201
+ authorId: 1,
202
+ }),
203
+ factory.post({
204
+ id: 4,
205
+ authorId: 2,
206
+ }),
207
+ factory.post({
208
+ id: 5,
209
+ authorId: 2,
210
+ }),
211
+ factory.post({
212
+ id: 6,
213
+ authorId: 2,
214
+ }),
215
+ ],
216
+ });
217
+ const users = await db.findMany("user", {
218
+ select: ["id"],
219
+ include: {
220
+ posts: {
221
+ select: ["id"],
222
+ orderBy: ["id"],
223
+ limit: 2,
224
+ offset: 1,
225
+ },
226
+ },
227
+ orderBy: ["id"],
228
+ });
229
+ expect(users).toEqual([
230
+ {
231
+ id: 1,
232
+ posts: [{ id: 2 }, { id: 3 }],
233
+ },
234
+ {
235
+ id: 2,
236
+ posts: [{ id: 5 }, { id: 6 }],
237
+ },
238
+ ]);
239
+ }, { rollback: true });
240
+ });
241
+ test("can include nested relations in oneToMany relations", async () => {
242
+ await db.transact(async (db) => {
243
+ // Create users and colors first
244
+ await db.createMany("user", {
245
+ values: [
246
+ factory.user({ id: 1, name: "User 1" }),
247
+ factory.user({ id: 2, name: "User 2" }),
248
+ ],
249
+ });
250
+ await db.createMany("color", {
251
+ values: [
252
+ factory.color({ hex: "#FF0000", name: "Red" }),
253
+ factory.color({ hex: "#00FF00", name: "Green" }),
254
+ ],
255
+ });
256
+ // Create posts with N:1 relations to colors
257
+ await db.createMany("post", {
258
+ values: [
259
+ factory.post({
260
+ id: 1,
261
+ authorId: 1,
262
+ title: "Post 1",
263
+ backgroundColorValue: "#FF0000",
264
+ }),
265
+ factory.post({
266
+ id: 2,
267
+ authorId: 1,
268
+ title: "Post 2",
269
+ backgroundColorValue: "#00FF00",
270
+ }),
271
+ ],
272
+ });
273
+ // Create likes (N:N relation via post -> likes <- user)
274
+ await db.createMany("like", {
275
+ values: [
276
+ factory.like({ id: 1, userId: 2, postId: 1 }),
277
+ factory.like({ id: 2, userId: 2, postId: 2 }),
278
+ ],
279
+ });
280
+ const users = await db.findMany("user", {
281
+ select: ["id", "name"],
282
+ include: {
283
+ posts: {
284
+ select: ["id", "title"],
285
+ include: {
286
+ backgroundColor: {
287
+ select: ["hex", "name"],
288
+ },
289
+ likes: {
290
+ select: ["id"],
291
+ include: {
292
+ user: {
293
+ select: ["id", "name"],
294
+ },
295
+ },
296
+ },
297
+ },
298
+ orderBy: ["id"],
299
+ },
300
+ },
301
+ orderBy: ["id"],
302
+ });
303
+ expect(users).toEqual([
304
+ {
305
+ id: 1,
306
+ name: "User 1",
307
+ posts: [
308
+ {
309
+ id: 1,
310
+ title: "Post 1",
311
+ backgroundColor: {
312
+ hex: "#FF0000",
313
+ name: "Red",
314
+ },
315
+ likes: [
316
+ {
317
+ id: 1,
318
+ user: { id: 2, name: "User 2" },
319
+ },
320
+ ],
321
+ },
322
+ {
323
+ id: 2,
324
+ title: "Post 2",
325
+ backgroundColor: {
326
+ hex: "#00FF00",
327
+ name: "Green",
328
+ },
329
+ likes: [
330
+ {
331
+ id: 2,
332
+ user: { id: 2, name: "User 2" },
333
+ },
334
+ ],
335
+ },
336
+ ],
337
+ },
338
+ {
339
+ id: 2,
340
+ name: "User 2",
341
+ posts: [],
342
+ },
343
+ ]);
344
+ }, { rollback: true });
345
+ });
346
+ test("can filter and order deeply nested relations", async () => {
347
+ await db.transact(async (db) => {
348
+ await db.createMany("user", {
349
+ values: [factory.user({ id: 1 }), factory.user({ id: 2 })],
350
+ });
351
+ await db.createMany("color", {
352
+ values: [
353
+ factory.color({ hex: "#FF0000", name: "Red" }),
354
+ factory.color({ hex: "#00FF00", name: "Green" }),
355
+ ],
356
+ });
357
+ await db.createMany("post", {
358
+ values: [
359
+ factory.post({
360
+ id: 1,
361
+ authorId: 1,
362
+ backgroundColorValue: "#FF0000",
363
+ createdAt: new Date("2024-01-01"),
364
+ }),
365
+ factory.post({
366
+ id: 2,
367
+ authorId: 1,
368
+ backgroundColorValue: "#00FF00",
369
+ createdAt: new Date("2024-01-02"),
370
+ }),
371
+ ],
372
+ });
373
+ await db.createMany("like", {
374
+ values: [
375
+ factory.like({
376
+ id: 1,
377
+ userId: 2,
378
+ postId: 1,
379
+ createdAt: new Date("2024-01-03"),
380
+ }),
381
+ factory.like({
382
+ id: 2,
383
+ userId: 1,
384
+ postId: 1,
385
+ createdAt: new Date("2024-01-04"),
386
+ }),
387
+ factory.like({
388
+ id: 3,
389
+ userId: 2,
390
+ postId: 2,
391
+ createdAt: new Date("2024-01-04"),
392
+ }),
393
+ ],
394
+ });
395
+ const users = await db.findMany("user", {
396
+ select: ["id"],
397
+ include: {
398
+ posts: {
399
+ select: ["id"],
400
+ where: {},
401
+ include: {
402
+ backgroundColor: {
403
+ select: ["name"],
404
+ where: {
405
+ name: "Red",
406
+ },
407
+ },
408
+ likes: {
409
+ select: ["id", "createdAt"],
410
+ orderBy: [["createdAt", "desc"]],
411
+ include: {
412
+ user: {
413
+ select: ["id"],
414
+ },
415
+ },
416
+ },
417
+ },
418
+ },
419
+ },
420
+ orderBy: ["id"],
421
+ });
422
+ expect(users).toEqual([
423
+ {
424
+ id: 1,
425
+ posts: [
426
+ {
427
+ id: 1,
428
+ backgroundColor: { name: "Red" },
429
+ likes: [
430
+ {
431
+ id: 2,
432
+ createdAt: new Date("2024-01-04"),
433
+ user: { id: 1 },
434
+ },
435
+ {
436
+ id: 1,
437
+ createdAt: new Date("2024-01-03"),
438
+ user: { id: 2 },
439
+ },
440
+ ],
441
+ },
442
+ ],
443
+ },
444
+ {
445
+ id: 2,
446
+ posts: [],
447
+ },
448
+ ]);
449
+ }, { rollback: true });
450
+ });
451
+ test("can include oneToMany relations with multi-field joins", async () => {
452
+ await db.transact(async (db) => {
453
+ await db.createMany("user", {
454
+ values: [
455
+ factory.user({ id: 1, name: "Lynne Tillman" }),
456
+ factory.user({ id: 2, name: "Stewart Home" }),
457
+ factory.user({ id: 3, name: "Judith Butler" }),
458
+ ],
459
+ });
460
+ await db.createMany("friendship", {
461
+ values: [
462
+ factory.friendship({ userId: 1, friendId: 2 }),
463
+ factory.friendship({ userId: 1, friendId: 3 }),
464
+ ],
465
+ });
466
+ await db.createMany("friendshipStats", {
467
+ values: [
468
+ factory.friendshipStats({
469
+ id: 1,
470
+ userId: 1,
471
+ friendId: 2,
472
+ messagesSent: 100,
473
+ likesGiven: 50,
474
+ }),
475
+ factory.friendshipStats({
476
+ id: 2,
477
+ userId: 1,
478
+ friendId: 3,
479
+ messagesSent: 200,
480
+ likesGiven: 75,
481
+ }),
482
+ ],
483
+ });
484
+ const users = await db.findMany("user", {
485
+ select: ["id"],
486
+ include: {
487
+ friendships: {
488
+ select: ["userId", "friendId"],
489
+ include: {
490
+ friend: {
491
+ select: ["id", "name"],
492
+ },
493
+ stats: {
494
+ select: ["messagesSent", "likesGiven"],
495
+ },
496
+ },
497
+ },
498
+ },
499
+ orderBy: ["id"],
500
+ });
501
+ expect(users).toEqual([
502
+ {
503
+ id: 1,
504
+ friendships: [
505
+ {
506
+ userId: 1,
507
+ friendId: 2,
508
+ friend: { id: 2, name: "Stewart Home" },
509
+ stats: { messagesSent: 100, likesGiven: 50 },
510
+ },
511
+ {
512
+ userId: 1,
513
+ friendId: 3,
514
+ friend: { id: 3, name: "Judith Butler" },
515
+ stats: { messagesSent: 200, likesGiven: 75 },
516
+ },
517
+ ],
518
+ },
519
+ {
520
+ id: 2,
521
+ friendships: [],
522
+ },
523
+ {
524
+ id: 3,
525
+ friendships: [],
526
+ },
527
+ ]);
528
+ }, { rollback: true });
529
+ });
530
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,66 @@
1
+ import { afterAll, beforeAll, beforeEach, describe, expect, test, vi, } from "vitest";
2
+ import { config } from "@casekit/orm2-fixtures";
3
+ import { orm } from "../orm.js";
4
+ import { mockLogger } from "./util/logger.js";
5
+ describe("orm.findMany: middleware", () => {
6
+ const logger = mockLogger();
7
+ let db;
8
+ beforeEach(() => {
9
+ logger.clear();
10
+ });
11
+ beforeAll(async () => {
12
+ db = orm({ ...config, logger });
13
+ await db.connect();
14
+ });
15
+ afterAll(async () => {
16
+ await db.close();
17
+ });
18
+ describe("findMany middleware", () => {
19
+ test("it allows overriding the orm's findMany method", async () => {
20
+ await db.transact(async (db) => {
21
+ // Create multiple test users
22
+ await db.createMany("user", {
23
+ values: [
24
+ {
25
+ id: 1,
26
+ name: "Test User 1",
27
+ email: "test1@example.com",
28
+ role: "user",
29
+ },
30
+ {
31
+ id: 2,
32
+ name: "Test User 2",
33
+ email: "test2@example.com",
34
+ role: "admin",
35
+ },
36
+ ],
37
+ returning: ["id"],
38
+ });
39
+ const stub = vi.fn();
40
+ const dbWithMiddleware = db.middleware([
41
+ {
42
+ findMany: (db, table, query) => {
43
+ stub("called stub in middleware 1");
44
+ return db.findMany(table, query);
45
+ },
46
+ },
47
+ {
48
+ findMany: (db, table, query) => {
49
+ stub("called stub in middleware 2");
50
+ return db.findMany(table, query);
51
+ },
52
+ },
53
+ ]);
54
+ const results = await dbWithMiddleware.findMany("user", {
55
+ select: ["id", "name"],
56
+ where: { role: "user" },
57
+ });
58
+ expect(results).toEqual([{ id: 1, name: "Test User 1" }]);
59
+ expect(stub.mock.calls).toEqual([
60
+ ["called stub in middleware 1"],
61
+ ["called stub in middleware 2"],
62
+ ]);
63
+ }, { rollback: true });
64
+ });
65
+ });
66
+ });
@@ -0,0 +1 @@
1
+ export {};