@uql/core 1.0.12 → 3.1.0

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 (464) hide show
  1. package/CHANGELOG.md +254 -0
  2. package/LICENSE.md +2 -2
  3. package/dist/browser/http/bus.d.ts +3 -0
  4. package/dist/browser/http/bus.js +14 -0
  5. package/dist/browser/http/http.d.ts +6 -0
  6. package/dist/browser/http/http.js +45 -0
  7. package/dist/browser/http/index.d.ts +2 -0
  8. package/dist/browser/http/index.js +3 -0
  9. package/dist/browser/index.d.ts +4 -0
  10. package/dist/browser/index.js +5 -0
  11. package/dist/browser/options.d.ts +4 -0
  12. package/dist/browser/options.js +14 -0
  13. package/dist/browser/querier/genericClientRepository.d.ts +17 -0
  14. package/dist/browser/querier/genericClientRepository.js +39 -0
  15. package/dist/browser/querier/httpQuerier.d.ts +20 -0
  16. package/dist/browser/querier/httpQuerier.js +71 -0
  17. package/dist/browser/querier/index.d.ts +3 -0
  18. package/dist/browser/querier/index.js +4 -0
  19. package/dist/browser/querier/querier.util.d.ts +2 -0
  20. package/dist/browser/querier/querier.util.js +17 -0
  21. package/dist/browser/type/clientQuerier.d.ts +16 -0
  22. package/dist/browser/type/clientQuerier.js +2 -0
  23. package/dist/browser/type/clientQuerierPool.d.ts +4 -0
  24. package/dist/browser/type/clientQuerierPool.js +2 -0
  25. package/dist/browser/type/clientRepository.d.ts +13 -0
  26. package/dist/browser/type/clientRepository.js +2 -0
  27. package/dist/browser/type/index.d.ts +4 -0
  28. package/dist/browser/type/index.js +5 -0
  29. package/dist/browser/type/request.d.ts +28 -0
  30. package/dist/browser/type/request.js +2 -0
  31. package/dist/browser/uql-browser.min.js +2150 -0
  32. package/dist/browser/uql-browser.min.js.map +1 -0
  33. package/dist/dialect/abstractDialect.d.ts +16 -0
  34. package/dist/dialect/abstractDialect.js +28 -0
  35. package/dist/dialect/abstractSqlDialect.d.ts +47 -0
  36. package/dist/dialect/abstractSqlDialect.js +650 -0
  37. package/dist/dialect/index.d.ts +3 -0
  38. package/dist/dialect/index.js +4 -0
  39. package/dist/dialect/queryContext.d.ts +48 -0
  40. package/dist/dialect/queryContext.js +65 -0
  41. package/{entity → dist/entity}/decorator/definition.d.ts +3 -3
  42. package/dist/entity/decorator/definition.js +214 -0
  43. package/{entity → dist/entity}/decorator/entity.d.ts +1 -1
  44. package/dist/entity/decorator/entity.js +7 -0
  45. package/{entity → dist/entity}/decorator/field.d.ts +1 -1
  46. package/dist/entity/decorator/field.js +8 -0
  47. package/{entity → dist/entity}/decorator/id.d.ts +1 -1
  48. package/dist/entity/decorator/id.js +8 -0
  49. package/dist/entity/decorator/index.d.ts +5 -0
  50. package/dist/entity/decorator/index.js +6 -0
  51. package/{entity → dist/entity}/decorator/relation.d.ts +1 -1
  52. package/dist/entity/decorator/relation.js +20 -0
  53. package/dist/entity/index.d.ts +1 -0
  54. package/dist/entity/index.js +2 -0
  55. package/dist/express/index.d.ts +2 -0
  56. package/dist/express/index.js +3 -0
  57. package/dist/express/querierMiddleware.d.ts +26 -0
  58. package/dist/express/querierMiddleware.js +190 -0
  59. package/dist/express/query.util.d.ts +2 -0
  60. package/dist/express/query.util.js +19 -0
  61. package/dist/index.d.ts +9 -0
  62. package/dist/index.js +10 -0
  63. package/dist/maria/index.d.ts +3 -0
  64. package/dist/maria/index.js +4 -0
  65. package/dist/maria/mariaDialect.d.ts +8 -0
  66. package/dist/maria/mariaDialect.js +38 -0
  67. package/dist/maria/mariaQuerierPool.test.d.ts +5 -0
  68. package/dist/maria/mariaQuerierPool.test.js +19 -0
  69. package/dist/maria/mariadbQuerier.d.ts +17 -0
  70. package/dist/maria/mariadbQuerier.js +39 -0
  71. package/dist/maria/mariadbQuerier.test.d.ts +4 -0
  72. package/dist/maria/mariadbQuerier.test.js +19 -0
  73. package/dist/maria/mariadbQuerierPool.d.ts +10 -0
  74. package/dist/maria/mariadbQuerierPool.js +17 -0
  75. package/dist/migrate/cli.d.ts +2 -0
  76. package/dist/migrate/cli.js +254 -0
  77. package/dist/migrate/generator/index.d.ts +4 -0
  78. package/dist/migrate/generator/index.js +5 -0
  79. package/dist/migrate/generator/mongoSchemaGenerator.d.ts +12 -0
  80. package/dist/migrate/generator/mongoSchemaGenerator.js +100 -0
  81. package/dist/migrate/generator/mysqlSchemaGenerator.d.ts +14 -0
  82. package/dist/migrate/generator/mysqlSchemaGenerator.js +81 -0
  83. package/dist/migrate/generator/postgresSchemaGenerator.d.ts +18 -0
  84. package/dist/migrate/generator/postgresSchemaGenerator.js +111 -0
  85. package/dist/migrate/generator/sqliteSchemaGenerator.d.ts +14 -0
  86. package/dist/migrate/generator/sqliteSchemaGenerator.js +68 -0
  87. package/dist/migrate/index.d.ts +12 -0
  88. package/dist/migrate/index.js +17 -0
  89. package/dist/migrate/introspection/index.d.ts +4 -0
  90. package/dist/migrate/introspection/index.js +5 -0
  91. package/dist/migrate/introspection/mongoIntrospector.d.ts +8 -0
  92. package/dist/migrate/introspection/mongoIntrospector.js +46 -0
  93. package/dist/migrate/introspection/mysqlIntrospector.d.ts +25 -0
  94. package/dist/migrate/introspection/mysqlIntrospector.js +220 -0
  95. package/dist/migrate/introspection/postgresIntrospector.d.ts +21 -0
  96. package/dist/migrate/introspection/postgresIntrospector.js +269 -0
  97. package/dist/migrate/introspection/sqliteIntrospector.d.ts +23 -0
  98. package/dist/migrate/introspection/sqliteIntrospector.js +212 -0
  99. package/dist/migrate/migrator-mongo.test.d.ts +1 -0
  100. package/dist/migrate/migrator-mongo.test.js +54 -0
  101. package/dist/migrate/migrator.d.ts +133 -0
  102. package/dist/migrate/migrator.js +600 -0
  103. package/dist/migrate/migrator.test.d.ts +1 -0
  104. package/dist/migrate/migrator.test.js +106 -0
  105. package/dist/migrate/schemaGenerator.d.ts +78 -0
  106. package/dist/migrate/schemaGenerator.js +363 -0
  107. package/dist/migrate/storage/databaseStorage.d.ts +24 -0
  108. package/dist/migrate/storage/databaseStorage.js +77 -0
  109. package/dist/migrate/storage/index.d.ts +2 -0
  110. package/dist/migrate/storage/index.js +3 -0
  111. package/dist/migrate/storage/jsonStorage.d.ts +15 -0
  112. package/dist/migrate/storage/jsonStorage.js +51 -0
  113. package/dist/migrate/type.d.ts +1 -0
  114. package/dist/migrate/type.js +2 -0
  115. package/dist/mongo/index.d.ts +3 -0
  116. package/dist/mongo/index.js +4 -0
  117. package/dist/mongo/mongoDialect.d.ts +34 -0
  118. package/dist/mongo/mongoDialect.js +163 -0
  119. package/dist/mongo/mongodbQuerier.d.ts +28 -0
  120. package/dist/mongo/mongodbQuerier.js +204 -0
  121. package/dist/mongo/mongodbQuerier.test.d.ts +1 -0
  122. package/dist/mongo/mongodbQuerier.test.js +36 -0
  123. package/dist/mongo/mongodbQuerierPool.d.ts +10 -0
  124. package/dist/mongo/mongodbQuerierPool.js +20 -0
  125. package/dist/mongo/mongodbQuerierPool.test.d.ts +1 -0
  126. package/dist/mongo/mongodbQuerierPool.test.js +21 -0
  127. package/dist/mysql/index.d.ts +3 -0
  128. package/dist/mysql/index.js +4 -0
  129. package/dist/mysql/mysql2Querier.d.ts +17 -0
  130. package/dist/mysql/mysql2Querier.js +43 -0
  131. package/dist/mysql/mysql2Querier.test.d.ts +4 -0
  132. package/dist/mysql/mysql2Querier.test.js +16 -0
  133. package/dist/mysql/mysql2QuerierPool.d.ts +10 -0
  134. package/dist/mysql/mysql2QuerierPool.js +17 -0
  135. package/dist/mysql/mysql2QuerierPool.test.d.ts +5 -0
  136. package/dist/mysql/mysql2QuerierPool.test.js +16 -0
  137. package/dist/mysql/mysqlDialect.d.ts +5 -0
  138. package/dist/mysql/mysqlDialect.js +15 -0
  139. package/dist/namingStrategy/defaultNamingStrategy.d.ts +9 -0
  140. package/dist/namingStrategy/defaultNamingStrategy.js +15 -0
  141. package/dist/namingStrategy/index.d.ts +2 -0
  142. package/dist/namingStrategy/index.js +3 -0
  143. package/dist/namingStrategy/snakeCaseNamingStrategy.d.ts +8 -0
  144. package/dist/namingStrategy/snakeCaseNamingStrategy.js +14 -0
  145. package/{options.d.ts → dist/options.d.ts} +1 -1
  146. package/dist/options.js +14 -0
  147. package/dist/package.json +131 -0
  148. package/dist/postgres/index.d.ts +3 -0
  149. package/dist/postgres/index.js +4 -0
  150. package/dist/postgres/pgQuerier.d.ts +17 -0
  151. package/dist/postgres/pgQuerier.js +39 -0
  152. package/dist/postgres/pgQuerier.test.d.ts +4 -0
  153. package/dist/postgres/pgQuerier.test.js +20 -0
  154. package/dist/postgres/pgQuerierPool.d.ts +10 -0
  155. package/dist/postgres/pgQuerierPool.js +17 -0
  156. package/dist/postgres/pgQuerierPool.test.d.ts +5 -0
  157. package/dist/postgres/pgQuerierPool.test.js +23 -0
  158. package/dist/postgres/postgresDialect.d.ts +13 -0
  159. package/dist/postgres/postgresDialect.js +110 -0
  160. package/dist/querier/abstractQuerier-test.d.ts +45 -0
  161. package/dist/querier/abstractQuerier-test.js +461 -0
  162. package/dist/querier/abstractQuerier.d.ts +50 -0
  163. package/dist/querier/abstractQuerier.js +278 -0
  164. package/dist/querier/abstractQuerierPool-test.d.ts +9 -0
  165. package/dist/querier/abstractQuerierPool-test.js +18 -0
  166. package/dist/querier/abstractQuerierPool.d.ts +14 -0
  167. package/dist/querier/abstractQuerierPool.js +9 -0
  168. package/dist/querier/abstractSqlQuerier-test.d.ts +9 -0
  169. package/dist/querier/abstractSqlQuerier-test.js +16 -0
  170. package/dist/querier/abstractSqlQuerier.d.ts +28 -0
  171. package/dist/querier/abstractSqlQuerier.js +133 -0
  172. package/dist/querier/decorator/index.d.ts +3 -0
  173. package/dist/querier/decorator/index.js +4 -0
  174. package/dist/querier/decorator/injectQuerier.d.ts +3 -0
  175. package/dist/querier/decorator/injectQuerier.js +33 -0
  176. package/dist/querier/decorator/serialized.d.ts +6 -0
  177. package/dist/querier/decorator/serialized.js +14 -0
  178. package/{querier → dist/querier}/decorator/transactional.d.ts +1 -1
  179. package/dist/querier/decorator/transactional.js +48 -0
  180. package/dist/querier/index.d.ts +4 -0
  181. package/dist/querier/index.js +5 -0
  182. package/dist/repository/genericRepository.d.ts +20 -0
  183. package/dist/repository/genericRepository.js +51 -0
  184. package/dist/repository/index.d.ts +1 -0
  185. package/dist/repository/index.js +2 -0
  186. package/dist/sqlite/index.d.ts +3 -0
  187. package/dist/sqlite/index.js +4 -0
  188. package/dist/sqlite/sqliteDialect.d.ts +10 -0
  189. package/dist/sqlite/sqliteDialect.js +48 -0
  190. package/dist/sqlite/sqliteQuerier.d.ts +15 -0
  191. package/dist/sqlite/sqliteQuerier.js +33 -0
  192. package/dist/sqlite/sqliteQuerier.test.d.ts +5 -0
  193. package/dist/sqlite/sqliteQuerier.test.js +19 -0
  194. package/dist/sqlite/sqliteQuerierPool.d.ts +14 -0
  195. package/dist/sqlite/sqliteQuerierPool.js +34 -0
  196. package/dist/sqlite/sqliteQuerierPool.test.d.ts +5 -0
  197. package/dist/sqlite/sqliteQuerierPool.test.js +10 -0
  198. package/dist/test/entityMock.d.ts +164 -0
  199. package/dist/test/entityMock.js +554 -0
  200. package/dist/test/index.d.ts +3 -0
  201. package/dist/test/index.js +4 -0
  202. package/dist/test/it.util.d.ts +4 -0
  203. package/dist/test/it.util.js +55 -0
  204. package/dist/test/spec.util.d.ts +14 -0
  205. package/dist/test/spec.util.js +50 -0
  206. package/{type → dist/type}/entity.d.ts +97 -4
  207. package/dist/type/entity.js +5 -0
  208. package/dist/type/index.d.ts +9 -0
  209. package/dist/type/index.js +10 -0
  210. package/dist/type/migration.d.ts +213 -0
  211. package/dist/type/migration.js +2 -0
  212. package/dist/type/namingStrategy.d.ts +17 -0
  213. package/dist/type/namingStrategy.js +2 -0
  214. package/dist/type/querier.d.ts +96 -0
  215. package/dist/type/querier.js +11 -0
  216. package/{type → dist/type}/querierPool.d.ts +7 -3
  217. package/dist/type/querierPool.js +2 -0
  218. package/{type → dist/type}/query.d.ts +170 -108
  219. package/dist/type/query.js +9 -0
  220. package/{type → dist/type}/repository.d.ts +42 -35
  221. package/dist/type/repository.js +2 -0
  222. package/{type → dist/type}/universalQuerier.d.ts +50 -28
  223. package/dist/type/universalQuerier.js +2 -0
  224. package/dist/type/utility.d.ts +13 -0
  225. package/dist/type/utility.js +2 -0
  226. package/dist/util/dialect.util.d.ts +12 -0
  227. package/dist/util/dialect.util.js +93 -0
  228. package/dist/util/index.d.ts +5 -0
  229. package/dist/util/index.js +6 -0
  230. package/dist/util/object.util.d.ts +7 -0
  231. package/dist/util/object.util.js +19 -0
  232. package/dist/util/raw.d.ts +8 -0
  233. package/dist/util/raw.js +11 -0
  234. package/dist/util/sql.util.d.ts +13 -0
  235. package/dist/util/sql.util.js +78 -0
  236. package/{util → dist/util}/string.util.d.ts +1 -0
  237. package/dist/util/string.util.js +34 -0
  238. package/package.json +85 -17
  239. package/src/@types/index.d.ts +1 -0
  240. package/src/@types/jest.d.ts +6 -0
  241. package/src/browser/http/bus.spec.ts +22 -0
  242. package/src/browser/http/bus.ts +17 -0
  243. package/src/browser/http/http.spec.ts +70 -0
  244. package/src/browser/http/http.ts +55 -0
  245. package/src/browser/http/index.ts +2 -0
  246. package/src/browser/index.ts +4 -0
  247. package/src/browser/options.spec.ts +37 -0
  248. package/src/browser/options.ts +18 -0
  249. package/src/browser/querier/genericClientRepository.spec.ts +105 -0
  250. package/src/browser/querier/genericClientRepository.ts +49 -0
  251. package/src/browser/querier/httpQuerier.ts +82 -0
  252. package/src/browser/querier/index.ts +3 -0
  253. package/src/browser/querier/querier.util.spec.ts +35 -0
  254. package/src/browser/querier/querier.util.ts +18 -0
  255. package/src/browser/type/clientQuerier.ts +45 -0
  256. package/src/browser/type/clientQuerierPool.ts +5 -0
  257. package/src/browser/type/clientRepository.ts +22 -0
  258. package/src/browser/type/index.ts +4 -0
  259. package/src/browser/type/request.ts +25 -0
  260. package/src/dialect/abstractDialect.ts +28 -0
  261. package/src/dialect/abstractSqlDialect-spec.ts +1309 -0
  262. package/src/dialect/abstractSqlDialect.ts +805 -0
  263. package/src/dialect/index.ts +3 -0
  264. package/src/dialect/namingStrategy.spec.ts +52 -0
  265. package/src/dialect/queryContext.ts +69 -0
  266. package/src/entity/decorator/definition.spec.ts +736 -0
  267. package/src/entity/decorator/definition.ts +265 -0
  268. package/src/entity/decorator/entity.ts +8 -0
  269. package/src/entity/decorator/field.ts +9 -0
  270. package/src/entity/decorator/id.ts +9 -0
  271. package/src/entity/decorator/index.ts +5 -0
  272. package/src/entity/decorator/relation.spec.ts +41 -0
  273. package/src/entity/decorator/relation.ts +34 -0
  274. package/src/entity/index.ts +1 -0
  275. package/src/express/@types/express.d.ts +8 -0
  276. package/src/express/@types/index.d.ts +1 -0
  277. package/src/express/index.ts +2 -0
  278. package/src/express/querierMiddleware.ts +217 -0
  279. package/src/express/query.util.spec.ts +40 -0
  280. package/src/express/query.util.ts +21 -0
  281. package/src/index.ts +9 -0
  282. package/src/maria/index.ts +3 -0
  283. package/src/maria/mariaDialect.spec.ts +207 -0
  284. package/src/maria/mariaDialect.ts +42 -0
  285. package/src/maria/mariaQuerierPool.test.ts +23 -0
  286. package/src/maria/mariadbQuerier.test.ts +23 -0
  287. package/src/maria/mariadbQuerier.ts +45 -0
  288. package/src/maria/mariadbQuerierPool.ts +21 -0
  289. package/src/migrate/cli.ts +301 -0
  290. package/src/migrate/generator/index.ts +4 -0
  291. package/src/migrate/generator/mongoSchemaGenerator.spec.ts +112 -0
  292. package/src/migrate/generator/mongoSchemaGenerator.ts +115 -0
  293. package/src/migrate/generator/mysqlSchemaGenerator.spec.ts +34 -0
  294. package/src/migrate/generator/mysqlSchemaGenerator.ts +92 -0
  295. package/src/migrate/generator/postgresSchemaGenerator.spec.ts +44 -0
  296. package/src/migrate/generator/postgresSchemaGenerator.ts +127 -0
  297. package/src/migrate/generator/sqliteSchemaGenerator.spec.ts +33 -0
  298. package/src/migrate/generator/sqliteSchemaGenerator.ts +81 -0
  299. package/src/migrate/index.ts +41 -0
  300. package/src/migrate/introspection/index.ts +4 -0
  301. package/src/migrate/introspection/mongoIntrospector.spec.ts +75 -0
  302. package/src/migrate/introspection/mongoIntrospector.ts +47 -0
  303. package/src/migrate/introspection/mysqlIntrospector.spec.ts +113 -0
  304. package/src/migrate/introspection/mysqlIntrospector.ts +278 -0
  305. package/src/migrate/introspection/postgresIntrospector.spec.ts +112 -0
  306. package/src/migrate/introspection/postgresIntrospector.ts +329 -0
  307. package/src/migrate/introspection/sqliteIntrospector.spec.ts +112 -0
  308. package/src/migrate/introspection/sqliteIntrospector.ts +296 -0
  309. package/src/migrate/migrator-mongo.test.ts +54 -0
  310. package/src/migrate/migrator.spec.ts +255 -0
  311. package/src/migrate/migrator.test.ts +94 -0
  312. package/src/migrate/migrator.ts +719 -0
  313. package/src/migrate/namingStrategy.spec.ts +22 -0
  314. package/src/migrate/schemaGenerator-advanced.spec.ts +138 -0
  315. package/src/migrate/schemaGenerator.spec.ts +190 -0
  316. package/src/migrate/schemaGenerator.ts +478 -0
  317. package/src/migrate/storage/databaseStorage.spec.ts +69 -0
  318. package/src/migrate/storage/databaseStorage.ts +100 -0
  319. package/src/migrate/storage/index.ts +2 -0
  320. package/src/migrate/storage/jsonStorage.ts +58 -0
  321. package/src/migrate/type.ts +1 -0
  322. package/src/mongo/index.ts +3 -0
  323. package/src/mongo/mongoDialect.spec.ts +251 -0
  324. package/src/mongo/mongoDialect.ts +238 -0
  325. package/src/mongo/mongodbQuerier.test.ts +45 -0
  326. package/src/mongo/mongodbQuerier.ts +256 -0
  327. package/src/mongo/mongodbQuerierPool.test.ts +25 -0
  328. package/src/mongo/mongodbQuerierPool.ts +24 -0
  329. package/src/mysql/index.ts +3 -0
  330. package/src/mysql/mysql2Querier.test.ts +20 -0
  331. package/src/mysql/mysql2Querier.ts +49 -0
  332. package/src/mysql/mysql2QuerierPool.test.ts +20 -0
  333. package/src/mysql/mysql2QuerierPool.ts +21 -0
  334. package/src/mysql/mysqlDialect.spec.ts +20 -0
  335. package/src/mysql/mysqlDialect.ts +16 -0
  336. package/src/namingStrategy/defaultNamingStrategy.ts +18 -0
  337. package/src/namingStrategy/index.spec.ts +36 -0
  338. package/src/namingStrategy/index.ts +2 -0
  339. package/src/namingStrategy/snakeCaseNamingStrategy.ts +15 -0
  340. package/src/options.spec.ts +41 -0
  341. package/src/options.ts +18 -0
  342. package/src/postgres/index.ts +3 -0
  343. package/src/postgres/manual-types.d.ts +4 -0
  344. package/src/postgres/pgQuerier.test.ts +25 -0
  345. package/src/postgres/pgQuerier.ts +45 -0
  346. package/src/postgres/pgQuerierPool.test.ts +28 -0
  347. package/src/postgres/pgQuerierPool.ts +21 -0
  348. package/src/postgres/postgresDialect.spec.ts +428 -0
  349. package/src/postgres/postgresDialect.ts +144 -0
  350. package/src/querier/abstractQuerier-test.ts +584 -0
  351. package/src/querier/abstractQuerier.ts +353 -0
  352. package/src/querier/abstractQuerierPool-test.ts +20 -0
  353. package/src/querier/abstractQuerierPool.ts +18 -0
  354. package/src/querier/abstractSqlQuerier-spec.ts +979 -0
  355. package/src/querier/abstractSqlQuerier-test.ts +21 -0
  356. package/src/querier/abstractSqlQuerier.ts +138 -0
  357. package/src/querier/decorator/index.ts +3 -0
  358. package/src/querier/decorator/injectQuerier.spec.ts +74 -0
  359. package/src/querier/decorator/injectQuerier.ts +45 -0
  360. package/src/querier/decorator/serialized.spec.ts +98 -0
  361. package/src/querier/decorator/serialized.ts +13 -0
  362. package/src/querier/decorator/transactional.spec.ts +240 -0
  363. package/src/querier/decorator/transactional.ts +56 -0
  364. package/src/querier/index.ts +4 -0
  365. package/src/repository/genericRepository.spec.ts +111 -0
  366. package/src/repository/genericRepository.ts +74 -0
  367. package/src/repository/index.ts +1 -0
  368. package/src/sqlite/index.ts +3 -0
  369. package/src/sqlite/manual-types.d.ts +4 -0
  370. package/src/sqlite/sqliteDialect.spec.ts +155 -0
  371. package/src/sqlite/sqliteDialect.ts +76 -0
  372. package/src/sqlite/sqliteQuerier.spec.ts +36 -0
  373. package/src/sqlite/sqliteQuerier.test.ts +21 -0
  374. package/src/sqlite/sqliteQuerier.ts +37 -0
  375. package/src/sqlite/sqliteQuerierPool.test.ts +12 -0
  376. package/src/sqlite/sqliteQuerierPool.ts +38 -0
  377. package/src/test/entityMock.ts +375 -0
  378. package/src/test/index.ts +3 -0
  379. package/src/test/it.util.ts +69 -0
  380. package/src/test/spec.util.ts +57 -0
  381. package/src/type/entity.ts +218 -0
  382. package/src/type/index.ts +9 -0
  383. package/src/type/migration.ts +241 -0
  384. package/src/type/namingStrategy.ts +17 -0
  385. package/src/type/querier.ts +143 -0
  386. package/src/type/querierPool.ts +26 -0
  387. package/src/type/query.ts +506 -0
  388. package/src/type/repository.ts +142 -0
  389. package/src/type/universalQuerier.ts +133 -0
  390. package/src/type/utility.ts +21 -0
  391. package/src/util/dialect.util-extra.spec.ts +96 -0
  392. package/src/util/dialect.util.spec.ts +23 -0
  393. package/src/util/dialect.util.ts +134 -0
  394. package/src/util/index.ts +5 -0
  395. package/src/util/object.util.spec.ts +29 -0
  396. package/src/util/object.util.ts +27 -0
  397. package/src/util/raw.ts +11 -0
  398. package/src/util/sql.util-extra.spec.ts +17 -0
  399. package/src/util/sql.util.spec.ts +208 -0
  400. package/src/util/sql.util.ts +104 -0
  401. package/src/util/string.util.spec.ts +46 -0
  402. package/src/util/string.util.ts +35 -0
  403. package/tsconfig.build.json +5 -0
  404. package/tsconfig.json +8 -0
  405. package/README.md +0 -177
  406. package/dialect/abstractSqlDialect.d.ts +0 -30
  407. package/dialect/abstractSqlDialect.js +0 -365
  408. package/dialect/index.d.ts +0 -4
  409. package/dialect/index.js +0 -8
  410. package/dialect/mysqlDialect.d.ts +0 -6
  411. package/dialect/mysqlDialect.js +0 -21
  412. package/dialect/postgresDialect.d.ts +0 -8
  413. package/dialect/postgresDialect.js +0 -44
  414. package/dialect/sqliteDialect.d.ts +0 -4
  415. package/dialect/sqliteDialect.js +0 -11
  416. package/entity/decorator/definition.js +0 -223
  417. package/entity/decorator/entity.js +0 -11
  418. package/entity/decorator/field.js +0 -12
  419. package/entity/decorator/id.js +0 -12
  420. package/entity/decorator/index.d.ts +0 -5
  421. package/entity/decorator/index.js +0 -12
  422. package/entity/decorator/relation.js +0 -27
  423. package/entity/index.d.ts +0 -1
  424. package/entity/index.js +0 -5
  425. package/index.d.ts +0 -1
  426. package/index.js +0 -5
  427. package/options.js +0 -20
  428. package/querier/abstractQuerier.d.ts +0 -30
  429. package/querier/abstractQuerier.js +0 -230
  430. package/querier/abstractSqlQuerier.d.ts +0 -27
  431. package/querier/abstractSqlQuerier.js +0 -88
  432. package/querier/decorator/index.d.ts +0 -2
  433. package/querier/decorator/index.js +0 -6
  434. package/querier/decorator/injectQuerier.d.ts +0 -3
  435. package/querier/decorator/injectQuerier.js +0 -39
  436. package/querier/decorator/transactional.js +0 -52
  437. package/querier/index.d.ts +0 -3
  438. package/querier/index.js +0 -7
  439. package/repository/genericRepository.d.ts +0 -19
  440. package/repository/genericRepository.js +0 -52
  441. package/repository/index.d.ts +0 -1
  442. package/repository/index.js +0 -5
  443. package/type/entity.js +0 -5
  444. package/type/index.d.ts +0 -7
  445. package/type/index.js +0 -11
  446. package/type/querier.d.ts +0 -53
  447. package/type/querier.js +0 -3
  448. package/type/querierPool.js +0 -3
  449. package/type/query.js +0 -13
  450. package/type/repository.js +0 -3
  451. package/type/universalQuerier.js +0 -3
  452. package/type/utility.d.ts +0 -12
  453. package/type/utility.js +0 -3
  454. package/util/dialect.util.d.ts +0 -17
  455. package/util/dialect.util.js +0 -114
  456. package/util/index.d.ts +0 -5
  457. package/util/index.js +0 -9
  458. package/util/object.util.d.ts +0 -3
  459. package/util/object.util.js +0 -22
  460. package/util/raw.d.ts +0 -2
  461. package/util/raw.js +0 -9
  462. package/util/sql.util.d.ts +0 -2
  463. package/util/sql.util.js +0 -55
  464. package/util/string.util.js +0 -20
