@budibase/server 2.3.16 → 2.3.17-alpha.1

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 (455) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.6a3954cc.js → index.2492f6c7.js} +364 -364
  3. package/builder/assets/{index.4488f38d.css → index.7e76c039.css} +1 -1
  4. package/builder/index.html +2 -2
  5. package/dist/api/controllers/query/index.js +2 -0
  6. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  7. package/dist/api/controllers/row/external.js +12 -1
  8. package/dist/api/controllers/table/external.js +8 -8
  9. package/dist/app.js +7 -1
  10. package/dist/constants/index.js +4 -24
  11. package/dist/db/defaultData/datasource_bb_default.js +6 -5
  12. package/dist/db/linkedRows/LinkController.js +9 -8
  13. package/dist/ddApm.js +11 -0
  14. package/dist/elasticApm.js +14 -0
  15. package/dist/integrations/base/sql.js +10 -3
  16. package/dist/package.json +9 -6
  17. package/dist/sdk/app/backups/exports.js +8 -2
  18. package/dist/sdk/app/datasources/datasources.js +3 -0
  19. package/dist/tsconfig.build.tsbuildinfo +1 -1
  20. package/dist/utilities/retry.js +30 -0
  21. package/jest-testcontainers-config.js +8 -0
  22. package/jest.config.ts +28 -11
  23. package/package.json +10 -7
  24. package/scripts/load/create-many-apps.js +24 -0
  25. package/scripts/load/create-many-rows.js +30 -0
  26. package/scripts/load/utils.js +66 -0
  27. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  28. package/src/api/controllers/query/index.ts +2 -0
  29. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  30. package/src/api/controllers/row/external.ts +13 -1
  31. package/src/api/controllers/table/external.ts +3 -2
  32. package/src/api/routes/public/applications.ts +0 -1
  33. package/src/api/routes/public/tests/compare.spec.js +1 -1
  34. package/src/api/routes/public/tests/users.spec.js +1 -1
  35. package/src/api/routes/public/tests/utils.ts +25 -8
  36. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  37. package/src/api/routes/tests/analytics.spec.js +4 -1
  38. package/src/api/routes/tests/apikeys.spec.js +1 -1
  39. package/src/api/routes/tests/application.spec.ts +20 -6
  40. package/src/api/routes/tests/auth.spec.js +2 -2
  41. package/src/api/routes/tests/automation.spec.js +6 -2
  42. package/src/api/routes/tests/backup.spec.ts +4 -13
  43. package/src/api/routes/tests/{cloud.spec.ts → cloud.seq.spec.ts} +11 -15
  44. package/src/api/routes/tests/component.spec.js +1 -1
  45. package/src/api/routes/tests/datasource.spec.ts +20 -3
  46. package/src/api/routes/tests/dev.spec.js +1 -1
  47. package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
  48. package/src/api/routes/tests/integration.spec.js +1 -1
  49. package/src/api/routes/tests/layout.spec.js +1 -1
  50. package/src/api/routes/tests/metadata.spec.js +1 -1
  51. package/src/api/routes/tests/misc.spec.js +1 -1
  52. package/src/api/routes/tests/permissions.spec.js +4 -1
  53. package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
  54. package/src/api/routes/tests/role.spec.js +6 -1
  55. package/src/api/routes/tests/routing.spec.js +1 -1
  56. package/src/api/routes/tests/row.spec.js +11 -3
  57. package/src/api/routes/tests/screen.spec.js +1 -1
  58. package/src/api/routes/tests/static.spec.js +2 -1
  59. package/src/api/routes/tests/table.spec.js +1 -1
  60. package/src/api/routes/tests/templates.spec.js +1 -1
  61. package/src/api/routes/tests/user.spec.js +12 -12
  62. package/src/api/routes/tests/utilities/TestFunctions.ts +25 -2
  63. package/src/api/routes/tests/utilities/index.ts +5 -3
  64. package/src/api/routes/tests/view.spec.js +4 -1
  65. package/src/api/routes/tests/webhook.spec.js +11 -2
  66. package/src/app.ts +10 -1
  67. package/src/automations/tests/automation.spec.js +4 -4
  68. package/src/automations/tests/bash.spec.js +1 -1
  69. package/src/automations/tests/discord.spec.js +1 -1
  70. package/src/automations/tests/executeQuery.spec.js +2 -3
  71. package/src/automations/tests/executeScript.spec.js +1 -1
  72. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  73. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  74. package/src/automations/tests/serverLog.spec.js +1 -1
  75. package/src/automations/tests/updateRow.spec.js +1 -1
  76. package/src/automations/tests/zapier.spec.js +1 -1
  77. package/src/constants/index.ts +1 -23
  78. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  79. package/src/db/linkedRows/LinkController.ts +2 -1
  80. package/src/db/tests/linkController.spec.js +4 -1
  81. package/src/db/tests/linkTests.spec.js +1 -1
  82. package/src/ddApm.ts +7 -0
  83. package/src/elasticApm.ts +10 -0
  84. package/src/integration-test/postgres.spec.ts +752 -0
  85. package/src/integrations/base/sql.ts +15 -5
  86. package/src/integrations/oracle.ts +1 -1
  87. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  88. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  89. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  90. package/src/migrations/tests/index.spec.ts +13 -20
  91. package/src/sdk/app/backups/exports.ts +8 -2
  92. package/src/sdk/app/datasources/datasources.ts +3 -0
  93. package/src/tests/jestEnv.ts +2 -6
  94. package/src/tests/jestSetup.ts +8 -7
  95. package/src/tests/utilities/TestConfiguration.ts +126 -50
  96. package/src/tests/utilities/structures.ts +16 -2
  97. package/src/utilities/retry.ts +18 -0
  98. package/tsconfig.build.json +1 -0
  99. package/coverage/clover.xml +0 -11755
  100. package/coverage/coverage-final.json +0 -284
  101. package/coverage/lcov-report/base.css +0 -224
  102. package/coverage/lcov-report/block-navigation.js +0 -87
  103. package/coverage/lcov-report/favicon.png +0 -0
  104. package/coverage/lcov-report/index.html +0 -1031
  105. package/coverage/lcov-report/prettify.css +0 -1
  106. package/coverage/lcov-report/prettify.js +0 -2
  107. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  108. package/coverage/lcov-report/sorter.js +0 -196
  109. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
  110. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
  111. package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
  112. package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
  113. package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
  114. package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
  115. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
  116. package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
  117. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
  118. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
  119. package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
  120. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
  121. package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
  122. package/coverage/lcov-report/src/api/controllers/index.html +0 -431
  123. package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
  124. package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
  125. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
  126. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
  127. package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
  128. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
  129. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
  130. package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
  131. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
  132. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
  133. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
  134. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
  135. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
  136. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
  137. package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
  138. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
  139. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
  140. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
  141. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
  142. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
  143. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
  144. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
  145. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
  146. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
  147. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
  148. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
  149. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
  150. package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
  151. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
  152. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
  153. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
  154. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
  155. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
  156. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
  157. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
  158. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
  159. package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
  160. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
  161. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
  162. package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
  163. package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
  164. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
  165. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
  166. package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
  167. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
  168. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
  169. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
  170. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -577
  171. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
  172. package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
  173. package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
  174. package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
  175. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
  176. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
  177. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
  178. package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
  179. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
  180. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
  181. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
  182. package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
  183. package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
  184. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
  185. package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
  186. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
  187. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
  188. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
  189. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
  190. package/coverage/lcov-report/src/api/index.html +0 -116
  191. package/coverage/lcov-report/src/api/index.ts.html +0 -352
  192. package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
  193. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
  194. package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
  195. package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
  196. package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
  197. package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
  198. package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
  199. package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
  200. package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
  201. package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
  202. package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
  203. package/coverage/lcov-report/src/api/routes/index.html +0 -551
  204. package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
  205. package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
  206. package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
  207. package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
  208. package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
  209. package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
  210. package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
  211. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
  212. package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
  213. package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
  214. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
  215. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
  216. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
  217. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
  218. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
  219. package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
  220. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
  221. package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
  222. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
  223. package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
  224. package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
  225. package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
  226. package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
  227. package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
  228. package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
  229. package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
  230. package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
  231. package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
  232. package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
  233. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
  234. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
  235. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
  236. package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
  237. package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
  238. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
  239. package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
  240. package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
  241. package/coverage/lcov-report/src/app.ts.html +0 -424
  242. package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
  243. package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
  244. package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
  245. package/coverage/lcov-report/src/automations/index.html +0 -191
  246. package/coverage/lcov-report/src/automations/index.ts.html +0 -163
  247. package/coverage/lcov-report/src/automations/logging/index.html +0 -116
  248. package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
  249. package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
  250. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
  251. package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
  252. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
  253. package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -349
  254. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
  255. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
  256. package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
  257. package/coverage/lcov-report/src/automations/steps/index.html +0 -371
  258. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -361
  259. package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
  260. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
  261. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
  262. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
  263. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
  264. package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -292
  265. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
  266. package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
  267. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -355
  268. package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
  269. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
  270. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
  271. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
  272. package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
  273. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
  274. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
  275. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
  276. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
  277. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
  278. package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
  279. package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
  280. package/coverage/lcov-report/src/constants/index.html +0 -146
  281. package/coverage/lcov-report/src/constants/index.ts.html +0 -697
  282. package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
  283. package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
  284. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
  285. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
  286. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
  287. package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
  288. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
  289. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
  290. package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
  291. package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
  292. package/coverage/lcov-report/src/db/index.html +0 -176
  293. package/coverage/lcov-report/src/db/index.ts.html +0 -133
  294. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
  295. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
  296. package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
  297. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
  298. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
  299. package/coverage/lcov-report/src/db/newid.ts.html +0 -100
  300. package/coverage/lcov-report/src/db/utils.ts.html +0 -913
  301. package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
  302. package/coverage/lcov-report/src/definitions/index.html +0 -116
  303. package/coverage/lcov-report/src/environment.ts.html +0 -472
  304. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
  305. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
  306. package/coverage/lcov-report/src/events/index.html +0 -161
  307. package/coverage/lcov-report/src/events/index.ts.html +0 -100
  308. package/coverage/lcov-report/src/events/utils.ts.html +0 -319
  309. package/coverage/lcov-report/src/index.html +0 -191
  310. package/coverage/lcov-report/src/index.ts.html +0 -133
  311. package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
  312. package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
  313. package/coverage/lcov-report/src/integrations/base/index.html +0 -161
  314. package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
  315. package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
  316. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
  317. package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
  318. package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
  319. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
  320. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
  321. package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
  322. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
  323. package/coverage/lcov-report/src/integrations/index.html +0 -371
  324. package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
  325. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
  326. package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
  327. package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
  328. package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
  329. package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
  330. package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
  331. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
  332. package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
  333. package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
  334. package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
  335. package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
  336. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
  337. package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
  338. package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
  339. package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
  340. package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
  341. package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
  342. package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
  343. package/coverage/lcov-report/src/middleware/index.html +0 -236
  344. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
  345. package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
  346. package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
  347. package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
  348. package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
  349. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
  350. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
  351. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
  352. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
  353. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
  354. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
  355. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
  356. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
  357. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
  358. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
  359. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
  360. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
  361. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
  362. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
  363. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
  364. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
  365. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
  366. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
  367. package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
  368. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
  369. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
  370. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
  371. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
  372. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
  373. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
  374. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
  375. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
  376. package/coverage/lcov-report/src/migrations/index.html +0 -116
  377. package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
  378. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
  379. package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
  380. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
  381. package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
  382. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
  383. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
  384. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
  385. package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
  386. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
  387. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
  388. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
  389. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
  390. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
  391. package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
  392. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
  393. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
  394. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
  395. package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
  396. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
  397. package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
  398. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
  399. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
  400. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
  401. package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
  402. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
  403. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
  404. package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
  405. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
  406. package/coverage/lcov-report/src/sdk/index.html +0 -116
  407. package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
  408. package/coverage/lcov-report/src/sdk/users/index.html +0 -131
  409. package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
  410. package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
  411. package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
  412. package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
  413. package/coverage/lcov-report/src/startup.ts.html +0 -484
  414. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
  415. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
  416. package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
  417. package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
  418. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
  419. package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
  420. package/coverage/lcov-report/src/threads/index.html +0 -161
  421. package/coverage/lcov-report/src/threads/index.ts.html +0 -418
  422. package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
  423. package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
  424. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
  425. package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
  426. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  427. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
  428. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
  429. package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
  430. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
  431. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
  432. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
  433. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  434. package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
  435. package/coverage/lcov-report/src/utilities/index.html +0 -251
  436. package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
  437. package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
  438. package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
  439. package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
  440. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
  441. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
  442. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
  443. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
  444. package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
  445. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
  446. package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
  447. package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
  448. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
  449. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
  450. package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
  451. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
  452. package/coverage/lcov-report/src/watch.ts.html +0 -196
  453. package/coverage/lcov-report/src/websocket.ts.html +0 -163
  454. package/coverage/lcov.info +0 -21750
  455. package/dist/api/routes/public/tests/utils.js +0 -33
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.retry = void 0;
13
+ function retry(fn, maxTry = 5, retryCount = 1) {
14
+ return __awaiter(this, void 0, void 0, function* () {
15
+ const currRetry = typeof retryCount === "number" ? retryCount : 1;
16
+ try {
17
+ const result = yield fn();
18
+ return result;
19
+ }
20
+ catch (e) {
21
+ console.log(`Retry ${currRetry} failed.`);
22
+ if (currRetry > maxTry) {
23
+ console.log(`All ${maxTry} retry attempts exhausted`);
24
+ throw e;
25
+ }
26
+ return retry(fn, maxTry, currRetry + 1);
27
+ }
28
+ });
29
+ }
30
+ exports.retry = retry;
@@ -0,0 +1,8 @@
1
+ const { join } = require("path")
2
+ require("dotenv").config({
3
+ path: join(__dirname, "..", "..", "hosting", ".env"),
4
+ })
5
+
6
+ const jestTestcontainersConfigGenerator = require("../../jestTestcontainersConfigGenerator")
7
+
8
+ module.exports = jestTestcontainersConfigGenerator()
package/jest.config.ts CHANGED
@@ -1,16 +1,13 @@
1
1
  import { Config } from "@jest/types"
