@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,383 @@
1
+ import { afterAll, beforeAll, beforeEach, describe, expect, test, } from "vitest";
2
+ import { $and, $eq, $gt, $gte, $ilike, $in, $is, $like, $lt, $lte, $ne, $not, $or, } from "../operators.js";
3
+ import { createTestDB } from "./util/db.js";
4
+ describe("findMany: where", () => {
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
+ describe("basic operators", () => {
16
+ test("a value with no operator performs an equality check", async () => {
17
+ await db.transact(async (db) => {
18
+ await db.createMany("user", {
19
+ values: [
20
+ factory.user({ id: 1, name: "Alice" }),
21
+ factory.user({ id: 2, name: "Bob" }),
22
+ ],
23
+ });
24
+ const users = await db.findMany("user", {
25
+ select: ["id", "name"],
26
+ where: { name: "Alice" },
27
+ });
28
+ expect(users).toEqual([{ id: 1, name: "Alice" }]);
29
+ }, { rollback: true });
30
+ });
31
+ test("$eq operator matches exact values", async () => {
32
+ await db.transact(async (db) => {
33
+ await db.createMany("user", {
34
+ values: [
35
+ factory.user({ id: 1, name: "Alice" }),
36
+ factory.user({ id: 2, name: "Bob" }),
37
+ ],
38
+ });
39
+ const users = await db.findMany("user", {
40
+ select: ["id", "name"],
41
+ where: { name: { [$eq]: "Alice" } },
42
+ });
43
+ expect(users).toEqual([{ id: 1, name: "Alice" }]);
44
+ }, { rollback: true });
45
+ });
46
+ test("$ne operator excludes matching values", async () => {
47
+ await db.transact(async (db) => {
48
+ await db.createMany("user", {
49
+ values: [
50
+ factory.user({ id: 1, name: "Alice" }),
51
+ factory.user({ id: 2, name: "Bob" }),
52
+ ],
53
+ });
54
+ const users = await db.findMany("user", {
55
+ select: ["id", "name"],
56
+ where: { name: { [$ne]: "Alice" } },
57
+ orderBy: ["id"],
58
+ });
59
+ expect(users).toEqual([{ id: 2, name: "Bob" }]);
60
+ }, { rollback: true });
61
+ });
62
+ test("$gt operator compares values correctly", async () => {
63
+ await db.transact(async (db) => {
64
+ await db.createMany("user", {
65
+ values: [
66
+ factory.user({ id: 1 }),
67
+ factory.user({ id: 2 }),
68
+ factory.user({ id: 3 }),
69
+ ],
70
+ });
71
+ const users = await db.findMany("user", {
72
+ select: ["id"],
73
+ where: { id: { [$gt]: 1 } },
74
+ orderBy: ["id"],
75
+ });
76
+ expect(users).toEqual([{ id: 2 }, { id: 3 }]);
77
+ }, { rollback: true });
78
+ });
79
+ test("$gte operator compares values correctly", async () => {
80
+ await db.transact(async (db) => {
81
+ await db.createMany("user", {
82
+ values: [
83
+ factory.user({ id: 1 }),
84
+ factory.user({ id: 2 }),
85
+ factory.user({ id: 3 }),
86
+ ],
87
+ });
88
+ const users = await db.findMany("user", {
89
+ select: ["id"],
90
+ where: { id: { [$gte]: 2 } },
91
+ orderBy: ["id"],
92
+ });
93
+ expect(users).toEqual([{ id: 2 }, { id: 3 }]);
94
+ }, { rollback: true });
95
+ });
96
+ test("$lt operator compares values correctly", async () => {
97
+ await db.transact(async (db) => {
98
+ await db.createMany("user", {
99
+ values: [
100
+ factory.user({ id: 1 }),
101
+ factory.user({ id: 2 }),
102
+ factory.user({ id: 3 }),
103
+ ],
104
+ });
105
+ const users = await db.findMany("user", {
106
+ select: ["id"],
107
+ where: { id: { [$lt]: 3 } },
108
+ orderBy: ["id"],
109
+ });
110
+ expect(users).toEqual([{ id: 1 }, { id: 2 }]);
111
+ }, { rollback: true });
112
+ });
113
+ test("$lte operator compares values correctly", async () => {
114
+ await db.transact(async (db) => {
115
+ await db.createMany("user", {
116
+ values: [
117
+ factory.user({ id: 1 }),
118
+ factory.user({ id: 2 }),
119
+ factory.user({ id: 3 }),
120
+ ],
121
+ });
122
+ const users = await db.findMany("user", {
123
+ select: ["id"],
124
+ where: { id: { [$lte]: 2 } },
125
+ orderBy: ["id"],
126
+ });
127
+ expect(users).toEqual([{ id: 1 }, { id: 2 }]);
128
+ }, { rollback: true });
129
+ });
130
+ });
131
+ describe("array operators", () => {
132
+ test("$in operator matches array of values", async () => {
133
+ await db.transact(async (db) => {
134
+ await db.createMany("user", {
135
+ values: [
136
+ factory.user({ id: 1, name: "Alice" }),
137
+ factory.user({ id: 2, name: "Bob" }),
138
+ factory.user({ id: 3, name: "Charlie" }),
139
+ ],
140
+ });
141
+ const users = await db.findMany("user", {
142
+ select: ["id", "name"],
143
+ where: { name: { [$in]: ["Alice", "Charlie"] } },
144
+ orderBy: ["id"],
145
+ });
146
+ expect(users).toEqual([
147
+ { id: 1, name: "Alice" },
148
+ { id: 3, name: "Charlie" },
149
+ ]);
150
+ }, { rollback: true });
151
+ });
152
+ test("$in operator with empty array returns no results", async () => {
153
+ await db.transact(async (db) => {
154
+ await db.createMany("user", {
155
+ values: [
156
+ factory.user({ id: 1 }),
157
+ factory.user({ id: 2 }),
158
+ ],
159
+ });
160
+ const users = await db.findMany("user", {
161
+ select: ["id"],
162
+ where: { id: { [$in]: [] } },
163
+ });
164
+ expect(users).toEqual([]);
165
+ }, { rollback: true });
166
+ });
167
+ });
168
+ describe("string matching operators", () => {
169
+ test("$like operator matches pattern", async () => {
170
+ await db.transact(async (db) => {
171
+ await db.createMany("user", {
172
+ values: [
173
+ factory.user({ id: 1, name: "Alice" }),
174
+ factory.user({ id: 2, name: "alex" }),
175
+ factory.user({ id: 3, name: "Bob" }),
176
+ ],
177
+ });
178
+ const users = await db.findMany("user", {
179
+ select: ["id", "name"],
180
+ where: { name: { [$like]: "A%" } },
181
+ orderBy: ["id"],
182
+ });
183
+ expect(users).toEqual([{ id: 1, name: "Alice" }]);
184
+ }, { rollback: true });
185
+ });
186
+ test("$ilike operator matches pattern case-insensitive", async () => {
187
+ await db.transact(async (db) => {
188
+ await db.createMany("user", {
189
+ values: [
190
+ factory.user({ id: 1, name: "Alice" }),
191
+ factory.user({ id: 2, name: "alex" }),
192
+ factory.user({ id: 3, name: "Bob" }),
193
+ ],
194
+ });
195
+ const users = await db.findMany("user", {
196
+ select: ["id", "name"],
197
+ where: { name: { [$ilike]: "a%" } },
198
+ orderBy: ["id"],
199
+ });
200
+ expect(users).toEqual([
201
+ { id: 1, name: "Alice" },
202
+ { id: 2, name: "alex" },
203
+ ]);
204
+ }, { rollback: true });
205
+ });
206
+ });
207
+ describe("null handling operators", () => {
208
+ test("null as a value performs an IS NULL check", async () => {
209
+ await db.transact(async (db) => {
210
+ await db.createMany("user", {
211
+ values: [
212
+ factory.user({ id: 1, deletedAt: new Date() }),
213
+ factory.user({ id: 2, deletedAt: null }),
214
+ ],
215
+ });
216
+ const users = await db.findMany("user", {
217
+ select: ["id"],
218
+ where: { deletedAt: null },
219
+ });
220
+ expect(users).toEqual([{ id: 2 }]);
221
+ }, { rollback: true });
222
+ });
223
+ test("$is operator handles null values", async () => {
224
+ await db.transact(async (db) => {
225
+ await db.createMany("user", {
226
+ values: [
227
+ factory.user({ id: 1, deletedAt: new Date() }),
228
+ factory.user({ id: 2, deletedAt: null }),
229
+ ],
230
+ });
231
+ const users = await db.findMany("user", {
232
+ select: ["id"],
233
+ where: { deletedAt: { [$is]: null } },
234
+ });
235
+ expect(users).toEqual([{ id: 2 }]);
236
+ }, { rollback: true });
237
+ });
238
+ test("$not operator with null finds non-null values", async () => {
239
+ await db.transact(async (db) => {
240
+ await db.createMany("user", {
241
+ values: [
242
+ factory.user({ id: 1, deletedAt: new Date() }),
243
+ factory.user({ id: 2, deletedAt: null }),
244
+ ],
245
+ });
246
+ const users = await db.findMany("user", {
247
+ select: ["id"],
248
+ where: { deletedAt: { [$not]: null } },
249
+ });
250
+ expect(users).toEqual([{ id: 1 }]);
251
+ }, { rollback: true });
252
+ });
253
+ });
254
+ describe("logical operators", () => {
255
+ test("$and operator combines conditions", async () => {
256
+ await db.transact(async (db) => {
257
+ await db.createMany("user", {
258
+ values: [
259
+ factory.user({
260
+ id: 1,
261
+ name: "Alice",
262
+ role: "admin",
263
+ }),
264
+ factory.user({ id: 2, name: "Bob", role: "user" }),
265
+ factory.user({
266
+ id: 3,
267
+ name: "Charlie",
268
+ role: "admin",
269
+ }),
270
+ ],
271
+ });
272
+ const users = await db.findMany("user", {
273
+ select: ["id", "name"],
274
+ where: {
275
+ [$and]: [
276
+ { role: "admin" },
277
+ { name: { [$like]: "A%" } },
278
+ ],
279
+ },
280
+ });
281
+ expect(users).toEqual([{ id: 1, name: "Alice" }]);
282
+ }, { rollback: true });
283
+ });
284
+ test("$or operator combines conditions", async () => {
285
+ await db.transact(async (db) => {
286
+ await db.createMany("user", {
287
+ values: [
288
+ factory.user({
289
+ id: 1,
290
+ name: "Alice",
291
+ role: "admin",
292
+ }),
293
+ factory.user({ id: 2, name: "Bob", role: "user" }),
294
+ factory.user({
295
+ id: 3,
296
+ name: "Charlie",
297
+ role: "admin",
298
+ }),
299
+ ],
300
+ });
301
+ const users = await db.findMany("user", {
302
+ select: ["id", "name"],
303
+ where: {
304
+ [$or]: [{ name: "Alice" }, { name: "Bob" }],
305
+ },
306
+ orderBy: ["id"],
307
+ });
308
+ expect(users).toEqual([
309
+ { id: 1, name: "Alice" },
310
+ { id: 2, name: "Bob" },
311
+ ]);
312
+ }, { rollback: true });
313
+ });
314
+ test("can combine $and and $or operators", async () => {
315
+ await db.transact(async (db) => {
316
+ await db.createMany("user", {
317
+ values: [
318
+ factory.user({
319
+ id: 1,
320
+ name: "Alice",
321
+ role: "admin",
322
+ }),
323
+ factory.user({ id: 2, name: "Bob", role: "user" }),
324
+ factory.user({
325
+ id: 3,
326
+ name: "Charlie",
327
+ role: "admin",
328
+ }),
329
+ factory.user({
330
+ id: 4,
331
+ name: "Charlie",
332
+ role: "user",
333
+ }),
334
+ factory.user({
335
+ id: 5,
336
+ name: "David",
337
+ role: "admin",
338
+ }),
339
+ ],
340
+ });
341
+ const users = await db.findMany("user", {
342
+ select: ["id", "name"],
343
+ where: {
344
+ [$and]: [
345
+ { role: "admin" },
346
+ {
347
+ [$or]: [
348
+ { name: "Alice" },
349
+ { name: "Charlie" },
350
+ ],
351
+ },
352
+ ],
353
+ },
354
+ orderBy: ["id"],
355
+ });
356
+ expect(users).toEqual([
357
+ { id: 1, name: "Alice" },
358
+ { id: 3, name: "Charlie" },
359
+ ]);
360
+ }, { rollback: true });
361
+ });
362
+ });
363
+ describe("error cases", () => {
364
+ test("$in operator throws error with non-array value", async () => {
365
+ await db.transact(async (db) => {
366
+ await expect(db.findMany("user", {
367
+ select: ["id"],
368
+ // @ts-expect-error testing invalid value
369
+ where: { id: { [$in]: "not-an-array" } },
370
+ })).rejects.toThrow("Non-array passed to IN clause");
371
+ }, { rollback: true });
372
+ });
373
+ test("$not operator throws error with invalid value", async () => {
374
+ await db.transact(async (db) => {
375
+ await expect(db.findMany("user", {
376
+ select: ["id"],
377
+ // @ts-expect-error testing invalid value
378
+ where: { id: { [$not]: "invalid" } },
379
+ })).rejects.toThrow("Invalid value passed to $not operator");
380
+ }, { rollback: true });
381
+ });
382
+ });
383
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,57 @@
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.findOne: 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("findOne middleware", () => {
19
+ test("it allows overriding the orm's findOne method", async () => {
20
+ await db.transact(async (db) => {
21
+ const user = await db.createOne("user", {
22
+ values: {
23
+ id: 1,
24
+ name: "Test User",
25
+ email: "test@example.com",
26
+ role: "user",
27
+ },
28
+ returning: ["id"],
29
+ });
30
+ const stub = vi.fn();
31
+ const dbWithMiddleware = db.middleware([
32
+ {
33
+ findOne: (db, table, query) => {
34
+ stub("called stub in middleware 1");
35
+ return db.findOne(table, query);
36
+ },
37
+ },
38
+ {
39
+ findOne: (db, table, query) => {
40
+ stub("called stub in middleware 2");
41
+ return db.findOne(table, query);
42
+ },
43
+ },
44
+ ]);
45
+ const result = await dbWithMiddleware.findOne("user", {
46
+ select: ["id", "name"],
47
+ where: { id: 1 },
48
+ });
49
+ expect(result).toEqual({ id: 1, name: "Test User" });
50
+ expect(stub.mock.calls).toEqual([
51
+ ["called stub in middleware 1"],
52
+ ["called stub in middleware 2"],
53
+ ]);
54
+ }, { rollback: true });
55
+ });
56
+ });
57
+ });
@@ -0,0 +1 @@
1
+ export {};