@@ -0,0 +1,461 @@
1
+ import { expect } from 'bun:test';
2
+ import { getEntities } from '../entity/index.js';
3
+ import { Company, InventoryAdjustment, Item, ItemAdjustment, LedgerAccount, MeasureUnit, Tag, TaxCategory, User, } from '../test/index.js';
4
+ export class AbstractQuerierIt {
5
+ pool;
6
+ querier;
7
+ constructor(pool) {
8
+ this.pool = pool;
9
+ }
10
+ async beforeAll() {
11
+ const querier = await this.pool.getQuerier();
12
+ try {
13
+ this.querier = querier;
14
+ await this.dropTables();
15
+ await this.createTables();
16
+ }
17
+ finally {
18
+ await querier.release();
19
+ this.querier = undefined;
20
+ }
21
+ }
22
+ async beforeEach() {
23
+ this.querier = await this.pool.getQuerier();
24
+ await this.clearTables();
25
+ }
26
+ async afterEach() {
27
+ await this.querier.release();
28
+ }
29
+ async afterAll() {
30
+ await this.pool.end();
31
+ }
32
+ shouldGetRepository() {
33
+ const repository = this.querier.getRepository(User);
34
+ expect(repository).toBeDefined();
35
+ }
36
+ async shouldInsertMany() {
37
+ const ids = await this.querier.insertMany(User, [
38
+ {
39
+ name: 'Some Name A',
40
+ email: 'someemaila@example.com',
41
+ password: '123456789a!',
42
+ },
43
+ {
44
+ name: 'Some Name B',
45
+ email: 'someemailb@example.com',
46
+ password: '123456789b!',
47
+ },
48
+ ]);
49
+ expect(ids).toHaveLength(2);
50
+ for (const id of ids) {
51
+ expect(id).toBeDefined();
52
+ }
53
+ }
54
+ async shouldInsertManyEmpty() {
55
+ const ids = await this.querier.insertMany(User, []);
56
+ expect(ids).toEqual([]);
57
+ }
58
+ async shouldInsertOne() {
59
+ const creatorId = await this.querier.insertOne(User, {
60
+ name: 'Some Name C',
61
+ email: 'someemailc@example.com',
62
+ password: '123456789z!',
63
+ });
64
+ expect(creatorId).toBeDefined();
65
+ const companyId = await this.querier.insertOne(Company, {
66
+ name: 'Some Name C',
67
+ creatorId,
68
+ });
69
+ expect(companyId).toBeDefined();
70
+ const taxCategoryId = await this.querier.insertOne(TaxCategory, {
71
+ name: 'Some Name C',
72
+ description: 'Some Description Z',
73
+ creatorId,
74
+ companyId,
75
+ });
76
+ expect(taxCategoryId).toBeDefined();
77
+ }
78
+ async shouldInsertOneWithOnInsertId() {
79
+ const id1 = await this.querier.insertOne(TaxCategory, {
80
+ name: 'Some Name',
81
+ });
82
+ const id2 = await this.querier.insertOne(TaxCategory, {
83
+ pk: '123',
84
+ name: 'Some Name',
85
+ });
86
+ expect(id1).toBeDefined();
87
+ expect(id2).toBeDefined();
88
+ }
89
+ async shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {
90
+ const ids = await this.querier.insertMany(TaxCategory, [
91
+ {
92
+ name: 'Some Name A',
93
+ },
94
+ {
95
+ pk: '50',
96
+ name: 'Some Name B',
97
+ },
98
+ {
99
+ name: 'Some Name C',
100
+ },
101
+ {
102
+ pk: '70',
103
+ name: 'Some Name D',
104
+ },
105
+ ]);
106
+ expect(ids).toHaveLength(4);
107
+ for (const id of ids) {
108
+ expect(id).toBeDefined();
109
+ }
110
+ }
111
+ async shouldInsertManyWithAutoIncrementIdAsDefault() {
112
+ const ids = await this.querier.insertMany(LedgerAccount, [
113
+ {
114
+ name: 'Some Name A',
115
+ },
116
+ {
117
+ name: 'Some Name B',
118
+ },
119
+ {
120
+ name: 'Some Name C',
121
+ },
122
+ ]);
123
+ expect(ids).toHaveLength(3);
124
+ for (const id of ids) {
125
+ expect(id).toBeDefined();
126
+ }
127
+ const founds = await this.querier.findMany(LedgerAccount, {});
128
+ expect(founds.map(({ id }) => id)).toEqual(ids);
129
+ }
130
+ async shouldInsertOneAndCascadeOneToOne() {
131
+ const payload = {
132
+ name: 'Some Name D',
133
+ createdAt: 123,
134
+ profile: { picture: 'abc', createdAt: 123 },
135
+ };
136
+ const id = await this.querier.insertOne(User, payload);
137
+ expect(id).toBeDefined();
138
+ const found = await this.querier.findOneById(User, id, { $select: { profile: true } });
139
+ expect(found).toMatchObject({ id, profile: payload.profile });
140
+ }
141
+ async shouldInsertOneAndCascadeManyToOne() {
142
+ const payload = {
143
+ name: 'Centimeter',
144
+ createdAt: 123,
145
+ category: { name: 'Metric', createdAt: 123 },
146
+ };
147
+ const id = await this.querier.insertOne(MeasureUnit, payload);
148
+ expect(id).toBeDefined();
149
+ const found = await this.querier.findOneById(MeasureUnit, id, { $select: { category: true } });
150
+ expect(found).toMatchObject({ id, category: payload.category });
151
+ }
152
+ async shouldInsertSpecialChars() {
153
+ const payload = {
154
+ name: `I'm Cielo! How are you doing today? It's been a while since we last talked`,
155
+ createdAt: 123,
156
+ };
157
+ const id = await this.querier.insertOne(MeasureUnit, payload);
158
+ expect(id).toBeDefined();
159
+ const found = await this.querier.findOneById(MeasureUnit, id);
160
+ expect(found).toMatchObject(payload);
161
+ }
162
+ async shouldInsertOneAndCascadeOneToMany() {
163
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
164
+ const date = new Date();
165
+ const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {
166
+ description: 'some description',
167
+ date,
168
+ itemAdjustments,
169
+ });
170
+ expect(inventoryAdjustmentId).toBeDefined();
171
+ const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {
172
+ $select: { itemAdjustments: true },
173
+ });
174
+ expect(inventoryAdjustmentFound).toMatchObject({
175
+ id: inventoryAdjustmentId,
176
+ itemAdjustments,
177
+ });
178
+ const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });
179
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
180
+ }
181
+ async shouldInsertOneAndCascadeOneToManyWithSpecificFields() {
182
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
183
+ const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {
184
+ description: 'some description',
185
+ itemAdjustments: itemAdjustments.slice(),
186
+ });
187
+ expect(inventoryAdjustmentId).toBeDefined();
188
+ const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {
189
+ $select: { itemAdjustments: ['buyPrice'] },
190
+ });
191
+ expect(inventoryAdjustmentFound).toMatchObject({
192
+ id: inventoryAdjustmentId,
193
+ itemAdjustments,
194
+ });
195
+ const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });
196
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
197
+ }
198
+ async shouldUpdateOneAndCascadeOneToMany() {
199
+ const itemAdjustments = [{ buyPrice: 50 }, { buyPrice: 300 }];
200
+ const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {
201
+ description: 'some description',
202
+ });
203
+ expect(inventoryAdjustmentId).toBeDefined();
204
+ const changes = await this.querier.updateOneById(InventoryAdjustment, inventoryAdjustmentId, {
205
+ itemAdjustments,
206
+ });
207
+ expect(changes).toBe(1);
208
+ const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {
209
+ $select: { itemAdjustments: ['buyPrice'] },
210
+ });
211
+ expect(inventoryAdjustmentFound).toMatchObject({
212
+ id: inventoryAdjustmentId,
213
+ itemAdjustments,
214
+ });
215
+ const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });
216
+ expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);
217
+ }
218
+ async shouldUpdateOneByIdAndCascadeOneToManyNull() {
219
+ const id = await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });
220
+ await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(2);
221
+ await this.querier.updateOneById(InventoryAdjustment, id, {
222
+ itemAdjustments: null,
223
+ });
224
+ await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(0);
225
+ }
226
+ async shouldUpdateManyAndCascadeOneToManyNull() {
227
+ await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });
228
+ await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(2);
229
+ await this.querier.updateMany(InventoryAdjustment, { $where: {} }, {
230
+ itemAdjustments: null,
231
+ });
232
+ await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(0);
233
+ }
234
+ async shouldInsertOneAndCascadeManyToMany() {
235
+ const payload = {
236
+ name: 'item one',
237
+ createdAt: 1,
238
+ tags: [
239
+ {
240
+ name: 'tag one',
241
+ createdAt: 1,
242
+ },
243
+ {
244
+ name: 'tag two',
245
+ createdAt: 1,
246
+ },
247
+ ],
248
+ };
249
+ const id = await this.querier.insertOne(Item, payload);
250
+ expect(id).toBeDefined();
251
+ const foundItem = await this.querier.findOneById(Item, id, {
252
+ $select: { name: true, createdAt: true, tags: ['name', 'createdAt'] },
253
+ });
254
+ expect(foundItem).toMatchObject({
255
+ id,
256
+ ...payload,
257
+ });
258
+ const foundTags = await this.querier.findMany(Tag, {
259
+ $select: { name: true, createdAt: true, items: ['name', 'createdAt'] },
260
+ });
261
+ delete foundItem.tags;
262
+ expect(foundTags).toMatchObject(payload.tags.map((tag) => ({ ...tag, items: [foundItem] })));
263
+ }
264
+ async shouldUpdateOneAndCascadeManyToMany() {
265
+ const id = await this.querier.insertOne(Item, { createdAt: 1 });
266
+ const payload = {
267
+ name: 'item one',
268
+ updatedAt: 1,
269
+ tags: [
270
+ {
271
+ name: 'tag one',
272
+ createdAt: 1,
273
+ },
274
+ {
275
+ name: 'tag two',
276
+ createdAt: 1,
277
+ },
278
+ ],
279
+ };
280
+ await this.querier.updateOneById(Item, id, payload);
281
+ const found = await this.querier.findOneById(Item, id, {
282
+ $select: { name: true, updatedAt: true, tags: true },
283
+ });
284
+ expect(found).toMatchObject({
285
+ id,
286
+ ...payload,
287
+ });
288
+ }
289
+ async shouldUpsertOne() {
290
+ const pk = '507f1f77bcf86cd799439011';
291
+ const record1 = await this.querier.findOne(TaxCategory, {
292
+ $select: ['name'],
293
+ $where: { pk },
294
+ });
295
+ expect(record1).toBeUndefined();
296
+ await this.querier.upsertOne(TaxCategory, { pk: true }, {
297
+ pk,
298
+ name: 'Some Name C',
299
+ });
300
+ const record2 = await this.querier.findOne(TaxCategory, {
301
+ $select: ['name'],
302
+ $where: { pk },
303
+ });
304
+ expect(record2).toMatchObject({
305
+ name: 'Some Name C',
306
+ });
307
+ await this.querier.upsertOne(TaxCategory, { pk: true }, {
308
+ pk,
309
+ name: 'Some Name D',
310
+ });
311
+ const record3 = await this.querier.findOne(TaxCategory, {
312
+ $select: ['name'],
313
+ $where: { pk },
314
+ });
315
+ expect(record3).toMatchObject({
316
+ name: 'Some Name D',
317
+ });
318
+ }
319
+ async shouldFindOne() {
320
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
321
+ const found = await this.querier.findOne(User, {
322
+ $select: ['id', 'name', 'email', 'password'],
323
+ $where: {
324
+ email: 'someemaila@example.com',
325
+ },
326
+ });
327
+ expect(found).toMatchObject({
328
+ name: 'Some Name A',
329
+ email: 'someemaila@example.com',
330
+ password: '123456789a!',
331
+ });
332
+ const notFound = await this.querier.findOne(User, {
333
+ $where: {
334
+ name: 'some name',
335
+ },
336
+ });
337
+ expect(notFound).toBeUndefined();
338
+ }
339
+ async shouldCount() {
340
+ await expect(this.querier.count(User, {})).resolves.toBe(0);
341
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
342
+ await expect(this.querier.count(User, {})).resolves.toBe(3);
343
+ await expect(this.querier.count(User, { $where: { companyId: null } })).resolves.toBe(3);
344
+ await expect(this.querier.count(User, { $where: { companyId: 1 } })).resolves.toBe(0);
345
+ }
346
+ async shouldUpdateMany() {
347
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
348
+ await expect(this.querier.updateMany(User, { $where: { companyId: 1 } }, { companyId: null })).resolves.toBe(0);
349
+ await expect(this.querier.updateMany(User, { $where: { companyId: null } }, { companyId: 1 })).resolves.toBe(3);
350
+ await expect(this.querier.updateMany(User, { $where: { companyId: 1 } }, { companyId: null })).resolves.toBe(3);
351
+ }
352
+ async shouldThrowIfUnknownComparisonOperator() {
353
+ await expect(this.querier.findMany(User, {
354
+ $where: { name: { $someInvalidOperator: 'some' } },
355
+ })).rejects.toThrow('unknown operator: $someInvalidOperator');
356
+ }
357
+ async shouldThrowWhenRollbackTransactionWithoutBeginTransaction() {
358
+ await expect(this.querier.rollbackTransaction()).rejects.toThrow('not a pending transaction');
359
+ }
360
+ async shouldCommit() {
361
+ await expect(this.querier.count(User, {})).resolves.toBe(0);
362
+ await this.querier.beginTransaction();
363
+ await this.querier.insertOne(User, {});
364
+ await expect(this.querier.count(User, {})).resolves.toBe(1);
365
+ await this.querier.commitTransaction();
366
+ await expect(this.querier.count(User, {})).resolves.toBe(1);
367
+ await this.querier.release();
368
+ }
369
+ async shouldRollback() {
370
+ await expect(this.querier.count(User, {})).resolves.toBe(0);
371
+ await this.querier.beginTransaction();
372
+ await this.querier.insertOne(User, {});
373
+ await expect(this.querier.count(User, {})).resolves.toBe(1);
374
+ await this.querier.rollbackTransaction();
375
+ await expect(this.querier.count(User, {})).resolves.toBe(0);
376
+ await this.querier.release();
377
+ }
378
+ async shouldThrowWhenBeginTransactionAfterBeginTransaction() {
379
+ expect(this.querier.hasOpenTransaction).toBeFalsy();
380
+ await this.querier.beginTransaction();
381
+ expect(this.querier.hasOpenTransaction).toBe(true);
382
+ await expect(this.querier.beginTransaction()).rejects.toThrow('pending transaction');
383
+ await expect(this.querier.release()).rejects.toThrow('pending transaction');
384
+ await this.querier.rollbackTransaction();
385
+ await this.querier.release();
386
+ }
387
+ async shouldReturnTransactionValue() {
388
+ const affectedRows = await this.querier.transaction(async () => {
389
+ await this.shouldInsertMany();
390
+ const count = await this.querier.count(User, {});
391
+ await this.querier.deleteMany(User, {});
392
+ return count;
393
+ });
394
+ expect(affectedRows).toBe(2);
395
+ }
396
+ async shouldThrowWhenCommitTransactionWithoutBeginTransaction() {
397
+ await expect(this.querier.commitTransaction()).rejects.toThrow('not a pending transaction');
398
+ }
399
+ async shouldSelectOneToManyEmpty() {
400
+ const inventoryAdjustment = await this.querier.findOneById(InventoryAdjustment, -1, {
401
+ $select: { itemAdjustments: true, creator: true },
402
+ });
403
+ expect(inventoryAdjustment).toBeUndefined();
404
+ const inventoryAdjustments = await this.querier.findMany(InventoryAdjustment, {
405
+ $select: { itemAdjustments: true },
406
+ });
407
+ expect(inventoryAdjustments).toHaveLength(0);
408
+ }
409
+ async shouldSelectOneToMany() {
410
+ await this.shouldInsertOne();
411
+ const [user, company] = await Promise.all([
412
+ this.querier.findOne(User, { $select: ['id'] }),
413
+ this.querier.findOne(Company, { $select: ['id'] }),
414
+ ]);
415
+ const [firstItemId, secondItemId] = await this.querier.insertMany(Item, [
416
+ {
417
+ name: 'some item name a',
418
+ creatorId: user.id,
419
+ companyId: company.id,
420
+ },
421
+ {
422
+ name: 'some item name b',
423
+ creatorId: user.id,
424
+ companyId: company.id,
425
+ },
426
+ ]);
427
+ const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {
428
+ description: 'some inventory adjustment',
429
+ creatorId: user.id,
430
+ companyId: company.id,
431
+ itemAdjustments: [
432
+ { buyPrice: 1000, itemId: firstItemId },
433
+ { buyPrice: 2000, itemId: secondItemId },
434
+ ],
435
+ });
436
+ const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {
437
+ $select: { itemAdjustments: true, creator: true },
438
+ });
439
+ expect(inventoryAdjustmentFound).toMatchObject({
440
+ id: inventoryAdjustmentId,
441
+ itemAdjustments: [
442
+ { buyPrice: 1000, itemId: firstItemId },
443
+ { buyPrice: 2000, itemId: secondItemId },
444
+ ],
445
+ creator: {
446
+ email: 'someemailc@example.com',
447
+ name: 'Some Name C',
448
+ },
449
+ });
450
+ }
451
+ async shouldDeleteMany() {
452
+ await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);
453
+ await expect(this.querier.deleteMany(User, { $where: { companyId: 1 } })).resolves.toBe(0);
454
+ await expect(this.querier.deleteMany(User, { $where: { companyId: null } })).resolves.toBe(3);
455
+ }
456
+ async clearTables() {
457
+ const entities = getEntities();
458
+ await Promise.all(entities.map((entity) => this.querier.deleteMany(entity, {})));
459
+ }
460
+ }
461
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstractQuerier-test.js","sourceRoot":"","sources":["../../src/querier/abstractQuerier-test.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect } from 'bun:test';\nimport { getEntities } from '../entity/index.js';\nimport {\n  Company,\n  InventoryAdjustment,\n  Item,\n  ItemAdjustment,\n  LedgerAccount,\n  MeasureUnit,\n  type Spec,\n  Tag,\n  TaxCategory,\n  User,\n} from '../test/index.js';\nimport type { Querier, QuerierPool } from '../type/index.js';\n\nexport abstract class AbstractQuerierIt<Q extends Querier> implements Spec {\n  querier: Q;\n\n  constructor(protected pool: QuerierPool<Q>) {}\n\n  async beforeAll() {\n    const querier = await this.pool.getQuerier();\n    try {\n      this.querier = querier;\n      await this.dropTables();\n      await this.createTables();\n    } finally {\n      await querier.release();\n      this.querier = undefined;\n    }\n  }\n\n  async beforeEach() {\n    this.querier = await this.pool.getQuerier();\n    await this.clearTables();\n  }\n\n  async afterEach() {\n    await this.querier.release();\n  }\n\n  async afterAll() {\n    await this.pool.end();\n  }\n\n  shouldGetRepository() {\n    const repository = this.querier.getRepository(User);\n    expect(repository).toBeDefined();\n  }\n\n  async shouldInsertMany() {\n    const ids = await this.querier.insertMany(User, [\n      {\n        name: 'Some Name A',\n        email: 'someemaila@example.com',\n        password: '123456789a!',\n      },\n      {\n        name: 'Some Name B',\n        email: 'someemailb@example.com',\n        password: '123456789b!',\n      },\n    ]);\n    expect(ids).toHaveLength(2);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n  }\n\n  async shouldInsertManyEmpty() {\n    const ids = await this.querier.insertMany(User, []);\n    expect(ids).toEqual([]);\n  }\n\n  async shouldInsertOne() {\n    const creatorId = await this.querier.insertOne(User, {\n      name: 'Some Name C',\n      email: 'someemailc@example.com',\n      password: '123456789z!',\n    });\n    expect(creatorId).toBeDefined();\n\n    const companyId = await this.querier.insertOne(Company, {\n      name: 'Some Name C',\n      creatorId,\n    });\n    expect(companyId).toBeDefined();\n\n    const taxCategoryId = await this.querier.insertOne(TaxCategory, {\n      name: 'Some Name C',\n      description: 'Some Description Z',\n      creatorId,\n      companyId,\n    });\n    expect(taxCategoryId).toBeDefined();\n  }\n\n  async shouldInsertOneWithOnInsertId() {\n    const id1 = await this.querier.insertOne(TaxCategory, {\n      name: 'Some Name',\n    });\n    const id2 = await this.querier.insertOne(TaxCategory, {\n      pk: '123',\n      name: 'Some Name',\n    });\n    expect(id1).toBeDefined();\n    expect(id2).toBeDefined();\n  }\n\n  async shouldInsertManyWithSpecifiedIdsAndOnInsertIdAsDefault() {\n    const ids = await this.querier.insertMany(TaxCategory, [\n      {\n        name: 'Some Name A',\n      },\n      {\n        pk: '50',\n        name: 'Some Name B',\n      },\n      {\n        name: 'Some Name C',\n      },\n      {\n        pk: '70',\n        name: 'Some Name D',\n      },\n    ]);\n    expect(ids).toHaveLength(4);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n  }\n\n  async shouldInsertManyWithAutoIncrementIdAsDefault() {\n    const ids = await this.querier.insertMany(LedgerAccount, [\n      {\n        name: 'Some Name A',\n      },\n      {\n        name: 'Some Name B',\n      },\n      {\n        name: 'Some Name C',\n      },\n    ]);\n    expect(ids).toHaveLength(3);\n    for (const id of ids) {\n      expect(id).toBeDefined();\n    }\n    const founds = await this.querier.findMany(LedgerAccount, {});\n    expect(founds.map(({ id }) => id)).toEqual(ids);\n  }\n\n  async shouldInsertOneAndCascadeOneToOne() {\n    const payload = {\n      name: 'Some Name D',\n      createdAt: 123,\n      profile: { picture: 'abc', createdAt: 123 },\n    } satisfies User;\n    const id = await this.querier.insertOne(User, payload);\n    expect(id).toBeDefined();\n    const found = await this.querier.findOneById(User, id, { $select: { profile: true } });\n    expect(found).toMatchObject({ id, profile: payload.profile });\n  }\n\n  async shouldInsertOneAndCascadeManyToOne() {\n    const payload = {\n      name: 'Centimeter',\n      createdAt: 123,\n      category: { name: 'Metric', createdAt: 123 },\n    } satisfies MeasureUnit;\n\n    const id = await this.querier.insertOne(MeasureUnit, payload);\n\n    expect(id).toBeDefined();\n\n    const found = await this.querier.findOneById(MeasureUnit, id, { $select: { category: true } });\n\n    expect(found).toMatchObject({ id, category: payload.category });\n  }\n\n  async shouldInsertSpecialChars() {\n    const payload: MeasureUnit = {\n      name: `I'm Cielo! How are you doing today? It's been a while since we last talked`,\n      createdAt: 123,\n    };\n\n    const id = await this.querier.insertOne(MeasureUnit, payload);\n\n    expect(id).toBeDefined();\n\n    const found = await this.querier.findOneById(MeasureUnit, id);\n\n    expect(found).toMatchObject(payload);\n  }\n\n  async shouldInsertOneAndCascadeOneToMany() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const date = new Date();\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n      date,\n      itemAdjustments,\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $select: { itemAdjustments: true },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldInsertOneAndCascadeOneToManyWithSpecificFields() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n      itemAdjustments: itemAdjustments.slice(),\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $select: { itemAdjustments: ['buyPrice'] },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldUpdateOneAndCascadeOneToMany() {\n    const itemAdjustments: ItemAdjustment[] = [{ buyPrice: 50 }, { buyPrice: 300 }];\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some description',\n    });\n\n    expect(inventoryAdjustmentId).toBeDefined();\n\n    const changes = await this.querier.updateOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      itemAdjustments,\n    });\n\n    expect(changes).toBe(1);\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $select: { itemAdjustments: ['buyPrice'] },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments,\n    });\n\n    const itemAdjustmentsFound = await this.querier.findMany(ItemAdjustment, { $where: { inventoryAdjustmentId } });\n\n    expect(itemAdjustmentsFound).toMatchObject(itemAdjustments);\n  }\n\n  async shouldUpdateOneByIdAndCascadeOneToManyNull() {\n    const id = await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });\n\n    await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(2);\n\n    await this.querier.updateOneById(InventoryAdjustment, id, {\n      itemAdjustments: null,\n    });\n\n    await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(0);\n  }\n\n  async shouldUpdateManyAndCascadeOneToManyNull() {\n    await this.querier.insertOne(InventoryAdjustment, { itemAdjustments: [{}, {}] });\n\n    await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(2);\n\n    await this.querier.updateMany(\n      InventoryAdjustment,\n      { $where: {} },\n      {\n        itemAdjustments: null,\n      },\n    );\n\n    await expect(this.querier.count(ItemAdjustment, {})).resolves.toBe(0);\n  }\n\n  async shouldInsertOneAndCascadeManyToMany() {\n    const payload: Item = {\n      name: 'item one',\n      createdAt: 1,\n      tags: [\n        {\n          name: 'tag one',\n          createdAt: 1,\n        },\n        {\n          name: 'tag two',\n          createdAt: 1,\n        },\n      ],\n    };\n\n    const id = await this.querier.insertOne(Item, payload);\n\n    expect(id).toBeDefined();\n\n    const foundItem = await this.querier.findOneById(Item, id, {\n      $select: { name: true, createdAt: true, tags: ['name', 'createdAt'] },\n    });\n\n    expect(foundItem).toMatchObject({\n      id,\n      ...payload,\n    });\n\n    const foundTags = await this.querier.findMany(Tag, {\n      $select: { name: true, createdAt: true, items: ['name', 'createdAt'] },\n    });\n\n    delete foundItem.tags;\n\n    expect(foundTags).toMatchObject(payload.tags.map((tag) => ({ ...tag, items: [foundItem] })));\n  }\n\n  async shouldUpdateOneAndCascadeManyToMany() {\n    const id = await this.querier.insertOne(Item, { createdAt: 1 });\n    const payload: Item = {\n      name: 'item one',\n      updatedAt: 1,\n      tags: [\n        {\n          name: 'tag one',\n          createdAt: 1,\n        },\n        {\n          name: 'tag two',\n          createdAt: 1,\n        },\n      ],\n    };\n\n    await this.querier.updateOneById(Item, id, payload);\n\n    const found = await this.querier.findOneById(Item, id, {\n      $select: { name: true, updatedAt: true, tags: true },\n    });\n\n    expect(found).toMatchObject({\n      id,\n      ...payload,\n    });\n  }\n\n  async shouldUpsertOne() {\n    const pk = '507f1f77bcf86cd799439011';\n    const record1 = await this.querier.findOne(TaxCategory, {\n      $select: ['name'],\n      $where: { pk },\n    });\n    expect(record1).toBeUndefined();\n    await this.querier.upsertOne(\n      TaxCategory,\n      { pk: true },\n      {\n        pk,\n        name: 'Some Name C',\n      },\n    );\n    const record2 = await this.querier.findOne(TaxCategory, {\n      $select: ['name'],\n      $where: { pk },\n    });\n    expect(record2).toMatchObject({\n      name: 'Some Name C',\n    });\n    await this.querier.upsertOne(\n      TaxCategory,\n      { pk: true },\n      {\n        pk,\n        name: 'Some Name D',\n      },\n    );\n    const record3 = await this.querier.findOne(TaxCategory, {\n      $select: ['name'],\n      $where: { pk },\n    });\n    expect(record3).toMatchObject({\n      name: 'Some Name D',\n    });\n  }\n\n  async shouldFindOne() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    const found = await this.querier.findOne(User, {\n      $select: ['id', 'name', 'email', 'password'],\n      $where: {\n        email: 'someemaila@example.com',\n      },\n    });\n\n    expect(found).toMatchObject({\n      name: 'Some Name A',\n      email: 'someemaila@example.com',\n      password: '123456789a!',\n    });\n\n    const notFound = await this.querier.findOne(User, {\n      $where: {\n        name: 'some name',\n      },\n    });\n\n    expect(notFound).toBeUndefined();\n  }\n\n  async shouldCount() {\n    await expect(this.querier.count(User, {})).resolves.toBe(0);\n\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    await expect(this.querier.count(User, {})).resolves.toBe(3);\n    await expect(this.querier.count(User, { $where: { companyId: null } })).resolves.toBe(3);\n    await expect(this.querier.count(User, { $where: { companyId: 1 } })).resolves.toBe(0);\n  }\n\n  async shouldUpdateMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n\n    await expect(this.querier.updateMany(User, { $where: { companyId: 1 } }, { companyId: null })).resolves.toBe(0);\n    await expect(this.querier.updateMany(User, { $where: { companyId: null } }, { companyId: 1 })).resolves.toBe(3);\n    await expect(this.querier.updateMany(User, { $where: { companyId: 1 } }, { companyId: null })).resolves.toBe(3);\n  }\n\n  async shouldThrowIfUnknownComparisonOperator() {\n    await expect(\n      this.querier.findMany(User, {\n        $where: { name: { $someInvalidOperator: 'some' } as any },\n      }),\n    ).rejects.toThrow('unknown operator: $someInvalidOperator');\n  }\n\n  async shouldThrowWhenRollbackTransactionWithoutBeginTransaction() {\n    await expect(this.querier.rollbackTransaction()).rejects.toThrow('not a pending transaction');\n  }\n\n  async shouldCommit() {\n    await expect(this.querier.count(User, {})).resolves.toBe(0);\n    await this.querier.beginTransaction();\n    await this.querier.insertOne(User, {});\n    await expect(this.querier.count(User, {})).resolves.toBe(1);\n    await this.querier.commitTransaction();\n    await expect(this.querier.count(User, {})).resolves.toBe(1);\n    await this.querier.release();\n  }\n\n  async shouldRollback() {\n    await expect(this.querier.count(User, {})).resolves.toBe(0);\n    await this.querier.beginTransaction();\n    await this.querier.insertOne(User, {});\n    await expect(this.querier.count(User, {})).resolves.toBe(1);\n    await this.querier.rollbackTransaction();\n    await expect(this.querier.count(User, {})).resolves.toBe(0);\n    await this.querier.release();\n  }\n\n  async shouldThrowWhenBeginTransactionAfterBeginTransaction() {\n    expect(this.querier.hasOpenTransaction).toBeFalsy();\n    await this.querier.beginTransaction();\n    expect(this.querier.hasOpenTransaction).toBe(true);\n    await expect(this.querier.beginTransaction()).rejects.toThrow('pending transaction');\n    await expect(this.querier.release()).rejects.toThrow('pending transaction');\n    await this.querier.rollbackTransaction();\n    await this.querier.release();\n  }\n\n  async shouldReturnTransactionValue() {\n    const affectedRows = await this.querier.transaction(async () => {\n      await this.shouldInsertMany();\n      const count = await this.querier.count(User, {});\n      await this.querier.deleteMany(User, {});\n      return count;\n    });\n    expect(affectedRows).toBe(2);\n  }\n\n  async shouldThrowWhenCommitTransactionWithoutBeginTransaction() {\n    await expect(this.querier.commitTransaction()).rejects.toThrow('not a pending transaction');\n  }\n\n  async shouldSelectOneToManyEmpty() {\n    const inventoryAdjustment = await this.querier.findOneById(InventoryAdjustment, -1, {\n      $select: { itemAdjustments: true, creator: true },\n    });\n    expect(inventoryAdjustment).toBeUndefined();\n\n    const inventoryAdjustments = await this.querier.findMany(InventoryAdjustment, {\n      $select: { itemAdjustments: true },\n    });\n    expect(inventoryAdjustments).toHaveLength(0);\n  }\n\n  async shouldSelectOneToMany() {\n    await this.shouldInsertOne();\n\n    const [user, company] = await Promise.all([\n      this.querier.findOne(User, { $select: ['id'] }),\n      this.querier.findOne(Company, { $select: ['id'] }),\n    ]);\n\n    const [firstItemId, secondItemId] = await this.querier.insertMany(Item, [\n      {\n        name: 'some item name a',\n        creatorId: user.id,\n        companyId: company.id,\n      },\n      {\n        name: 'some item name b',\n        creatorId: user.id,\n        companyId: company.id,\n      },\n    ]);\n\n    const inventoryAdjustmentId = await this.querier.insertOne(InventoryAdjustment, {\n      description: 'some inventory adjustment',\n      creatorId: user.id,\n      companyId: company.id,\n      itemAdjustments: [\n        { buyPrice: 1000, itemId: firstItemId },\n        { buyPrice: 2000, itemId: secondItemId },\n      ],\n    });\n\n    const inventoryAdjustmentFound = await this.querier.findOneById(InventoryAdjustment, inventoryAdjustmentId, {\n      $select: { itemAdjustments: true, creator: true },\n    });\n\n    expect(inventoryAdjustmentFound).toMatchObject({\n      id: inventoryAdjustmentId,\n      itemAdjustments: [\n        { buyPrice: 1000, itemId: firstItemId },\n        { buyPrice: 2000, itemId: secondItemId },\n      ],\n      creator: {\n        email: 'someemailc@example.com',\n        name: 'Some Name C',\n      },\n    });\n  }\n\n  async shouldDeleteMany() {\n    await Promise.all([this.shouldInsertMany(), this.shouldInsertOne()]);\n    await expect(this.querier.deleteMany(User, { $where: { companyId: 1 } })).resolves.toBe(0);\n    await expect(this.querier.deleteMany(User, { $where: { companyId: null } })).resolves.toBe(3);\n  }\n\n  async clearTables() {\n    const entities = getEntities();\n    await Promise.all(entities.map((entity) => this.querier.deleteMany(entity, {})));\n  }\n\n  abstract createTables(): Promise<void>;\n\n  abstract dropTables(): Promise<void>;\n}\n"]}
@@ -0,0 +1,50 @@
1
+ import type { IdValue, Querier, Query, QueryConflictPaths, QueryOne, QueryOptions, QuerySearch, QuerySelect, QueryUpdateResult, RelationKey, Repository, Type } from '../type/index.js';
2
+ /**
3
+ * Base class for all database queriers.
4
+ * It provides a standardized way to execute tasks serially to prevent race conditions on database connections.
5
+ */
6
+ export declare abstract class AbstractQuerier implements Querier {
7
+ /**
8
+ * Internal promise used to queue database operations.
9
+ * This ensures that each operation is executed serially, preventing race conditions
10
+ * and ensuring that the database connection is used safely across concurrent calls.
11
+ */
12
+ private taskQueue;
13
+ findOneById<E>(entity: Type<E>, id: IdValue<E>, q?: QueryOne<E>): Promise<E>;
14
+ findOne<E>(entity: Type<E>, q: QueryOne<E>): Promise<E>;
15
+ abstract findMany<E>(entity: Type<E>, q: Query<E>): Promise<E[]>;
16
+ findManyAndCount<E>(entity: Type<E>, q: Query<E>): Promise<[E[], number]>;
17
+ abstract count<E>(entity: Type<E>, q: QuerySearch<E>): Promise<number>;
18
+ insertOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E>>;
19
+ abstract insertMany<E>(entity: Type<E>, payload: E[]): Promise<IdValue<E>[]>;
20
+ updateOneById<E>(entity: Type<E>, id: IdValue<E>, payload: E): Promise<number>;
21
+ abstract updateMany<E>(entity: Type<E>, q: QuerySearch<E>, payload: E): Promise<number>;
22
+ abstract upsertOne<E>(entity: Type<E>, conflictPaths: QueryConflictPaths<E>, payload: E): Promise<QueryUpdateResult>;
23
+ deleteOneById<E>(entity: Type<E>, id: IdValue<E>, opts?: QueryOptions): Promise<number>;
24
+ abstract deleteMany<E>(entity: Type<E>, q: QuerySearch<E>, opts?: QueryOptions): Promise<number>;
25
+ saveOne<E>(entity: Type<E>, payload: E): Promise<IdValue<E> | E[import("../type/entity.js").IdKey<E>]>;
26
+ saveMany<E>(entity: Type<E>, payload: E[]): Promise<(Awaited<IdValue<E>> | Awaited<E[import("../type/entity.js").IdKey<E>]>)[]>;
27
+ protected fillToManyRelations<E>(entity: Type<E>, payload: E[], select: QuerySelect<E>): Promise<void>;
28
+ protected putChildrenInParents<E>(parents: E[], children: E[], parentIdKey: string, referenceKey: string, relKey: string): void;
29
+ protected insertRelations<E>(entity: Type<E>, payload: E[]): Promise<void>;
30
+ protected updateRelations<E>(entity: Type<E>, q: QuerySearch<E>, payload: E): Promise<void>;
31
+ protected deleteRelations<E>(entity: Type<E>, ids: IdValue<E>[], opts?: QueryOptions): Promise<void>;
32
+ protected saveRelation<E>(entity: Type<E>, payload: E, relKey: RelationKey<E>, isUpdate?: boolean): Promise<void>;
33
+ getRepository<E>(entity: Type<E>): Repository<E>;
34
+ abstract readonly hasOpenTransaction: boolean;
35
+ transaction<T>(callback: () => Promise<T>): Promise<T>;
36
+ releaseIfFree(): Promise<void>;
37
+ /**
38
+ * Schedules a task to be executed serially in the querier instance.
39
+ * This is used by the @Serialized decorator to protect database-level operations.
40
+ *
41
+ * @param task - The async task to execute.
42
+ * @returns A promise that resolves with the task's result.
43
+ */
44
+ protected serialize<T>(task: () => Promise<T>): Promise<T>;
45
+ abstract beginTransaction(): Promise<void>;
46
+ abstract commitTransaction(): Promise<void>;
47
+ abstract rollbackTransaction(): Promise<void>;
48
+ protected abstract internalRelease(): Promise<void>;
49
+ release(): Promise<void>;
50
+ }