@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
@@ -10,12 +10,16 @@ const MAX_RETRIES = 4
10
10
  const { TRIGGER_DEFINITIONS, ACTION_DEFINITIONS } = require("../../../automations")
11
11
  const { events } = require("@budibase/backend-core")
12
12
 
13
+
14
+ jest.setTimeout(30000)
15
+
13
16
  describe("/automations", () => {
14
17
  let request = setup.getRequest()
15
18
  let config = setup.getConfig()
16
19
 
17
20
  afterAll(setup.afterAll)
18
21
 
22
+ // For some reason this cannot be a beforeAll or the test "tests the automation successfully" fail
19
23
  beforeEach(async () => {
20
24
  await config.init()
21
25
  })
@@ -145,7 +149,7 @@ describe("/automations", () => {
145
149
  let elements = await getAllTableRows(config)
146
150
  // don't test it unless there are values to test
147
151
  if (elements.length > 1) {
148
- expect(elements.length).toEqual(5)
152
+ expect(elements.length).toBeGreaterThanOrEqual(MAX_RETRIES)
149
153
  expect(elements[0].name).toEqual("Test")
150
154
  expect(elements[0].description).toEqual("TEST")
151
155
  return
@@ -305,7 +309,7 @@ describe("/automations", () => {
305
309
  .expect('Content-Type', /json/)
306
310
  .expect(200)
307
311
 
308
- expect(res.body[0]).toEqual(expect.objectContaining(autoConfig))
312
+ expect(res.body[0]).toEqual(expect.objectContaining(autoConfig))
309
313
  })
310
314
 
311
315
  it("should apply authorization to endpoint", async () => {
@@ -1,17 +1,8 @@
1
- jest.mock("@budibase/backend-core", () => {
2
- const core = jest.requireActual("@budibase/backend-core")
3
- return {
4
- ...core,
5
- objectStore: {
6
- budibaseTempDir: core.objectStore.budibaseTempDir,
7
- },
8
- }
9
- })
10
-
11
1
  import * as setup from "./utilities"
12
2
  import { events } from "@budibase/backend-core"
13
3
  import sdk from "../../../sdk"
14
4
  import { checkBuilderEndpoint } from "./utilities/TestFunctions"
5
+
15
6
  describe("/backups", () => {
16
7
  let request = setup.getRequest()
17
8
  let config = setup.getConfig()
@@ -44,9 +35,9 @@ describe("/backups", () => {
44
35
 
45
36
  describe("calculateBackupStats", () => {
46
37
  it("should be able to calculate the backup statistics", async () => {
47
- config.createAutomation()
48
- config.createScreen()
49
- let res = await sdk.backups.calculateBackupStats(config.getAppId())
38
+ await config.createAutomation()
39
+ await config.createScreen()
40
+ let res = await sdk.backups.calculateBackupStats(config.getAppId()!)
50
41
  expect(res.automations).toEqual(1)
51
42
  expect(res.datasources).toEqual(1)
52
43
  expect(res.screens).toEqual(1)
@@ -1,14 +1,22 @@
1
- import { db as dbCore } from "@budibase/backend-core"
1
+ jest.setTimeout(30000)
2
+
2
3
  import { AppStatus } from "../../../db/utils"
3
4
 
4
5
  import * as setup from "./utilities"
5
6
 
7
+ import { wipeDb } from "./utilities/TestFunctions"
8
+
6
9
  describe("/cloud", () => {
7
- let request = setup.getRequest()
10
+ let request = setup.getRequest()!
8
11
  let config = setup.getConfig()
9
12
 
10
13
  afterAll(setup.afterAll)
11
14
 
15
+ beforeAll(() => {
16
+ // Importing is only allowed in self hosted environments
17
+ config.modeSelf()
18
+ })
19
+
12
20
  beforeEach(async () => {
13
21
  await config.init()
14
22
  })
@@ -22,19 +30,7 @@ describe("/cloud", () => {
22
30
  it("should be able to import apps", async () => {
23
31
  // first we need to delete any existing apps on the system so it looks clean otherwise the
24
32
  // import will not run
25
- await request
26
- .post(
27
- `/api/applications/${dbCore.getProdAppID(
28
- config.getAppId()
29
- )}/unpublish`
30
- )
31
- .set(config.defaultHeaders())
32
- .expect(204)
33
- await request
34
- .delete(`/api/applications/${config.getAppId()}`)
35
- .set(config.defaultHeaders())
36
- .expect("Content-Type", /json/)
37
- .expect(200)
33
+ await wipeDb()
38
34
 
39
35
  // get a count of apps before the import
40
36
  const preImportApps = await request
@@ -7,7 +7,7 @@ describe("/component", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -5,6 +5,10 @@ import { checkCacheForDynamicVariable } from "../../../threads/utils"
5
5
  import { context, events } from "@budibase/backend-core"
6
6
  import sdk from "../../../sdk"
7
7
 
8
+ import tk from "timekeeper"
9
+ import { mocks } from "@budibase/backend-core/tests"
10
+ tk.freeze(mocks.date.MOCK_DATE)
11
+
8
12
  let { basicDatasource } = setup.structures
9
13
  const pg = require("pg")
10
14
 
@@ -15,11 +19,13 @@ describe("/datasources", () => {
15
19
 
16
20
  afterAll(setup.afterAll)
17
21
 
18
- beforeEach(async () => {
22
+ async function setupTest() {
19
23
  await config.init()
20
24
  datasource = await config.createDatasource()
21
25
  jest.clearAllMocks()
22
- })
26
+ }
27
+
28
+ beforeAll(setupTest)
23
29
 
24
30
  describe("create", () => {
25
31
  it("should create a new datasource", async () => {
@@ -56,7 +62,14 @@ describe("/datasources", () => {
56
62
  datasource: any,
57
63
  fields: { path: string; queryString: string }
58
64
  ) {
59
- return config.previewQuery(request, config, datasource, fields)
65
+ return config.previewQuery(
66
+ request,
67
+ config,
68
+ datasource,
69
+ fields,
70
+ undefined,
71
+ ""
72
+ )
60
73
  }
61
74
 
62
75
  it("should invalidate changed or removed variables", async () => {
@@ -91,6 +104,8 @@ describe("/datasources", () => {
91
104
  })
92
105
 
93
106
  describe("fetch", () => {
107
+ beforeAll(setupTest)
108
+
94
109
  it("returns all the datasources from the server", async () => {
95
110
  const res = await request
96
111
  .get(`/api/datasources`)
@@ -159,6 +174,8 @@ describe("/datasources", () => {
159
174
  })
160
175
 
161
176
  describe("destroy", () => {
177
+ beforeAll(setupTest)
178
+
162
179
  it("deletes queries for the datasource after deletion and returns a success message", async () => {
163
180
  await config.createQuery()
164
181
 
@@ -8,7 +8,7 @@ describe("/dev", () => {
8
8
 
9
9
  afterAll(setup.afterAll)
10
10
 
11
- beforeEach(async () => {
11
+ beforeAll(async () => {
12
12
  await config.init()
13
13
  jest.clearAllMocks()
14
14
  })
@@ -0,0 +1,144 @@
1
+ const pg = require("pg")
2
+ jest.mock("pg", () => {
3
+ return {
4
+ Client: jest.fn().mockImplementation(() => ({
5
+ connect: jest.fn(),
6
+ query: jest.fn().mockImplementation(() => ({ rows: [] })),
7
+ end: jest.fn().mockImplementation((fn: any) => fn()),
8
+ })),
9
+ queryMock: jest.fn().mockImplementation(() => {}),
10
+ on: jest.fn(),
11
+ }
12
+ })
13
+ import * as setup from "./utilities"
14
+ import { mocks } from "@budibase/backend-core/tests"
15
+ import { env, events } from "@budibase/backend-core"
16
+ const structures = setup.structures
17
+
18
+ env._set("ENCRYPTION_KEY", "budibase")
19
+ mocks.licenses.useEnvironmentVariables()
20
+
21
+ describe("/api/env/variables", () => {
22
+ let request = setup.getRequest()
23
+ let config = setup.getConfig()
24
+
25
+ afterAll(setup.afterAll)
26
+
27
+ beforeAll(async () => {
28
+ await config.init()
29
+ })
30
+
31
+ it("should be able check the status of env var API", async () => {
32
+ const res = await request
33
+ .get(`/api/env/variables/status`)
34
+ .set(config.defaultHeaders())
35
+ .expect("Content-Type", /json/)
36
+ .expect(200)
37
+
38
+ expect(res.body.encryptionKeyAvailable).toEqual(true)
39
+ })
40
+
41
+ it("should be able to create an environment variable", async () => {
42
+ await request
43
+ .post(`/api/env/variables`)
44
+ .send(structures.basicEnvironmentVariable("test", "test"))
45
+ .set(config.defaultHeaders())
46
+ .expect(200)
47
+ })
48
+
49
+ it("should be able to fetch the 'test' variable name", async () => {
50
+ const res = await request
51
+ .get(`/api/env/variables`)
52
+ .set(config.defaultHeaders())
53
+ .expect("Content-Type", /json/)
54
+ .expect(200)
55
+ expect(res.body.variables.length).toEqual(1)
56
+ expect(res.body.variables[0]).toEqual("test")
57
+ })
58
+
59
+ it("should be able to update the environment variable 'test'", async () => {
60
+ const varName = "test"
61
+ await request
62
+ .patch(`/api/env/variables/${varName}`)
63
+ .send(structures.basicEnvironmentVariable("test", "test1"))
64
+ .set(config.defaultHeaders())
65
+ .expect(200)
66
+ })
67
+
68
+ it("should be able to delete the environment variable 'test'", async () => {
69
+ const varName = "test"
70
+ await request
71
+ .delete(`/api/env/variables/${varName}`)
72
+ .set(config.defaultHeaders())
73
+ .expect(200)
74
+ })
75
+
76
+ it("should create a datasource (using the environment variable) and query", async () => {
77
+ const datasourceBase = structures.basicDatasource()
78
+ await request
79
+ .post(`/api/env/variables`)
80
+ .send(structures.basicEnvironmentVariable("test", "test"))
81
+ .set(config.defaultHeaders())
82
+
83
+ datasourceBase.datasource.config = {
84
+ password: "{{ env.test }}",
85
+ }
86
+ const response = await request
87
+ .post(`/api/datasources`)
88
+ .send(datasourceBase)
89
+ .set(config.defaultHeaders())
90
+ .expect("Content-Type", /json/)
91
+ .expect(200)
92
+ expect(response.body.datasource._id).toBeDefined()
93
+
94
+ const response2 = await request
95
+ .post(`/api/queries`)
96
+ .send(structures.basicQuery(response.body.datasource._id))
97
+ .set(config.defaultHeaders())
98
+ .expect("Content-Type", /json/)
99
+ .expect(200)
100
+ expect(response2.body._id).toBeDefined()
101
+ })
102
+
103
+ it("should run a query preview and check the mocked results", async () => {
104
+ const datasourceBase = structures.basicDatasource()
105
+ await request
106
+ .post(`/api/env/variables`)
107
+ .send(structures.basicEnvironmentVariable("test", "test"))
108
+ .set(config.defaultHeaders())
109
+
110
+ datasourceBase.datasource.config = {
111
+ password: "{{ env.test }}",
112
+ }
113
+ const response = await request
114
+ .post(`/api/datasources`)
115
+ .send(datasourceBase)
116
+ .set(config.defaultHeaders())
117
+ .expect("Content-Type", /json/)
118
+ .expect(200)
119
+ expect(response.body.datasource._id).toBeDefined()
120
+
121
+ const query = {
122
+ datasourceId: response.body.datasource._id,
123
+ parameters: {},
124
+ fields: {},
125
+ queryVerb: "read",
126
+ name: response.body.datasource.name,
127
+ }
128
+ const res = await request
129
+ .post(`/api/queries/preview`)
130
+ .send(query)
131
+ .set(config.defaultHeaders())
132
+ .expect("Content-Type", /json/)
133
+ .expect(200)
134
+ expect(res.body.rows.length).toEqual(0)
135
+ expect(events.query.previewed).toBeCalledTimes(1)
136
+ // API doesn't include config in response
137
+ delete response.body.datasource.config
138
+ expect(events.query.previewed).toBeCalledWith(
139
+ response.body.datasource,
140
+ query
141
+ )
142
+ expect(pg.Client).toHaveBeenCalledWith({ password: "test", ssl: undefined })
143
+ })
144
+ })
@@ -7,7 +7,7 @@ describe("/integrations", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -10,7 +10,7 @@ describe("/layouts", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  await config.init()
15
15
  layout = await config.createLayout()
16
16
  jest.clearAllMocks()
@@ -9,7 +9,7 @@ describe("/metadata", () => {
9
9
 
10
10
  afterAll(setup.afterAll)
11
11
 
12
- beforeEach(async () => {
12
+ beforeAll(async () => {
13
13
  await config.init()
14
14
  automation = await config.createAutomation()
15
15
  })
@@ -7,7 +7,7 @@ describe("run misc tests", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -15,8 +15,11 @@ describe("/permission", () => {
15
15
 
16
16
  afterAll(setup.afterAll)
17
17
 
18
- beforeEach(async () => {
18
+ beforeAll(async () => {
19
19
  await config.init()
20
+ })
21
+
22
+ beforeEach(async () => {
20
23
  table = await config.createTable()
21
24
  row = await config.createRow()
22
25
  perms = await config.addPermission(STD_ROLE_ID, table._id)
@@ -1,3 +1,6 @@
1
+ const tk = require( "timekeeper")
2
+ tk.freeze(Date.now())
3
+
1
4
  // Mock out postgres for this
2
5
  jest.mock("pg")
3
6
  jest.mock("node-fetch")
@@ -27,10 +30,15 @@ describe("/queries", () => {
27
30
 
28
31
  afterAll(setup.afterAll)
29
32
 
30
- beforeEach(async () => {
33
+ const setupTest = async()=>{
34
+
31
35
  await config.init()
32
36
  datasource = await config.createDatasource()
33
37
  query = await config.createQuery()
38
+ }
39
+
40
+ beforeAll(async () => {
41
+ await setupTest()
34
42
  })
35
43
 
36
44
  async function createInvalidIntegration() {
@@ -101,6 +109,10 @@ describe("/queries", () => {
101
109
  })
102
110
 
103
111
  describe("fetch", () => {
112
+ beforeEach(async() => {
113
+ await setupTest()
114
+ })
115
+
104
116
  it("returns all the queries from the server", async () => {
105
117
  const res = await request
106
118
  .get(`/api/queries`)
@@ -178,6 +190,10 @@ describe("/queries", () => {
178
190
  })
179
191
 
180
192
  describe("destroy", () => {
193
+ beforeEach(async() => {
194
+ await setupTest()
195
+ })
196
+
181
197
  it("deletes a query and returns a success message", async () => {
182
198
  await request
183
199
  .delete(`/api/queries/${query._id}/${query._rev}`)
@@ -226,6 +242,7 @@ describe("/queries", () => {
226
242
  })
227
243
  expect(res.body.rows.length).toEqual(1)
228
244
  expect(events.query.previewed).toBeCalledTimes(1)
245
+ delete datasource.config
229
246
  expect(events.query.previewed).toBeCalledWith(datasource, query)
230
247
  })
231
248
 
@@ -239,6 +256,10 @@ describe("/queries", () => {
239
256
  })
240
257
 
241
258
  describe("execute", () => {
259
+ beforeEach(async() => {
260
+ await setupTest()
261
+ })
262
+
242
263
  it("should be able to execute the query", async () => {
243
264
  const res = await request
244
265
  .post(`/api/queries/${query._id}`)
@@ -10,7 +10,7 @@ describe("/roles", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  await config.init()
15
15
  })
16
16
 
@@ -60,6 +60,11 @@ describe("/roles", () => {
60
60
  })
61
61
 
62
62
  describe("fetch", () => {
63
+ beforeAll(async () => {
64
+ // Recreate the app
65
+ await config.init()
66
+ })
67
+
63
68
  it("should list custom roles, plus 2 default roles", async () => {
64
69
  const customRole = await config.createRole()
65
70
 
@@ -16,7 +16,7 @@ describe("/routing", () => {
16
16
 
17
17
  afterAll(setup.afterAll)
18
18
 
19
- beforeEach(async () => {
19
+ beforeAll(async () => {
20
20
  await config.init()
21
21
  screen = basicScreen()
22
22
  screen.routing.route = route
@@ -1,3 +1,8 @@
1
+ const tk = require( "timekeeper")
2
+ const timestamp = new Date("2023-01-26T11:48:57.597Z").toISOString()
3
+ tk.freeze(timestamp)
4
+
5
+
1
6
  const { outputProcessing } = require("../../../utilities/rowProcessor")
2
7
  const setup = require("./utilities")
3
8
  const { basicRow } = setup.structures
@@ -20,8 +25,11 @@ describe("/rows", () => {
20
25
 
21
26
  afterAll(setup.afterAll)
22
27
 
23
- beforeEach(async () => {
28
+ beforeAll(async () => {
24
29
  await config.init()
30
+ })
31
+
32
+ beforeEach(async()=>{
25
33
  table = await config.createTable()
26
34
  row = basicRow(table._id)
27
35
  })
@@ -111,8 +119,8 @@ describe("/rows", () => {
111
119
  _id: existing._id,
112
120
  _rev: existing._rev,
113
121
  type: "row",
114
- createdAt: "2020-01-01T00:00:00.000Z",
115
- updatedAt: "2020-01-01T00:00:00.000Z",
122
+ createdAt: timestamp,
123
+ updatedAt: timestamp,
116
124
  })
117
125
  await assertQueryUsage(queryUsage + 1)
118
126
  })
@@ -10,7 +10,7 @@ describe("/screens", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  await config.init()
15
15
  screen = await config.createScreen()
16
16
  })
@@ -8,7 +8,8 @@ describe("/static", () => {
8
8
 
9
9
  afterAll(setup.afterAll)
10
10
 
11
- beforeEach(async () => {
11
+ beforeAll(async () => {
12
+ config.modeSelf()
12
13
  app = await config.init()
13
14
  })
14
15
 
@@ -10,7 +10,7 @@ describe("/tables", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  const app = await config.init()
15
15
  appId = app.appId
16
16
  })
@@ -6,7 +6,7 @@ describe("/templates", () => {
6
6
 
7
7
  afterAll(setup.afterAll)
8
8
 
9
- beforeEach(async () => {
9
+ beforeAll(async () => {
10
10
  await config.init()
11
11
  })
12
12
 
@@ -1,8 +1,10 @@
1
- const { roles } = require("@budibase/backend-core")
1
+ const { roles, utils } = require("@budibase/backend-core")
2
2
  const { checkPermissionsEndpoint } = require("./utilities/TestFunctions")
3
3
  const setup = require("./utilities")
4
4
  const { BUILTIN_ROLE_IDS } = roles
5
5
 
6
+ jest.setTimeout(30000)
7
+
6
8
  jest.mock("../../../utilities/workerRequests", () => ({
7
9
  getGlobalUsers: jest.fn(() => {
8
10
  return {}
@@ -19,14 +21,15 @@ describe("/users", () => {
19
21
 
20
22
  afterAll(setup.afterAll)
21
23
 
24
+ // For some reason this cannot be a beforeAll or the test "should be able to update the user" fail
22
25
  beforeEach(async () => {
23
26
  await config.init()
24
27
  })
25
28
 
26
29
  describe("fetch", () => {
27
30
  it("returns a list of users from an instance db", async () => {
28
- await config.createUser("uuidx")
29
- await config.createUser("uuidy")
31
+ await config.createUser({ id: "uuidx" })
32
+ await config.createUser({ id: "uuidy" })
30
33
  const res = await request
31
34
  .get(`/api/users/metadata`)
32
35
  .set(config.defaultHeaders())
@@ -53,7 +56,7 @@ describe("/users", () => {
53
56
 
54
57
  describe("update", () => {
55
58
  it("should be able to update the user", async () => {
56
- const user = await config.createUser()
59
+ const user = await config.createUser({ id: `us_update${Math.random()}` })
57
60
  user.roleId = BUILTIN_ROLE_IDS.BASIC
58
61
  const res = await request
59
62
  .put(`/api/users/metadata`)
@@ -177,14 +180,11 @@ describe("/users", () => {
177
180
  const app1 = await config.createApp('App 1')
178
181
  const app2 = await config.createApp('App 2')
179
182
 
180
- let user = await config.createUser(
181
- undefined,
182
- undefined,
183
- undefined,
184
- undefined,
185
- false,
186
- true,
187
- { [app1.appId]: 'ADMIN' })
183
+ let user = await config.createUser({
184
+ builder: false,
185
+ admin: true,
186
+ roles: { [app1.appId]: 'ADMIN' }
187
+ })
188
188
  let res = await request
189
189
  .post(`/api/users/metadata/sync/${user._id}`)
190
190
  .set(config.defaultHeaders())
@@ -4,6 +4,8 @@ import { AppStatus } from "../../../../db/utils"
4
4
  import { roles, tenancy, context } from "@budibase/backend-core"
5
5
  import { TENANT_ID } from "../../../../tests/utilities/structures"
6
6
  import env from "../../../../environment"
7
+ import { db } from "@budibase/backend-core"
8
+ import Nano from "@budibase/nano"
7
9
 
8
10
  class Request {
9
11
  appId: any
@@ -30,7 +32,10 @@ export const getAllTableRows = async (config: any) => {
30
32
  return req.body
31
33
  }
32
34
 
33
- export const clearAllApps = async (tenantId = TENANT_ID) => {
35
+ export const clearAllApps = async (
36
+ tenantId = TENANT_ID,
37
+ exceptions: Array<string> = []
38
+ ) => {
34
39
  await tenancy.doInTenant(tenantId, async () => {
35
40
  const req: any = { query: { status: AppStatus.DEV }, user: { tenantId } }
36
41
  await appController.fetch(req)
@@ -38,7 +43,7 @@ export const clearAllApps = async (tenantId = TENANT_ID) => {
38
43
  if (!apps || apps.length <= 0) {
39
44
  return
40
45
  }
41
- for (let app of apps) {
46
+ for (let app of apps.filter((x: any) => !exceptions.includes(x.appId))) {
42
47
  const { appId } = app
43
48
  const req = new Request(null, { appId })
44
49
  await runRequest(appId, appController.destroy, req)
@@ -55,6 +60,24 @@ export const clearAllAutomations = async (config: any) => {
55
60
  }
56
61
  }
57
62
 
63
+ export const wipeDb = async () => {
64
+ const couchInfo = db.getCouchInfo()
65
+ const nano = Nano({
66
+ url: couchInfo.url,
67
+ requestDefaults: {
68
+ headers: {
69
+ Authorization: couchInfo.cookie,
70
+ },
71
+ },
72
+ parseUrl: false,
73
+ })
74
+ let dbs
75
+ do {
76
+ dbs = await nano.db.list()
77
+ await Promise.all(dbs.map(x => nano.db.destroy(x)))
78
+ } while (dbs.length)
79
+ }
80
+
58
81
  export const createRequest = (
59
82
  request: any,
60
83
  method: any,