@budibase/server 2.2.27-alpha.1 → 2.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (507) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.77ae0e4d.js → index.54ca0c91.js} +207 -207
  3. package/builder/index.html +1 -1
  4. package/coverage/clover.xml +4471 -8891
  5. package/coverage/coverage-final.json +69 -152
  6. package/coverage/lcov-report/index.html +117 -327
  7. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +1 -1
  8. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +1 -1
  9. package/coverage/lcov-report/src/api/controllers/application.ts.html +114 -114
  10. package/coverage/lcov-report/src/api/controllers/auth.ts.html +1 -1
  11. package/coverage/lcov-report/src/api/controllers/automation.ts.html +25 -25
  12. package/coverage/lcov-report/src/api/controllers/backup.ts.html +1 -1
  13. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +15 -15
  14. package/coverage/lcov-report/src/api/controllers/component.ts.html +1 -1
  15. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +17 -17
  16. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +12 -12
  17. package/coverage/lcov-report/src/api/controllers/deploy/index.html +1 -1
  18. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +70 -70
  19. package/coverage/lcov-report/src/api/controllers/dev.ts.html +10 -10
  20. package/coverage/lcov-report/src/api/controllers/index.html +35 -35
  21. package/coverage/lcov-report/src/api/controllers/integration.ts.html +1 -1
  22. package/coverage/lcov-report/src/api/controllers/layout.ts.html +11 -11
  23. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +1 -1
  24. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +1 -1
  25. package/coverage/lcov-report/src/api/controllers/permission.ts.html +22 -22
  26. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +1 -1
  27. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +1 -1
  28. package/coverage/lcov-report/src/api/controllers/plugin/index.html +1 -1
  29. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +8 -8
  30. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +1 -1
  31. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +1 -1
  32. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +1 -1
  33. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +1 -1
  34. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +1 -1
  35. package/coverage/lcov-report/src/api/controllers/public/index.html +1 -1
  36. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +1 -1
  37. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +1 -1
  38. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +1 -1
  39. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +1 -1
  40. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +1 -1
  41. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +1 -1
  42. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +1 -1
  43. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +1 -1
  44. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +1 -1
  45. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +1 -1
  46. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +1 -1
  47. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +1 -1
  48. package/coverage/lcov-report/src/api/controllers/query/import/index.html +1 -1
  49. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +1 -1
  50. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +1 -1
  51. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +1 -1
  52. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +1 -1
  53. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +1 -1
  54. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +1 -1
  55. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +1 -1
  56. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +1 -1
  57. package/coverage/lcov-report/src/api/controllers/query/index.html +1 -1
  58. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +13 -13
  59. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +1 -1
  60. package/coverage/lcov-report/src/api/controllers/role.ts.html +1 -1
  61. package/coverage/lcov-report/src/api/controllers/routing.ts.html +1 -1
  62. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +1 -1
  63. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +1 -1
  64. package/coverage/lcov-report/src/api/controllers/row/index.html +5 -5
  65. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +16 -16
  66. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +16 -16
  67. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +1 -1
  68. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +16 -16
  69. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +15 -15
  70. package/coverage/lcov-report/src/api/controllers/screen.ts.html +21 -21
  71. package/coverage/lcov-report/src/api/controllers/script.ts.html +1 -1
  72. package/coverage/lcov-report/src/api/controllers/static/index.html +1 -1
  73. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +1 -1
  74. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +43 -43
  75. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +1 -1
  76. package/coverage/lcov-report/src/api/controllers/table/index.html +20 -20
  77. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +18 -18
  78. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +49 -49
  79. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +34 -34
  80. package/coverage/lcov-report/src/api/controllers/templates.ts.html +1 -1
  81. package/coverage/lcov-report/src/api/controllers/user.ts.html +15 -15
  82. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +1 -1
  83. package/coverage/lcov-report/src/api/controllers/view/index.html +1 -1
  84. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +1 -1
  85. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +1 -1
  86. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +1 -1
  87. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +13 -13
  88. package/coverage/lcov-report/src/api/index.html +1 -1
  89. package/coverage/lcov-report/src/api/index.ts.html +5 -5
  90. package/coverage/lcov-report/src/api/routes/analytics.ts.html +1 -1
  91. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +1 -1
  92. package/coverage/lcov-report/src/api/routes/application.ts.html +1 -1
  93. package/coverage/lcov-report/src/api/routes/auth.ts.html +1 -1
  94. package/coverage/lcov-report/src/api/routes/automation.ts.html +1 -1
  95. package/coverage/lcov-report/src/api/routes/backup.ts.html +1 -1
  96. package/coverage/lcov-report/src/api/routes/cloud.ts.html +1 -1
  97. package/coverage/lcov-report/src/api/routes/component.ts.html +1 -1
  98. package/coverage/lcov-report/src/api/routes/datasource.ts.html +1 -1
  99. package/coverage/lcov-report/src/api/routes/deploy.ts.html +1 -1
  100. package/coverage/lcov-report/src/api/routes/dev.ts.html +1 -1
  101. package/coverage/lcov-report/src/api/routes/index.html +1 -1
  102. package/coverage/lcov-report/src/api/routes/index.ts.html +1 -1
  103. package/coverage/lcov-report/src/api/routes/integration.ts.html +1 -1
  104. package/coverage/lcov-report/src/api/routes/layout.ts.html +1 -1
  105. package/coverage/lcov-report/src/api/routes/metadata.ts.html +1 -1
  106. package/coverage/lcov-report/src/api/routes/migrations.ts.html +1 -1
  107. package/coverage/lcov-report/src/api/routes/permission.ts.html +1 -1
  108. package/coverage/lcov-report/src/api/routes/plugin.ts.html +1 -1
  109. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +1 -1
  110. package/coverage/lcov-report/src/api/routes/public/index.html +1 -1
  111. package/coverage/lcov-report/src/api/routes/public/index.ts.html +1 -1
  112. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +1 -1
  113. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +1 -1
  114. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +1 -1
  115. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +1 -1
  116. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +1 -1
  117. package/coverage/lcov-report/src/api/routes/public/tests/index.html +8 -38
  118. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +1 -1
  119. package/coverage/lcov-report/src/api/routes/public/users.ts.html +1 -1
  120. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +1 -1
  121. package/coverage/lcov-report/src/api/routes/public/utils/index.html +1 -1
  122. package/coverage/lcov-report/src/api/routes/query.ts.html +1 -1
  123. package/coverage/lcov-report/src/api/routes/role.ts.html +1 -1
  124. package/coverage/lcov-report/src/api/routes/routing.ts.html +1 -1
  125. package/coverage/lcov-report/src/api/routes/row.ts.html +1 -1
  126. package/coverage/lcov-report/src/api/routes/screen.ts.html +1 -1
  127. package/coverage/lcov-report/src/api/routes/script.ts.html +1 -1
  128. package/coverage/lcov-report/src/api/routes/static.ts.html +1 -1
  129. package/coverage/lcov-report/src/api/routes/table.ts.html +1 -1
  130. package/coverage/lcov-report/src/api/routes/templates.ts.html +1 -1
  131. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +41 -110
  132. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +19 -19
  133. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +5 -11
  134. package/coverage/lcov-report/src/api/routes/user.ts.html +1 -1
  135. package/coverage/lcov-report/src/api/routes/utils/index.html +1 -1
  136. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +1 -1
  137. package/coverage/lcov-report/src/api/routes/view.ts.html +1 -1
  138. package/coverage/lcov-report/src/api/routes/webhook.ts.html +1 -1
  139. package/coverage/lcov-report/src/app.ts.html +3 -6
  140. package/coverage/lcov-report/src/automations/actions.ts.html +1 -1
  141. package/coverage/lcov-report/src/automations/automationUtils.ts.html +1 -1
  142. package/coverage/lcov-report/src/automations/bullboard.ts.html +2 -2
  143. package/coverage/lcov-report/src/automations/index.html +27 -27
  144. package/coverage/lcov-report/src/automations/index.ts.html +5 -5
  145. package/coverage/lcov-report/src/automations/logging/index.html +1 -1
  146. package/coverage/lcov-report/src/automations/logging/index.ts.html +7 -7
  147. package/coverage/lcov-report/src/automations/steps/bash.ts.html +1 -1
  148. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +1 -1
  149. package/coverage/lcov-report/src/automations/steps/delay.ts.html +1 -1
  150. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +1 -1
  151. package/coverage/lcov-report/src/automations/steps/discord.ts.html +1 -1
  152. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +1 -1
  153. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +1 -1
  154. package/coverage/lcov-report/src/automations/steps/filter.ts.html +1 -1
  155. package/coverage/lcov-report/src/automations/steps/index.html +1 -1
  156. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +1 -1
  157. package/coverage/lcov-report/src/automations/steps/loop.ts.html +1 -1
  158. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +1 -1
  159. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +1 -1
  160. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +1 -1
  161. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +1 -1
  162. package/coverage/lcov-report/src/automations/steps/slack.ts.html +1 -1
  163. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +1 -1
  164. package/coverage/lcov-report/src/automations/steps/utils.ts.html +1 -1
  165. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +1 -1
  166. package/coverage/lcov-report/src/automations/tests/utilities/index.html +1 -1
  167. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +1 -1
  168. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +1 -1
  169. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +1 -1
  170. package/coverage/lcov-report/src/automations/triggerInfo/index.html +1 -1
  171. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +1 -1
  172. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +1 -1
  173. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +1 -1
  174. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +1 -1
  175. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +1 -1
  176. package/coverage/lcov-report/src/automations/triggers.ts.html +24 -24
  177. package/coverage/lcov-report/src/automations/utils.ts.html +38 -38
  178. package/coverage/lcov-report/src/constants/index.html +1 -1
  179. package/coverage/lcov-report/src/constants/index.ts.html +2 -2
  180. package/coverage/lcov-report/src/constants/layouts.ts.html +1 -1
  181. package/coverage/lcov-report/src/constants/screens.ts.html +3 -3
  182. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +1 -1
  183. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +1 -1
  184. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +1 -1
  185. package/coverage/lcov-report/src/db/defaultData/index.html +1 -1
  186. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +1 -1
  187. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +1 -1
  188. package/coverage/lcov-report/src/db/dynamoClient.ts.html +1 -1
  189. package/coverage/lcov-report/src/db/inMemoryView.ts.html +1 -1
  190. package/coverage/lcov-report/src/db/index.html +16 -16
  191. package/coverage/lcov-report/src/db/index.ts.html +13 -13
  192. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +12 -12
  193. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +1 -1
  194. package/coverage/lcov-report/src/db/linkedRows/index.html +1 -1
  195. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +15 -15
  196. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +6 -6
  197. package/coverage/lcov-report/src/db/newid.ts.html +3 -3
  198. package/coverage/lcov-report/src/db/utils.ts.html +33 -33
  199. package/coverage/lcov-report/src/definitions/automations.ts.html +1 -1
  200. package/coverage/lcov-report/src/definitions/index.html +1 -1
  201. package/coverage/lcov-report/src/environment.ts.html +19 -19
  202. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +1 -1
  203. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +1 -1
  204. package/coverage/lcov-report/src/events/index.html +1 -1
  205. package/coverage/lcov-report/src/events/index.ts.html +1 -1
  206. package/coverage/lcov-report/src/events/utils.ts.html +1 -1
  207. package/coverage/lcov-report/src/index.html +16 -16
  208. package/coverage/lcov-report/src/index.ts.html +1 -1
  209. package/coverage/lcov-report/src/integrations/airtable.ts.html +1 -1
  210. package/coverage/lcov-report/src/integrations/arangodb.ts.html +1 -1
  211. package/coverage/lcov-report/src/integrations/base/index.html +1 -1
  212. package/coverage/lcov-report/src/integrations/base/query.ts.html +1 -1
  213. package/coverage/lcov-report/src/integrations/base/sql.ts.html +1 -1
  214. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +1 -1
  215. package/coverage/lcov-report/src/integrations/base/utils.ts.html +1 -1
  216. package/coverage/lcov-report/src/integrations/couchdb.ts.html +1 -1
  217. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +1 -1
  218. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +1 -1
  219. package/coverage/lcov-report/src/integrations/firebase.ts.html +1 -1
  220. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +1 -1
  221. package/coverage/lcov-report/src/integrations/index.html +1 -1
  222. package/coverage/lcov-report/src/integrations/index.ts.html +10 -10
  223. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +1 -1
  224. package/coverage/lcov-report/src/integrations/mongodb.ts.html +1 -1
  225. package/coverage/lcov-report/src/integrations/mysql.ts.html +1 -1
  226. package/coverage/lcov-report/src/integrations/oracle.ts.html +1 -1
  227. package/coverage/lcov-report/src/integrations/postgres.ts.html +1 -1
  228. package/coverage/lcov-report/src/integrations/queries/index.html +1 -1
  229. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +1 -1
  230. package/coverage/lcov-report/src/integrations/redis.ts.html +1 -1
  231. package/coverage/lcov-report/src/integrations/rest.ts.html +1 -1
  232. package/coverage/lcov-report/src/integrations/s3.ts.html +1 -1
  233. package/coverage/lcov-report/src/integrations/snowflake.ts.html +1 -1
  234. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
  235. package/coverage/lcov-report/src/integrations/tests/index.html +5 -230
  236. package/coverage/lcov-report/src/integrations/utils.ts.html +3 -3
  237. package/coverage/lcov-report/src/middleware/appInfo.ts.html +1 -1
  238. package/coverage/lcov-report/src/middleware/authorized.ts.html +19 -19
  239. package/coverage/lcov-report/src/middleware/builder.ts.html +13 -13
  240. package/coverage/lcov-report/src/middleware/currentapp.ts.html +47 -47
  241. package/coverage/lcov-report/src/middleware/index.html +15 -15
  242. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +1 -1
  243. package/coverage/lcov-report/src/middleware/publicApi.ts.html +1 -1
  244. package/coverage/lcov-report/src/middleware/resourceId.ts.html +1 -1
  245. package/coverage/lcov-report/src/middleware/selfhost.ts.html +1 -1
  246. package/coverage/lcov-report/src/middleware/utils.ts.html +3 -3
  247. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +1 -1
  248. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +1 -1
  249. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +1 -1
  250. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +1 -1
  251. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +1 -1
  252. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +1 -1
  253. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +1 -1
  254. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +1 -1
  255. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +1 -1
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +1 -1
  257. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +1 -1
  258. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +1 -1
  259. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +1 -1
  260. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +1 -1
  261. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +1 -1
  262. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +1 -1
  263. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +1 -1
  264. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +1 -1
  265. package/coverage/lcov-report/src/migrations/functions/index.html +1 -1
  266. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +1 -1
  267. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +1 -1
  268. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +1 -1
  269. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +1 -1
  270. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +1 -1
  271. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +1 -1
  272. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +1 -1
  273. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +1 -1
  274. package/coverage/lcov-report/src/migrations/index.html +1 -1
  275. package/coverage/lcov-report/src/migrations/index.ts.html +1 -1
  276. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +1 -1
  277. package/coverage/lcov-report/src/migrations/tests/index.html +8 -23
  278. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +1 -1
  279. package/coverage/lcov-report/src/sdk/app/applications/index.html +1 -1
  280. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +1 -1
  281. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +18 -18
  282. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +7 -7
  283. package/coverage/lcov-report/src/sdk/app/automations/index.html +1 -1
  284. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +1 -1
  285. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +8 -8
  286. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +1 -1
  287. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +1 -1
  288. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +1 -1
  289. package/coverage/lcov-report/src/sdk/app/backups/index.html +1 -1
  290. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +1 -1
  291. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +1 -1
  292. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +15 -15
  293. package/coverage/lcov-report/src/sdk/app/datasources/index.html +1 -1
  294. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +1 -1
  295. package/coverage/lcov-report/src/sdk/app/queries/index.html +1 -1
  296. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +1 -1
  297. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +1 -1
  298. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +1 -1
  299. package/coverage/lcov-report/src/sdk/app/rows/index.html +1 -1
  300. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +1 -1
  301. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +1 -1
  302. package/coverage/lcov-report/src/sdk/app/tables/index.html +1 -1
  303. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +5 -5
  304. package/coverage/lcov-report/src/sdk/index.html +1 -1
  305. package/coverage/lcov-report/src/sdk/index.ts.html +2 -2
  306. package/coverage/lcov-report/src/sdk/users/index.html +1 -1
  307. package/coverage/lcov-report/src/sdk/users/index.ts.html +1 -1
  308. package/coverage/lcov-report/src/sdk/users/utils.ts.html +24 -24
  309. package/coverage/lcov-report/src/sdk/utils/index.html +1 -1
  310. package/coverage/lcov-report/src/sdk/utils/index.ts.html +1 -1
  311. package/coverage/lcov-report/src/startup.ts.html +4 -4
  312. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +140 -308
  313. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +6 -6
  314. package/coverage/lcov-report/src/tests/utilities/index.html +18 -18
  315. package/coverage/lcov-report/src/tests/utilities/index.ts.html +1 -1
  316. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +18 -18
  317. package/coverage/lcov-report/src/threads/automation.ts.html +1 -1
  318. package/coverage/lcov-report/src/threads/index.html +1 -1
  319. package/coverage/lcov-report/src/threads/index.ts.html +1 -1
  320. package/coverage/lcov-report/src/threads/query.ts.html +1 -1
  321. package/coverage/lcov-report/src/threads/utils.ts.html +1 -1
  322. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +2 -2
  323. package/coverage/lcov-report/src/utilities/centralPath.ts.html +1 -1
  324. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +3 -3
  325. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +1 -1
  326. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +2 -2
  327. package/coverage/lcov-report/src/utilities/fileSystem/index.html +1 -1
  328. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +1 -1
  329. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +1 -1
  330. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +1 -1
  331. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +1 -1
  332. package/coverage/lcov-report/src/utilities/global.ts.html +36 -36
  333. package/coverage/lcov-report/src/utilities/index.html +19 -34
  334. package/coverage/lcov-report/src/utilities/index.ts.html +19 -19
  335. package/coverage/lcov-report/src/utilities/redis.ts.html +1 -1
  336. package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
  337. package/coverage/lcov-report/src/utilities/routing/index.ts.html +1 -1
  338. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +1 -1
  339. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +41 -41
  340. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +2 -2
  341. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +12 -12
  342. package/coverage/lcov-report/src/utilities/schema.ts.html +1 -1
  343. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +1 -1
  344. package/coverage/lcov-report/src/utilities/security.ts.html +19 -19
  345. package/coverage/lcov-report/src/utilities/usageQuota/index.html +1 -1
  346. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +32 -32
  347. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +1 -1
  348. package/coverage/lcov-report/src/utilities/users.ts.html +1 -1
  349. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +15 -15
  350. package/coverage/lcov-report/src/watch.ts.html +1 -1
  351. package/coverage/lcov-report/src/websocket.ts.html +1 -1
  352. package/coverage/lcov.info +12860 -20071
  353. package/dist/app.js +1 -1
  354. package/dist/package.json +6 -8
  355. package/dist/tsconfig.build.tsbuildinfo +1 -1
  356. package/jest.config.ts +11 -28
  357. package/package.json +7 -9
  358. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  359. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  360. package/src/api/routes/tests/analytics.spec.js +1 -4
  361. package/src/api/routes/tests/apikeys.spec.js +1 -1
  362. package/src/api/routes/tests/application.spec.ts +6 -20
  363. package/src/api/routes/tests/auth.spec.js +2 -2
  364. package/src/api/routes/tests/automation.spec.js +1 -5
  365. package/src/api/routes/tests/backup.spec.ts +13 -4
  366. package/src/api/routes/tests/{cloud.seq.spec.ts → cloud.spec.ts} +14 -8
  367. package/src/api/routes/tests/component.spec.js +1 -1
  368. package/src/api/routes/tests/datasource.spec.ts +3 -20
  369. package/src/api/routes/tests/dev.spec.js +1 -1
  370. package/src/api/routes/tests/integration.spec.js +1 -1
  371. package/src/api/routes/tests/layout.spec.js +1 -1
  372. package/src/api/routes/tests/metadata.spec.js +1 -1
  373. package/src/api/routes/tests/misc.spec.js +1 -1
  374. package/src/api/routes/tests/permissions.spec.js +1 -4
  375. package/src/api/routes/tests/{query.seq.spec.js → query.spec.js} +1 -21
  376. package/src/api/routes/tests/role.spec.js +1 -6
  377. package/src/api/routes/tests/routing.spec.js +1 -1
  378. package/src/api/routes/tests/row.spec.js +3 -11
  379. package/src/api/routes/tests/screen.spec.js +1 -1
  380. package/src/api/routes/tests/static.spec.js +1 -2
  381. package/src/api/routes/tests/table.spec.js +1 -1
  382. package/src/api/routes/tests/templates.spec.js +1 -1
  383. package/src/api/routes/tests/user.spec.js +0 -3
  384. package/src/api/routes/tests/utilities/TestFunctions.ts +2 -25
  385. package/src/api/routes/tests/utilities/index.ts +3 -5
  386. package/src/api/routes/tests/view.spec.js +1 -4
  387. package/src/api/routes/tests/webhook.spec.js +2 -11
  388. package/src/app.ts +1 -2
  389. package/src/automations/tests/automation.spec.js +4 -4
  390. package/src/automations/tests/bash.spec.js +1 -1
  391. package/src/automations/tests/discord.spec.js +1 -1
  392. package/src/automations/tests/executeQuery.spec.js +3 -2
  393. package/src/automations/tests/executeScript.spec.js +1 -1
  394. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  395. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  396. package/src/automations/tests/serverLog.spec.js +1 -1
  397. package/src/automations/tests/updateRow.spec.js +1 -1
  398. package/src/automations/tests/zapier.spec.js +1 -1
  399. package/src/db/tests/linkController.spec.js +1 -4
  400. package/src/db/tests/linkTests.spec.js +1 -1
  401. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  402. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  403. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  404. package/src/migrations/tests/index.spec.ts +2 -3
  405. package/src/tests/jestEnv.ts +6 -2
  406. package/src/tests/jestSetup.ts +6 -5
  407. package/src/tests/utilities/TestConfiguration.ts +34 -90
  408. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/curl/curl.spec.js.html +0 -391
  409. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/curl/index.html +0 -116
  410. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi2/index.html +0 -116
  411. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi2/openapi2.spec.js.html +0 -796
  412. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi3/index.html +0 -116
  413. package/coverage/lcov-report/src/api/controllers/query/import/sources/tests/openapi3/openapi3.spec.js.html +0 -805
  414. package/coverage/lcov-report/src/api/controllers/query/import/tests/index.html +0 -116
  415. package/coverage/lcov-report/src/api/controllers/query/import/tests/index.spec.js.html +0 -568
  416. package/coverage/lcov-report/src/api/controllers/view/tests/index.html +0 -116
  417. package/coverage/lcov-report/src/api/controllers/view/tests/viewBuilder.spec.js.html +0 -277
  418. package/coverage/lcov-report/src/api/routes/public/tests/compare.spec.js.html +0 -583
  419. package/coverage/lcov-report/src/api/routes/public/tests/users.spec.js.html +0 -199
  420. package/coverage/lcov-report/src/api/routes/tests/analytics.spec.js.html +0 -271
  421. package/coverage/lcov-report/src/api/routes/tests/apikeys.spec.js.html +0 -259
  422. package/coverage/lcov-report/src/api/routes/tests/application.spec.ts.html +0 -1066
  423. package/coverage/lcov-report/src/api/routes/tests/auth.spec.js.html +0 -154
  424. package/coverage/lcov-report/src/api/routes/tests/automation.spec.js.html +0 -1123
  425. package/coverage/lcov-report/src/api/routes/tests/backup.spec.ts.html +0 -223
  426. package/coverage/lcov-report/src/api/routes/tests/cloud.seq.spec.ts.html +0 -262
  427. package/coverage/lcov-report/src/api/routes/tests/component.spec.js.html +0 -178
  428. package/coverage/lcov-report/src/api/routes/tests/datasource.spec.ts.html +0 -799
  429. package/coverage/lcov-report/src/api/routes/tests/dev.spec.js.html +0 -202
  430. package/coverage/lcov-report/src/api/routes/tests/index.html +0 -521
  431. package/coverage/lcov-report/src/api/routes/tests/integration.spec.js.html +0 -238
  432. package/coverage/lcov-report/src/api/routes/tests/internalSearch.spec.js.html +0 -670
  433. package/coverage/lcov-report/src/api/routes/tests/layout.spec.js.html +0 -259
  434. package/coverage/lcov-report/src/api/routes/tests/metadata.spec.js.html +0 -280
  435. package/coverage/lcov-report/src/api/routes/tests/misc.spec.js.html +0 -358
  436. package/coverage/lcov-report/src/api/routes/tests/permissions.spec.js.html +0 -484
  437. package/coverage/lcov-report/src/api/routes/tests/plugin.spec.ts.html +0 -622
  438. package/coverage/lcov-report/src/api/routes/tests/query.seq.spec.js.html +0 -1696
  439. package/coverage/lcov-report/src/api/routes/tests/role.spec.js.html +0 -478
  440. package/coverage/lcov-report/src/api/routes/tests/routing.spec.js.html +0 -430
  441. package/coverage/lcov-report/src/api/routes/tests/row.spec.js.html +0 -1804
  442. package/coverage/lcov-report/src/api/routes/tests/screen.spec.js.html +0 -391
  443. package/coverage/lcov-report/src/api/routes/tests/static.spec.js.html +0 -541
  444. package/coverage/lcov-report/src/api/routes/tests/table.spec.js.html +0 -991
  445. package/coverage/lcov-report/src/api/routes/tests/templates.spec.js.html +0 -154
  446. package/coverage/lcov-report/src/api/routes/tests/user.spec.js.html +0 -688
  447. package/coverage/lcov-report/src/api/routes/tests/view.spec.js.html +0 -1342
  448. package/coverage/lcov-report/src/api/routes/tests/webhook.spec.js.html +0 -484
  449. package/coverage/lcov-report/src/automations/tests/automation.spec.js.html +0 -337
  450. package/coverage/lcov-report/src/automations/tests/bash.spec.js.html +0 -187
  451. package/coverage/lcov-report/src/automations/tests/createRow.spec.ts.html +0 -223
  452. package/coverage/lcov-report/src/automations/tests/delay.spec.js.html +0 -133
  453. package/coverage/lcov-report/src/automations/tests/deleteRow.spec.ts.html +0 -250
  454. package/coverage/lcov-report/src/automations/tests/discord.spec.js.html +0 -166
  455. package/coverage/lcov-report/src/automations/tests/executeQuery.spec.js.html +0 -229
  456. package/coverage/lcov-report/src/automations/tests/executeScript.spec.js.html +0 -229
  457. package/coverage/lcov-report/src/automations/tests/filter.spec.js.html +0 -232
  458. package/coverage/lcov-report/src/automations/tests/index.html +0 -341
  459. package/coverage/lcov-report/src/automations/tests/loop.spec.ts.html +0 -220
  460. package/coverage/lcov-report/src/automations/tests/outgoingWebhook.spec.js.html +0 -202
  461. package/coverage/lcov-report/src/automations/tests/queryRows.spec.js.html +0 -436
  462. package/coverage/lcov-report/src/automations/tests/sendSmtpEmail.spec.js.html +0 -298
  463. package/coverage/lcov-report/src/automations/tests/serverLog.spec.js.html +0 -151
  464. package/coverage/lcov-report/src/automations/tests/updateRow.spec.js.html +0 -217
  465. package/coverage/lcov-report/src/automations/tests/zapier.spec.js.html +0 -166
  466. package/coverage/lcov-report/src/automations/unitTests/automationUtils.spec.ts.html +0 -280
  467. package/coverage/lcov-report/src/automations/unitTests/index.html +0 -116
  468. package/coverage/lcov-report/src/db/tests/index.html +0 -131
  469. package/coverage/lcov-report/src/db/tests/linkController.spec.js.html +0 -793
  470. package/coverage/lcov-report/src/db/tests/linkTests.spec.js.html +0 -277
  471. package/coverage/lcov-report/src/integrations/tests/airtable.spec.ts.html +0 -310
  472. package/coverage/lcov-report/src/integrations/tests/arangodb.spec.ts.html +0 -199
  473. package/coverage/lcov-report/src/integrations/tests/couchdb.spec.ts.html +0 -349
  474. package/coverage/lcov-report/src/integrations/tests/dynamodb.spec.ts.html +0 -550
  475. package/coverage/lcov-report/src/integrations/tests/elasticsearch.spec.ts.html +0 -331
  476. package/coverage/lcov-report/src/integrations/tests/firebase.spec.ts.html +0 -376
  477. package/coverage/lcov-report/src/integrations/tests/microsoftSqlServer.spec.ts.html +0 -253
  478. package/coverage/lcov-report/src/integrations/tests/mongo.spec.ts.html +0 -1087
  479. package/coverage/lcov-report/src/integrations/tests/mysql.spec.ts.html +0 -484
  480. package/coverage/lcov-report/src/integrations/tests/oracle.spec.ts.html +0 -373
  481. package/coverage/lcov-report/src/integrations/tests/postgres.spec.ts.html +0 -328
  482. package/coverage/lcov-report/src/integrations/tests/redis.spec.ts.html +0 -337
  483. package/coverage/lcov-report/src/integrations/tests/rest.spec.ts.html +0 -1870
  484. package/coverage/lcov-report/src/integrations/tests/s3.spec.ts.html +0 -421
  485. package/coverage/lcov-report/src/integrations/tests/sql.spec.ts.html +0 -1753
  486. package/coverage/lcov-report/src/middleware/tests/authorized.spec.js.html +0 -574
  487. package/coverage/lcov-report/src/middleware/tests/currentapp.spec.js.html +0 -814
  488. package/coverage/lcov-report/src/middleware/tests/index.html +0 -161
  489. package/coverage/lcov-report/src/middleware/tests/resourceId.spec.js.html +0 -397
  490. package/coverage/lcov-report/src/middleware/tests/selfhost.spec.js.html +0 -214
  491. package/coverage/lcov-report/src/migrations/functions/tests/appUrls.spec.js.html +0 -163
  492. package/coverage/lcov-report/src/migrations/functions/tests/index.html +0 -161
  493. package/coverage/lcov-report/src/migrations/functions/tests/syncQuotas.spec.js.html +0 -163
  494. package/coverage/lcov-report/src/migrations/functions/tests/tableSettings.spec.ts.html +0 -517
  495. package/coverage/lcov-report/src/migrations/functions/tests/userEmailViewCasing.spec.js.html +0 -190
  496. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/index.html +0 -131
  497. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/syncApps.spec.ts.html +0 -190
  498. package/coverage/lcov-report/src/migrations/functions/usageQuotas/tests/syncRows.spec.ts.html +0 -244
  499. package/coverage/lcov-report/src/migrations/tests/index.spec.ts.html +0 -535
  500. package/coverage/lcov-report/src/sdk/tests/attachments.spec.ts.html +0 -313
  501. package/coverage/lcov-report/src/sdk/tests/index.html +0 -116
  502. package/coverage/lcov-report/src/utilities/retry.ts.html +0 -139
  503. package/coverage/lcov-report/src/utilities/rowProcessor/tests/index.html +0 -116
  504. package/coverage/lcov-report/src/utilities/rowProcessor/tests/utils.spec.ts.html +0 -256
  505. package/dist/utilities/retry.js +0 -30
  506. package/jest-testcontainers-config.js +0 -8
  507. package/src/utilities/retry.ts +0 -18