2
+
2
3
  import * as fs from "fs"
4
+ const preset = require("ts-jest/jest-preset")
3
5
 
4
- const config: Config.InitialOptions = {
5
- testEnvironment: "node",
6
+ const baseConfig: Config.InitialProjectOptions = {
7
+ ...preset,
8
+ preset: "@trendyol/jest-testcontainers",
6
9
  setupFiles: ["./src/tests/jestEnv.ts"],
7
10
  setupFilesAfterEnv: ["./src/tests/jestSetup.ts"],
8
- collectCoverageFrom: [
9
- "src/**/*.{js,ts}",
10
- // The use of coverage with couchdb view functions breaks tests
11
- "!src/db/views/staticViews.*",
12
- ],
13
- coverageReporters: ["lcov", "json", "clover"],
14
11
  transform: {
15
12
  "^.+\\.ts?$": "@swc/jest",
16
13
  },
@@ -18,19 +15,39 @@ const config: Config.InitialOptions = {
18
15
 
19
16
  if (!process.env.CI) {
20
17
  // use sources when not in CI
21
- config.moduleNameMapper = {
18
+ baseConfig.moduleNameMapper = {
22
19
  "@budibase/backend-core/(.*)": "<rootDir>/../backend-core/$1",
23
20
  "@budibase/backend-core": "<rootDir>/../backend-core/src",
24
21
  "@budibase/types": "<rootDir>/../types/src",
25
- "^axios.*$": "<rootDir>/node_modules/axios/lib/axios.js",
26
22
  }
27
23
  // add pro sources if they exist
28
24
  if (fs.existsSync("../../../budibase-pro")) {
29
- config.moduleNameMapper["@budibase/pro"] =
25
+ baseConfig.moduleNameMapper["@budibase/pro"] =
30
26
  "<rootDir>/../../../budibase-pro/packages/pro/src"
31
27
  }
32
28
  } else {
33
29
  console.log("Running tests with compiled dependency sources")
34
30
  }
35
31
 
32
+ const config: Config.InitialOptions = {
33
+ projects: [
34
+ {
35
+ ...baseConfig,
36
+ displayName: "sequential test",
37
+ testMatch: ["<rootDir>/**/*.seq.spec.[jt]s"],
38
+ runner: "jest-serial-runner",
39
+ },
40
+ {
41
+ ...baseConfig,
42
+ testMatch: ["<rootDir>/**/!(*.seq).spec.[jt]s"],
43
+ },
44
+ ],
45
+ collectCoverageFrom: [
46
+ "src/**/*.{js,ts}",
47
+ // The use of coverage with couchdb view functions breaks tests
48
+ "!src/db/views/staticViews.*",
49
+ ],
50
+ coverageReporters: ["lcov", "json", "clover"],
51
+ }
52
+
36
53
  export default config
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@budibase/server",
3
3
  "email": "hi@budibase.com",
4
- "version": "2.3.16",
4
+ "version": "2.3.17-alpha.1",
5
5
  "description": "Budibase Web Server",
6
6
  "main": "src/index.ts",
7
7
  "repository": {
@@ -43,11 +43,11 @@
43
43
  "license": "GPL-3.0",
44
44
  "dependencies": {
45
45
  "@apidevtools/swagger-parser": "10.0.3",
46
- "@budibase/backend-core": "^2.3.16",
47
- "@budibase/client": "^2.3.16",
48
- "@budibase/pro": "2.3.15",
49
- "@budibase/string-templates": "^2.3.16",
50
- "@budibase/types": "^2.3.16",
46
+ "@budibase/backend-core": "2.3.17-alpha.1",
47
+ "@budibase/client": "2.3.17-alpha.1",
48
+ "@budibase/pro": "2.3.17-alpha.0",
49
+ "@budibase/string-templates": "2.3.17-alpha.1",
50
+ "@budibase/types": "2.3.17-alpha.1",
51
51
  "@bull-board/api": "3.7.0",
52
52
  "@bull-board/koa": "3.9.4",
53
53
  "@elastic/elasticsearch": "7.10.0",
@@ -64,6 +64,7 @@
64
64
  "chokidar": "3.5.3",
65
65
  "csvtojson": "2.0.10",
66
66
  "curlconverter": "3.21.0",
67
+ "dd-trace": "3.13.2",
67
68
  "dotenv": "8.2.0",
68
69
  "download": "8.0.0",
69
70
  "elastic-apm-node": "3.38.0",
@@ -125,6 +126,7 @@
125
126
  "@jest/test-sequencer": "24.9.0",
126
127
  "@swc/core": "^1.3.25",
127
128
  "@swc/jest": "^0.2.24",
129
+ "@trendyol/jest-testcontainers": "^2.1.1",
128
130
  "@types/apidoc": "0.50.0",
129
131
  "@types/bson": "4.2.0",
130
132
  "@types/global-agent": "2.1.1",
@@ -151,6 +153,7 @@
151
153
  "is-wsl": "2.2.0",
152
154
  "jest": "28.1.1",
153
155
  "jest-openapi": "0.14.2",
156
+ "jest-serial-runner": "^1.2.1",
154
157
  "nodemon": "2.0.15",
155
158
  "openapi-types": "9.3.1",
156
159
  "openapi-typescript": "5.2.0",
@@ -169,5 +172,5 @@
169
172
  "optionalDependencies": {
170
173
  "oracledb": "5.3.0"
171
174
  },
172
- "gitHead": "0840e8897bc36ba5bc09c9d8d1a73a7de6498305"
175
+ "gitHead": "5c22c75429f742b3e0e64c01fc3ad41b5fd55000"
173
176
  }
@@ -0,0 +1,24 @@
1
+ #!/bin/node
2
+ const { createApp } = require("./utils")
3
+
4
+ const APP_COUNT = 100
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ for (let i = 0; i < APP_COUNT; i++) {
13
+ const app = await createApp(process.argv[2])
14
+ console.log(`App created: ${app._id}`)
15
+ }
16
+ }
17
+
18
+ run()
19
+ .then(() => {
20
+ console.log(`Finished creating ${APP_COUNT} apps.`)
21
+ })
22
+ .catch(err => {
23
+ console.error(err)
24
+ })
@@ -0,0 +1,30 @@
1
+ #!/bin/node
2
+ const { createApp, getTable, createRow } = require("./utils")
3
+
4
+ const ROW_COUNT = 1000
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ const apiKey = process.argv[2]
13
+ const app = await createApp(apiKey)
14
+ console.log(`App created: ${app._id}`)
15
+ const table = await getTable(apiKey, app._id)
16
+ console.log(`Table found: ${table.name}`)
17
+ const promises = []
18
+ for (let i = 0; i < ROW_COUNT; i++) {
19
+ promises.push(await createRow(apiKey, app._id, table))
20
+ }
21
+ await Promise.all(promises)
22
+ }
23
+
24
+ run()
25
+ .then(() => {
26
+ console.log(`Finished creating ${ROW_COUNT} rows.`)
27
+ })
28
+ .catch(err => {
29
+ console.error(err)
30
+ })
@@ -0,0 +1,66 @@
1
+ const fetch = require("node-fetch")
2
+ const uuid = require("uuid/v4")
3
+
4
+ const URL_APP = "http://localhost:10000/api/public/v1/applications"
5
+ const URL_TABLE = "http://localhost:10000/api/public/v1/tables/search"
6
+
7
+ async function request(apiKey, url, method, body, appId = undefined) {
8
+ const headers = {
9
+ "x-budibase-api-key": apiKey,
10
+ "Content-Type": "application/json",
11
+ }
12
+ if (appId) {
13
+ headers["x-budibase-app-id"] = appId
14
+ }
15
+ const res = await fetch(url, {
16
+ method,
17
+ headers,
18
+ body: JSON.stringify(body),
19
+ })
20
+ if (res.status !== 200) {
21
+ throw new Error(await res.text())
22
+ }
23
+ return res
24
+ }
25
+
26
+ exports.createApp = async apiKey => {
27
+ const name = uuid().replace(/-/g, "")
28
+ const body = {
29
+ name,
30
+ url: `/${name}`,
31
+ useTemplate: "true",
32
+ templateKey: "app/school-admin-panel",
33
+ templateName: "School Admin Panel",
34
+ }
35
+ const res = await request(apiKey, URL_APP, "POST", body)
36
+ const json = await res.json()
37
+ return json.data
38
+ }
39
+
40
+ exports.getTable = async (apiKey, appId) => {
41
+ const res = await request(apiKey, URL_TABLE, "POST", {}, appId)
42
+ const json = await res.json()
43
+ return json.data[0]
44
+ }
45
+
46
+ exports.createRow = async (apiKey, appId, table) => {
47
+ const body = {}
48
+ for (let [key, schema] of Object.entries(table.schema)) {
49
+ let fake
50
+ switch (schema.type) {
51
+ default:
52
+ case "string":
53
+ fake = schema.constraints.inclusion
54
+ ? schema.constraints.inclusion[0]
55
+ : "a"
56
+ break
57
+ case "number":
58
+ fake = 1
59
+ break
60
+ }
61
+ body[key] = fake
62
+ }
63
+ const url = `http://localhost:10000/api/public/v1/tables/${table._id}/rows`
64
+ const res = await request(apiKey, url, "POST", body, appId)
65
+ return (await res.json()).data
66
+ }
@@ -41,7 +41,7 @@ const datasets = {
41
41
  describe("Rest Importer", () => {
42
42
  const config = new TestConfig(false)
43
43
 
44
- beforeEach(async () => {
44
+ beforeAll(async () => {
45
45
  await config.init()
46
46
  })
47
47
 
@@ -186,6 +186,8 @@ export async function preview(ctx: any) {
186
186
  schemaFields[key] = fieldType
187
187
  }
188
188
  }
189
+ // remove configuration before sending event
190
+ delete datasource.config
189
191
  await events.query.previewed(datasource, query)
190
192
  ctx.body = {
191
193
  rows,
@@ -10,6 +10,7 @@ import {
10
10
  FieldSchema,
11
11
  Row,
12
12
  Table,
13
+ RelationshipTypes,
13
14
  } from "@budibase/types"
14
15
  import {
15
16
  breakRowIdField,
@@ -18,7 +19,7 @@ import {
18
19
  convertRowId,
19
20
  } from "../../../integrations/utils"
20
21
  import { getDatasourceAndQuery } from "./utils"
21
- import { FieldTypes, RelationshipTypes } from "../../../constants"
22
+ import { FieldTypes } from "../../../constants"
22
23
  import { breakExternalTableId, isSQL } from "../../../integrations/utils"
23
24
  import { processObjectSync } from "@budibase/string-templates"
24
25
  import { cloneDeep } from "lodash/fp"
@@ -44,6 +45,7 @@ export interface RunConfig {
44
45
  row?: Row
45
46
  rows?: Row[]
46
47
  tables?: Record<string, Table>
48
+ includeSqlRelationships?: IncludeRelationship
47
49
  }
48
50
 
49
51
  function buildFilters(
@@ -706,7 +708,9 @@ export class ExternalRequest {
706
708
  },
707
709
  resource: {
708
710
  // have to specify the fields to avoid column overlap (for SQL)
709
- fields: isSql ? this.buildFields(table) : [],
711
+ fields: isSql
712
+ ? this.buildFields(table, config.includeSqlRelationships)
713
+ : [],
710
714
  },
711
715
  filters,
712
716
  sort,
@@ -18,6 +18,7 @@ import {
18
18
  PaginationJson,
19
19
  Table,
20
20
  Datasource,
21
+ IncludeRelationship,
21
22
  } from "@budibase/types"
22
23
  import sdk from "../../../sdk"
23
24
 
@@ -57,6 +58,7 @@ export async function patch(ctx: BBContext) {
57
58
  return handleRequest(Operation.UPDATE, tableId, {
58
59
  id: breakRowIdField(id),
59
60
  row: inputs,
61
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
60
62
  })
61
63
  }
62
64
 
@@ -65,6 +67,7 @@ export async function save(ctx: BBContext) {
65
67
  const tableId = ctx.params.tableId
66
68
  return handleRequest(Operation.CREATE, tableId, {
67
69
  row: inputs,
70
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
68
71
  })
69
72
  }
70
73
 
@@ -78,7 +81,9 @@ export async function fetchView(ctx: BBContext) {
78
81
 
79
82
  export async function fetch(ctx: BBContext) {
80
83
  const tableId = ctx.params.tableId
81
- return handleRequest(Operation.READ, tableId)
84
+ return handleRequest(Operation.READ, tableId, {
85
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
86
+ })
82
87
  }
83
88
 
84
89
  export async function find(ctx: BBContext) {
@@ -86,6 +91,7 @@ export async function find(ctx: BBContext) {
86
91
  const tableId = ctx.params.tableId
87
92
  const response = (await handleRequest(Operation.READ, tableId, {
88
93
  id: breakRowIdField(id),
94
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
89
95
  })) as Row[]
90
96
  return response ? response[0] : response
91
97
  }
@@ -95,6 +101,7 @@ export async function destroy(ctx: BBContext) {
95
101
  const id = ctx.request.body._id
96
102
  const { row } = (await handleRequest(Operation.DELETE, tableId, {
97
103
  id: breakRowIdField(id),
104
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
98
105
  })) as { row: Row }
99
106
  return { response: { ok: true }, row }
100
107
  }
@@ -107,6 +114,7 @@ export async function bulkDestroy(ctx: BBContext) {
107
114
  promises.push(
108
115
  handleRequest(Operation.DELETE, tableId, {
109
116
  id: breakRowIdField(row._id),
117
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
110
118
  })
111
119
  )
112
120
  }
@@ -149,6 +157,7 @@ export async function search(ctx: BBContext) {
149
157
  filters: query,
150
158
  sort,
151
159
  paginate: paginateObj as PaginationJson,
160
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
152
161
  })) as Row[]
153
162
  let hasNextPage = false
154
163
  if (paginate && rows.length === limit) {
@@ -159,6 +168,7 @@ export async function search(ctx: BBContext) {
159
168
  limit: 1,
160
169
  page: bookmark * limit + 1,
161
170
  },
171
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
162
172
  })) as Row[]
163
173
  hasNextPage = nextRows.length > 0
164
174
  }
@@ -249,6 +259,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
249
259
  const response = (await handleRequest(Operation.READ, tableId, {
250
260
  id,
251
261
  datasource,
262
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
252
263
  })) as Row[]
253
264
  const table: Table = tables[tableName]
254
265
  const row = response[0]
@@ -276,6 +287,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
276
287
  [primaryLink]: linkedIds,
277
288
  },
278
289
  },
290
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
279
291
  })
280
292
  }
281
293
  return row
@@ -8,7 +8,7 @@ import {
8
8
  foreignKeyStructure,
9
9
  hasTypeChanged,
10
10
  } from "./utils"
11
- import { FieldTypes, RelationshipTypes } from "../../../constants"
11
+ import { FieldTypes } from "../../../constants"
12
12
  import { makeExternalQuery } from "../../../integrations/base/query"
13
13
  import { handleRequest } from "../row/external"
14
14
  import { events, context } from "@budibase/backend-core"
@@ -22,6 +22,7 @@ import {
22
22
  FieldSchema,
23
23
  BBContext,
24
24
  TableRequest,
25
+ RelationshipTypes,
25
26
  } from "@budibase/types"
26
27
  import sdk from "../../../sdk"
27
28
  const { cloneDeep } = require("lodash/fp")
@@ -146,7 +147,7 @@ function generateLinkSchema(
146
147
  column: FieldSchema,
147
148
  table: Table,
148
149
  relatedTable: Table,
149
- type: string
150
+ type: RelationshipTypes
150
151
  ) {
151
152
  if (!table.primary || !relatedTable.primary) {
152
153
  throw new Error("Unable to generate link schema, no primary keys")
@@ -1,7 +1,6 @@
1
1
  import controller from "../../controllers/public/applications"
2
2
  import Endpoint from "./utils/Endpoint"
3
3
  const { nameValidator, applicationValidator } = require("../utils/validators")
4
- import { db } from "@budibase/backend-core"
5
4
 
6
5
  const read = [],
7
6
  write = []
@@ -13,7 +13,7 @@ beforeAll(async () => {
13
13
  app = await config.init()
14
14
  table = await config.updateTable()
15
15
  apiKey = await config.generateApiKey()
16
- makeRequest = generateMakeRequest(apiKey, setup)
16
+ makeRequest = generateMakeRequest(apiKey)
17
17
  })
18
18
 
19
19
  afterAll(setup.afterAll)
@@ -10,7 +10,7 @@ beforeAll(async () => {
10
10
  await config.init()
11
11
  globalUser = await config.globalUser()
12
12
  apiKey = await config.generateApiKey(globalUser._id)
13
- makeRequest = generateMakeRequest(apiKey, setup)
13
+ makeRequest = generateMakeRequest(apiKey)
14
14
  workerRequests.readGlobalUser.mockReturnValue(globalUser)
15
15
  })
16
16
 
@@ -1,13 +1,27 @@
1
+ import * as setup from "../../tests/utilities"
1
2
  import { checkSlashesInUrl } from "../../../../utilities"
3
+ import supertest from "supertest"
2
4
 
3
- export function generateMakeRequest(apiKey: string, setup: any) {
4
- const request = setup.getRequest()
5
- const config = setup.getConfig()
5
+ export type HttpMethod = "post" | "get" | "put" | "delete" | "patch"
6
+
7
+ export type MakeRequestResponse = (
8
+ method: HttpMethod,
9
+ endpoint: string,
10
+ body?: any,
11
+ intAppId?: string
12
+ ) => Promise<supertest.Response>
13
+
14
+ export function generateMakeRequest(
15
+ apiKey: string,
16
+ isInternal = false
17
+ ): MakeRequestResponse {
18
+ const request = setup.getRequest()!
19
+ const config = setup.getConfig()!
6
20
  return async (
7
- method: string,
21
+ method: HttpMethod,
8
22
  endpoint: string,
9
23
  body?: any,
10
- intAppId: string = config.getAppId()
24
+ intAppId: string | null = config.getAppId()
11
25
  ) => {
12
26
  const extraHeaders: any = {
13
27
  "x-budibase-api-key": apiKey,
@@ -15,9 +29,12 @@ export function generateMakeRequest(apiKey: string, setup: any) {
15
29
  if (intAppId) {
16
30
  extraHeaders["x-budibase-app-id"] = intAppId
17
31
  }
18
- const req = request[method](
19
- checkSlashesInUrl(`/api/public/v1/${endpoint}`)
20
- ).set(config.defaultHeaders(extraHeaders))
32
+
33
+ const url = isInternal
34
+ ? endpoint
35
+ : checkSlashesInUrl(`/api/public/v1/${endpoint}`)
36
+
37
+ const req = request[method](url).set(config.defaultHeaders(extraHeaders))
21
38
  if (body) {
22
39
  req.send(body)
23
40
  }
@@ -7,7 +7,7 @@ Array [
7
7
  "entities": Array [
8
8
  Object {
9
9
  "_id": "ta_users",
10
- "_rev": "1-6f4013e796887f1771bf7837598d87e7",
10
+ "_rev": "1-2375e1bc58aeec664dc1b1f04ad43e44",
11
11
  "createdAt": "2020-01-01T00:00:00.000Z",
12
12
  "name": "Users",
13
13
  "primaryDisplay": "email",
@@ -10,8 +10,11 @@ describe("/static", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  app = await config.init()
15
+ })
16
+
17
+ beforeEach(()=>{
15
18
  jest.clearAllMocks()
16
19
  })
17
20
 
@@ -7,7 +7,7 @@ describe("/api/keys", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -14,18 +14,22 @@ jest.mock("../../../utilities/redis", () => ({
14
14
  import { clearAllApps, checkBuilderEndpoint } from "./utilities/TestFunctions"
15
15
  import * as setup from "./utilities"
16
16
  import { AppStatus } from "../../../db/utils"
17
- import { events } from "@budibase/backend-core"
17
+ import { events, utils } from "@budibase/backend-core"
18
18
  import env from "../../../environment"
19
19
 
20
+ jest.setTimeout(15000)
21
+
20
22
  describe("/applications", () => {
21
23
  let request = setup.getRequest()
22
24
  let config = setup.getConfig()
23
25
 
24
26
  afterAll(setup.afterAll)
25
27
 
26
- beforeEach(async () => {
27
- await clearAllApps()
28
+ beforeAll(async () => {
28
29
  await config.init()
30
+ })
31
+
32
+ beforeEach(async () => {
29
33
  jest.clearAllMocks()
30
34
  })
31
35
 
@@ -33,7 +37,7 @@ describe("/applications", () => {
33
37
  it("creates empty app", async () => {
34
38
  const res = await request
35
39
  .post("/api/applications")
36
- .field("name", "My App")
40
+ .field("name", utils.newid())
37
41
  .set(config.defaultHeaders())
38
42
  .expect("Content-Type", /json/)
39
43
  .expect(200)
@@ -44,7 +48,7 @@ describe("/applications", () => {
44
48
  it("creates app from template", async () => {
45
49
  const res = await request
46
50
  .post("/api/applications")
47
- .field("name", "My App")
51
+ .field("name", utils.newid())
48
52
  .field("useTemplate", "true")
49
53
  .field("templateKey", "test")
50
54
  .field("templateString", "{}") // override the file download
@@ -59,7 +63,7 @@ describe("/applications", () => {
59
63
  it("creates app from file", async () => {
60
64
  const res = await request
61
65
  .post("/api/applications")
62
- .field("name", "My App")
66
+ .field("name", utils.newid())
63
67
  .field("useTemplate", "true")
64
68
  .set(config.defaultHeaders())
65
69
  .attach("templateFile", "src/api/routes/tests/data/export.txt")
@@ -106,6 +110,11 @@ describe("/applications", () => {
106
110
  })
107
111
 
108
112
  describe("fetch", () => {
113
+ beforeEach(async () => {
114
+ // Clean all apps but the onde from config
115
+ await clearAllApps(config.getTenantId(), [config.getAppId()!])
116
+ })
117
+
109
118
  it("lists all applications", async () => {
110
119
  await config.createApp("app1")
111
120
  await config.createApp("app2")
@@ -266,6 +275,11 @@ describe("/applications", () => {
266
275
  })
267
276
 
268
277
  describe("unpublish", () => {
278
+ beforeEach(async () => {
279
+ // We want to republish as the unpublish will delete the prod app
280
+ await config.publish()
281
+ })
282
+
269
283
  it("should unpublish app with dev app ID", async () => {
270
284
  const appId = config.getAppId()
271
285
  await request
@@ -7,7 +7,7 @@ describe("/authenticate", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -18,7 +18,7 @@ describe("/authenticate", () => {
18
18
  .set(config.defaultHeaders())
19
19
  .expect("Content-Type", /json/)
20
20
  .expect(200)
21
- expect(res.body._id).toEqual(generateUserMetadataID("us_uuid1"))
21
+ expect(res.body._id).toEqual(generateUserMetadataID(config.user._id))
22
22
  })
23
23
  })
24
24
  })