@@ -4,8 +4,6 @@ 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"
9
7
 
10
8
  class Request {
11
9
  appId: any
@@ -32,10 +30,7 @@ export const getAllTableRows = async (config: any) => {
32
30
  return req.body
33
31
  }
34
32
 
35
- export const clearAllApps = async (
36
- tenantId = TENANT_ID,
37
- exceptions: Array<string> = []
38
- ) => {
33
+ export const clearAllApps = async (tenantId = TENANT_ID) => {
39
34
  await tenancy.doInTenant(tenantId, async () => {
40
35
  const req: any = { query: { status: AppStatus.DEV }, user: { tenantId } }
41
36
  await appController.fetch(req)
@@ -43,7 +38,7 @@ export const clearAllApps = async (
43
38
  if (!apps || apps.length <= 0) {
44
39
  return
45
40
  }
46
- for (let app of apps.filter((x: any) => !exceptions.includes(x.appId))) {
41
+ for (let app of apps) {
47
42
  const { appId } = app
48
43
  const req = new Request(null, { appId })
49
44
  await runRequest(appId, appController.destroy, req)
@@ -60,24 +55,6 @@ export const clearAllAutomations = async (config: any) => {
60
55
  }
61
56
  }
62
57
 
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
-
81
58
  export const createRequest = (
82
59
  request: any,
83
60
  method: any,
@@ -1,6 +1,5 @@
1
1
  import TestConfig from "../../../../tests/utilities/TestConfiguration"
2
2
  import env from "../../../../environment"
3
- import supertest from "supertest"
4
3
  export * as structures from "../../../../tests/utilities/structures"
5
4
 
6
5
  function user() {
@@ -45,8 +44,7 @@ export function delay(ms: number) {
45
44
  return new Promise(resolve => setTimeout(resolve, ms))
46
45
  }
47
46
 
48
- let request: supertest.SuperTest<supertest.Test> | undefined | null,
49
- config: TestConfig | null
47
+ let request: any, config: any
50
48
 
51
49
  export function beforeAll() {
52
50
  config = new TestConfig()
@@ -67,14 +65,14 @@ export function getRequest() {
67
65
  if (!request) {
68
66
  beforeAll()
69
67
  }
70
- return request!
68
+ return request
71
69
  }
72
70
 
73
71
  export function getConfig() {
74
72
  if (!config) {
75
73
  beforeAll()
76
74
  }
77
- return config!
75
+ return config
78
76
  }
79
77
 
80
78
  export async function switchToSelfHosted(func: any) {
@@ -28,11 +28,8 @@ describe("/views", () => {
28
28
 
29
29
  afterAll(setup.afterAll)
30
30
 
31
- beforeAll(async () => {
31
+ beforeEach(async () => {
32
32
  await config.init()
33
- })
34
-
35
- beforeEach(async() => {
36
33
  table = await config.createTable(priceTable())
37
34
  })
38
35
 
@@ -9,8 +9,7 @@ describe("/webhooks", () => {
9
9
 
10
10
  afterAll(setup.afterAll)
11
11
 
12
- const setupTest = async () => {
13
- config.modeSelf()
12
+ beforeEach(async () => {
14
13
  await config.init()
15
14
  const autoConfig = basicAutomation()
16
15
  autoConfig.definition.trigger = {
@@ -19,9 +18,7 @@ describe("/webhooks", () => {
19
18
  }
20
19
  await config.createAutomation(autoConfig)
21
20
  webhook = await config.createWebhook()
22
- }
23
-
24
- beforeAll(setupTest)
21
+ })
25
22
 
26
23
  describe("create", () => {
27
24
  it("should create a webhook successfully", async () => {
@@ -47,8 +44,6 @@ describe("/webhooks", () => {
47
44
  })
48
45
 
49
46
  describe("fetch", () => {
50
- beforeAll(setupTest)
51
-
52
47
  it("returns the correct routing for basic user", async () => {
53
48
  const res = await request
54
49
  .get(`/api/webhooks`)
@@ -69,8 +64,6 @@ describe("/webhooks", () => {
69
64
  })
70
65
 
71
66
  describe("delete", () => {
72
- beforeAll(setupTest)
73
-
74
67
  it("should successfully delete", async () => {
75
68
  const res = await request
76
69
  .delete(`/api/webhooks/${webhook._id}/${webhook._rev}`)
@@ -91,8 +84,6 @@ describe("/webhooks", () => {
91
84
  })
92
85
 
93
86
  describe("build schema", () => {
94
- beforeAll(setupTest)
95
-
96
87
  it("should allow building a schema", async () => {
97
88
  const res = await request
98
89
  .post(`/api/webhooks/schema/${config.getAppId()}/${webhook._id}`)
package/src/app.ts CHANGED
@@ -62,7 +62,6 @@ initialiseWebsockets(server)
62
62
 
63
63
  let shuttingDown = false,
64
64
  errCode = 0
65
-
66
65
  server.on("close", async () => {
67
66
  // already in process
68
67
  if (shuttingDown) {
@@ -72,7 +71,7 @@ server.on("close", async () => {
72
71
  console.log("Server Closed")
73
72
  await automations.shutdown()
74
73
  await redis.shutdown()
75
- events.shutdown()
74
+ await events.shutdown()
76
75
  await Thread.shutdown()
77
76
  api.shutdown()
78
77
  if (!env.isTest()) {
@@ -21,7 +21,7 @@ const setup = require("./utilities")
21
21
  describe("Run through some parts of the automations system", () => {
22
22
  let config = setup.getConfig()
23
23
 
24
- beforeAll(async () => {
24
+ beforeEach(async () => {
25
25
  await automation.init()
26
26
  await config.init()
27
27
  })
@@ -29,9 +29,9 @@ describe("Run through some parts of the automations system", () => {
29
29
  afterAll(setup.afterAll)
30
30
 
31
31
  it("should be able to init in builder", async () => {
32
- await triggers.externalTrigger(basicAutomation(), { a: 1, appId: config.appId })
33
- await wait(100)
34
- expect(thread.execute).toHaveBeenCalled()
32
+ await triggers.externalTrigger(basicAutomation(), { a: 1, appId: "app_123" })
33
+ await wait(100)
34
+ expect(thread.execute).toHaveBeenCalled()
35
35
  })
36
36
 
37
37
  it("should check coercion", async () => {
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the bash action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeAll(async () => {
6
+ beforeEach(async () => {
7
7
  await config.init()
8
8
  })
9
9
  afterAll(setup.afterAll)
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  username: "joe_bloggs",
@@ -1,9 +1,10 @@
1
1
  const setup = require("./utilities")
2
2
 
3
3
  describe("test the execute query action", () => {
4
+ let datasource
4
5
  let config = setup.getConfig()
5
6
 
6
- beforeAll(async () => {
7
+ beforeEach(async () => {
7
8
  await config.init()
8
9
 
9
10
  await config.createDatasource()
@@ -40,7 +41,7 @@ describe("test the execute query action", () => {
40
41
  query: { queryId: "wrong_id" }
41
42
  }
42
43
  )
43
- expect(res.response).toEqual('Error: missing')
44
+ expect(res.response).toEqual('{"status":404,"name":"not_found","message":"missing","reason":"missing"}')
44
45
  expect(res.success).toEqual(false)
45
46
  })
46
47
 
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the execute script action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeAll(async () => {
6
+ beforeEach(async () => {
7
7
  await config.init()
8
8
  })
9
9
  afterAll(setup.afterAll)
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  requestMethod: "POST",
@@ -36,7 +36,7 @@ const setup = require("./utilities")
36
36
  describe("test the outgoing webhook action", () => {
37
37
  let inputs
38
38
  let config = setup.getConfig()
39
- beforeAll(async () => {
39
+ beforeEach(async () => {
40
40
  await config.init()
41
41
  })
42
42
 
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the server log action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeAll(async () => {
6
+ beforeEach(async () => {
7
7
  await config.init()
8
8
  inputs = {
9
9
  text: "log message",
@@ -4,7 +4,7 @@ describe("test the update row action", () => {
4
4
  let table, row, inputs
5
5
  let config = setup.getConfig()
6
6
 
7
- beforeAll(async () => {
7
+ beforeEach(async () => {
8
8
  await config.init()
9
9
  table = await config.createTable()
10
10
  row = await config.createRow()
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  value1: "test",
@@ -9,12 +9,9 @@ describe("test the link controller", () => {
9
9
  let config = new TestConfig(false)
10
10
  let table1, table2, appId
11
11
 
12
- beforeAll(async () => {
12
+ beforeEach(async () => {
13
13
  const app = await config.init()
14
14
  appId = app.appId
15
- })
16
-
17
- beforeEach(async () => {
18
15
  const { _id } = await config.createTable()
19
16
  table2 = await config.createLinkedTable(RelationshipTypes.MANY_TO_MANY, ["link", "link2"])
20
17
  // update table after creating link
@@ -9,7 +9,7 @@ describe("test link functionality", () => {
9
9
 
10
10
  describe("getLinkedTable", () => {
11
11
  let table
12
- beforeAll(async () => {
12
+ beforeEach(async () => {
13
13
  const app = await config.init()
14
14
  appId = app.appId
15
15
  table = await config.createTable()
@@ -6,7 +6,7 @@ const migration = require("../appUrls")
6
6
  describe("run", () => {
7
7
  let config = new TestConfig(false)
8
8
 
9
- beforeAll(async () => {
9
+ beforeEach(async () => {
10
10
  await config.init()
11
11
  })
12
12
 
@@ -11,7 +11,7 @@ const migration = require("../syncQuotas")
11
11
  describe("run", () => {
12
12
  let config = new TestConfig(false)
13
13
 
14
- beforeAll(async () => {
14
+ beforeEach(async () => {
15
15
  await config.init()
16
16
  })
17
17
 
@@ -19,7 +19,7 @@ const migration = require("../userEmailViewCasing")
19
19
  describe("run", () => {
20
20
  let config = new TestConfig(false)
21
21
 
22
- beforeAll(async () => {
22
+ beforeEach(async () => {
23
23
  await config.init()
24
24
  })
25
25
 
@@ -10,9 +10,8 @@ import * as structures from "../../tests/utilities/structures"
10
10
  import { MIGRATIONS } from "../"
11
11
  import * as helpers from "./helpers"
12
12
 
13
- import tk from "timekeeper"
14
- const timestamp = new Date().toISOString()
15
- tk.freeze(timestamp)
13
+ const { mocks } = require("@budibase/backend-core/tests")
14
+ const timestamp = mocks.date.MOCK_DATE.toISOString()
16
15
 
17
16
  const clearMigrations = async () => {
18
17
  const dbs = [context.getDevAppDB(), context.getProdAppDB()]
@@ -3,7 +3,11 @@ import { tmpdir } from "os"
3
3
 
4
4
  env._set("SELF_HOSTED", "1")
5
5
  env._set("NODE_ENV", "jest")
6
- env._set("MULTI_TENANCY", "1")
7
- // @ts-ignore
6
+ env._set("JWT_SECRET", "test-jwtsecret")
7
+ env._set("CLIENT_ID", "test-client-id")
8
8
  env._set("BUDIBASE_DIR", tmpdir("budibase-unittests"))
9
9
  env._set("LOG_LEVEL", "silent")
10
+ env._set("PORT", 0)
11
+ env._set("MINIO_URL", "http://localhost")
12
+ env._set("MINIO_ACCESS_KEY", "test")
13
+ env._set("MINIO_SECRET_KEY", "test")
@@ -1,6 +1,9 @@
1
- import env from "../environment"
2
- import { env as coreEnv } from "@budibase/backend-core"
3
- import { testContainerUtils } from "@budibase/backend-core/tests"
1
+ import { mocks } from "@budibase/backend-core/tests"
2
+
3
+ // mock all dates to 2020-01-01T00:00:00.000Z
4
+ // use tk.reset() to use real dates in individual tests
5
+ const tk = require("timekeeper")
6
+ tk.freeze(mocks.date.MOCK_DATE)
4
7
 
5
8
  if (!process.env.DEBUG) {
6
9
  global.console.log = jest.fn() // console.log are ignored in tests
@@ -12,5 +15,3 @@ if (!process.env.CI) {
12
15
  // 100 seconds
13
16
  jest.setTimeout(100000)
14
17
  }
15
-
16
- testContainerUtils.setupEnv(env, coreEnv)
@@ -1,4 +1,4 @@
1
- import { generator, mocks, structures } from "@budibase/backend-core/tests"
1
+ import { mocks } from "@budibase/backend-core/tests"
2
2
 
3
3
  // init the licensing mock
4
4
  import * as pro from "@budibase/pro"
@@ -10,7 +10,6 @@ mocks.licenses.useUnlimited()
10
10
  import { init as dbInit } from "../../db"
11
11
  dbInit()
12
12
  import env from "../../environment"
13
- import { env as coreEnv } from "@budibase/backend-core"
14
13
  import {
15
14
  basicTable,
16
15
  basicRow,
@@ -39,16 +38,13 @@ import { cleanup } from "../../utilities/fileSystem"
39
38
  import newid from "../../db/newid"
40
39
  import { generateUserMetadataID } from "../../db/utils"
41
40
  import { startup } from "../../startup"
42
- import { AuthToken, Database } from "@budibase/types"
43
41
  const supertest = require("supertest")
44
42
 
45
- type DefaultUserValues = {
46
- globalUserId: string
47
- email: string
48
- firstName: string
49
- lastName: string
50
- csrfToken: string
51
- }
43
+ const GLOBAL_USER_ID = "us_uuid1"
44
+ const EMAIL = "babs@babs.com"
45
+ const FIRSTNAME = "Barbara"
46
+ const LASTNAME = "Barbington"
47
+ const CSRF_TOKEN = "e3727778-7af0-4226-b5eb-f43cbe60a306"
52
48
 
53
49
  class TestConfiguration {
54
50
  server: any
@@ -66,8 +62,6 @@ class TestConfiguration {
66
62
  linkedTable: any
67
63
  automation: any
68
64
  datasource: any
69
- tenantId: string | null
70
- defaultUserValues: DefaultUserValues
71
65
 
72
66
  constructor(openServer = true) {
73
67
  if (openServer) {
@@ -82,18 +76,6 @@ class TestConfiguration {
82
76
  }
83
77
  this.appId = null
84
78
  this.allApps = []
85
- this.tenantId = null
86
- this.defaultUserValues = this.populateDefaultUserValues()
87
- }
88
-
89
- populateDefaultUserValues(): DefaultUserValues {
90
- return {
91
- globalUserId: `us_${newid()}`,
92
- email: generator.email(),
93
- firstName: generator.first(),
94
- lastName: generator.last(),
95
- csrfToken: generator.hash(),
96
- }
97
79
  }
98
80
 
99
81
  getRequest() {
@@ -118,10 +100,10 @@ class TestConfiguration {
118
100
 
119
101
  getUserDetails() {
120
102
  return {
121
- globalId: this.defaultUserValues.globalUserId,
122
- email: this.defaultUserValues.email,
123
- firstName: this.defaultUserValues.firstName,
124
- lastName: this.defaultUserValues.lastName,
103
+ globalId: GLOBAL_USER_ID,
104
+ email: EMAIL,
105
+ firstName: FIRSTNAME,
106
+ lastName: LASTNAME,
125
107
  }
126
108
  }
127
109
 
@@ -129,9 +111,7 @@ class TestConfiguration {
129
111
  if (!appId) {
130
112
  appId = this.appId
131
113
  }
132
-
133
- const tenant = this.getTenantId()
134
- return tenancy.doInTenant(tenant, () => {
114
+ return tenancy.doInTenant(TENANT_ID, () => {
135
115
  // check if already in a context
136
116
  if (context.getAppId() == null && appId !== null) {
137
117
  return context.doInAppContext(appId, async () => {
@@ -147,11 +127,6 @@ class TestConfiguration {
147
127
 
148
128
  // use a new id as the name to avoid name collisions
149
129
  async init(appName = newid()) {
150
- this.defaultUserValues = this.populateDefaultUserValues()
151
- if (context.isMultiTenant()) {
152
- this.tenantId = structures.tenant.id()
153
- }
154
-
155
130
  if (!this.started) {
156
131
  await startup()
157
132
  }
@@ -174,27 +149,6 @@ class TestConfiguration {
174
149
  }
175
150
  }
176
151
 
177
- // MODES
178
- #setMultiTenancy = (value: boolean) => {
179
- env._set("MULTI_TENANCY", value)
180
- coreEnv._set("MULTI_TENANCY", value)
181
- }
182
-
183
- #setSelfHosted = (value: boolean) => {
184
- env._set("SELF_HOSTED", value)
185
- coreEnv._set("SELF_HOSTED", value)
186
- }
187
-
188
- modeCloud = () => {
189
- this.#setSelfHosted(false)
190
- this.#setMultiTenancy(true)
191
- }
192
-
193
- modeSelf = () => {
194
- this.#setSelfHosted(true)
195
- this.#setMultiTenancy(false)
196
- }
197
-
198
152
  // UTILS
199
153
 
200
154
  async _req(body: any, params: any, controlFunc: any) {
@@ -205,7 +159,7 @@ class TestConfiguration {
205
159
  // fake cookies, we don't need them
206
160
  request.cookies = { set: () => {}, get: () => {} }
207
161
  request.config = { jwtSecret: env.JWT_SECRET }
208
- request.user = { appId, tenantId: this.getTenantId() }
162
+ request.user = { appId, tenantId: TENANT_ID }
209
163
  request.query = {}
210
164
  request.request = {
211
165
  body,
@@ -221,15 +175,15 @@ class TestConfiguration {
221
175
 
222
176
  // USER / AUTH
223
177
  async globalUser({
224
- id = this.defaultUserValues.globalUserId,
225
- firstName = this.defaultUserValues.firstName,
226
- lastName = this.defaultUserValues.lastName,
178
+ id = GLOBAL_USER_ID,
179
+ firstName = FIRSTNAME,
180
+ lastName = LASTNAME,
227
181
  builder = true,
228
182
  admin = false,
229
- email = this.defaultUserValues.email,
183
+ email = EMAIL,
230
184
  roles,
231
185
  }: any = {}) {
232
- return tenancy.doWithGlobalDB(this.getTenantId(), async (db: Database) => {
186
+ return tenancy.doWithGlobalDB(TENANT_ID, async (db: any) => {
233
187
  let existing
234
188
  try {
235
189
  existing = await db.get(id)
@@ -240,14 +194,14 @@ class TestConfiguration {
240
194
  _id: id,
241
195
  ...existing,
242
196
  roles: roles || {},
243
- tenantId: this.getTenantId(),
197
+ tenantId: TENANT_ID,
244
198
  firstName,
245
199
  lastName,
246
200
  }
247
201
  await sessions.createASession(id, {
248
202
  sessionId: "sessionid",
249
- tenantId: this.getTenantId(),
250
- csrfToken: this.defaultUserValues.csrfToken,
203
+ tenantId: TENANT_ID,
204
+ csrfToken: CSRF_TOKEN,
251
205
  })
252
206
  if (builder) {
253
207
  user.builder = { global: true }
@@ -261,7 +215,7 @@ class TestConfiguration {
261
215
  }
262
216
  const resp = await db.put(user)
263
217
  return {
264
- _rev: resp.rev,
218
+ _rev: resp._rev,
265
219
  ...user,
266
220
  }
267
221
  })
@@ -269,9 +223,9 @@ class TestConfiguration {
269
223
 
270
224
  async createUser(
271
225
  id = null,
272
- firstName = this.defaultUserValues.firstName,
273
- lastName = this.defaultUserValues.lastName,
274
- email = this.defaultUserValues.email,
226
+ firstName = FIRSTNAME,
227
+ lastName = LASTNAME,
228
+ email = EMAIL,
275
229
  builder = true,
276
230
  admin = false,
277
231
  roles = {}
@@ -310,13 +264,13 @@ class TestConfiguration {
310
264
  }
311
265
  await sessions.createASession(userId, {
312
266
  sessionId: "sessionid",
313
- tenantId: this.getTenantId(),
267
+ tenantId: TENANT_ID,
314
268
  })
315
269
  // have to fake this
316
270
  const authObj = {
317
271
  userId,
318
272
  sessionId: "sessionid",
319
- tenantId: this.getTenantId(),
273
+ tenantId: TENANT_ID,
320
274
  }
321
275
  const app = {
322
276
  roleId: roleId,
@@ -339,11 +293,10 @@ class TestConfiguration {
339
293
  }
340
294
 
341
295
  defaultHeaders(extras = {}) {
342
- const tenantId = this.getTenantId()
343
- const authObj: AuthToken = {
344
- userId: this.defaultUserValues.globalUserId,
296
+ const authObj = {
297
+ userId: GLOBAL_USER_ID,
345
298
  sessionId: "sessionid",
346
- tenantId,
299
+ tenantId: TENANT_ID,
347
300
  }
348
301
  const app = {
349
302
  roleId: roles.BUILTIN_ROLE_IDS.ADMIN,
@@ -357,7 +310,7 @@ class TestConfiguration {
357
310
  `${constants.Cookie.Auth}=${authToken}`,
358
311
  `${constants.Cookie.CurrentApp}=${appToken}`,
359
312
  ],
360
- [constants.Header.CSRF_TOKEN]: this.defaultUserValues.csrfToken,
313
+ [constants.Header.CSRF_TOKEN]: CSRF_TOKEN,
361
314
  ...extras,
362
315
  }
363
316
  if (this.appId) {
@@ -366,10 +319,6 @@ class TestConfiguration {
366
319
  return headers
367
320
  }
368
321
 
369
- getTenantId() {
370
- return this.tenantId || TENANT_ID
371
- }
372
-
373
322
  publicHeaders({ prodApp = true } = {}) {
374
323
  const appId = prodApp ? this.prodAppId : this.appId
375
324
 
@@ -379,16 +328,11 @@ class TestConfiguration {
379
328
  if (appId) {
380
329
  headers[constants.Header.APP_ID] = appId
381
330
  }
382
-
383
- if (this.tenantId) {
384
- headers[constants.Header.TENANT_ID] = this.tenantId
385
- }
386
-
387
331
  return headers
388
332
  }
389
333
 
390
334
  async roleHeaders({
391
- email = this.defaultUserValues.email,
335
+ email = EMAIL,
392
336
  roleId = roles.BUILTIN_ROLE_IDS.ADMIN,
393
337
  builder = false,
394
338
  prodApp = true,
@@ -398,8 +342,8 @@ class TestConfiguration {
398
342
 
399
343
  // API
400
344
 
401
- async generateApiKey(userId = this.defaultUserValues.globalUserId) {
402
- return tenancy.doWithGlobalDB(this.getTenantId(), async (db: any) => {
345
+ async generateApiKey(userId = GLOBAL_USER_ID) {
346
+ return tenancy.doWithGlobalDB(TENANT_ID, async (db: any) => {
403
347
  const id = dbCore.generateDevInfoID(userId)
404
348
  let devInfo
405
349
  try {
@@ -408,7 +352,7 @@ class TestConfiguration {
408
352
  devInfo = { _id: id, userId }
409
353
  }
410
354
  devInfo.apiKey = encryption.encrypt(
411
- `${this.getTenantId()}${dbCore.SEPARATOR}${newid()}`
355
+ `${TENANT_ID}${dbCore.SEPARATOR}${newid()}`
412
356
  )
413
357
  await db.put(devInfo)
414
358
  return devInfo.apiKey