@budibase/server 2.3.18-alpha.8 → 2.3.18

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 (477) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/index.4488f38d.css +6 -0
  3. package/builder/assets/{index.da67cdc2.js → index.527a5fcb.js} +415 -422
  4. package/builder/index.html +2 -2
  5. package/coverage/clover.xml +11774 -0
  6. package/coverage/coverage-final.json +284 -0
  7. package/coverage/lcov-report/base.css +224 -0
  8. package/coverage/lcov-report/block-navigation.js +87 -0
  9. package/coverage/lcov-report/favicon.png +0 -0
  10. package/coverage/lcov-report/index.html +1031 -0
  11. package/coverage/lcov-report/prettify.css +1 -0
  12. package/coverage/lcov-report/prettify.js +2 -0
  13. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  14. package/coverage/lcov-report/sorter.js +196 -0
  15. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +190 -0
  16. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +247 -0
  17. package/coverage/lcov-report/src/api/controllers/application.ts.html +1987 -0
  18. package/coverage/lcov-report/src/api/controllers/auth.ts.html +301 -0
  19. package/coverage/lcov-report/src/api/controllers/automation.ts.html +940 -0
  20. package/coverage/lcov-report/src/api/controllers/backup.ts.html +148 -0
  21. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +442 -0
  22. package/coverage/lcov-report/src/api/controllers/component.ts.html +259 -0
  23. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +1135 -0
  24. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +262 -0
  25. package/coverage/lcov-report/src/api/controllers/deploy/index.html +131 -0
  26. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +694 -0
  27. package/coverage/lcov-report/src/api/controllers/dev.ts.html +472 -0
  28. package/coverage/lcov-report/src/api/controllers/index.html +431 -0
  29. package/coverage/lcov-report/src/api/controllers/integration.ts.html +124 -0
  30. package/coverage/lcov-report/src/api/controllers/layout.ts.html +226 -0
  31. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +211 -0
  32. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +127 -0
  33. package/coverage/lcov-report/src/api/controllers/permission.ts.html +619 -0
  34. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +130 -0
  35. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +310 -0
  36. package/coverage/lcov-report/src/api/controllers/plugin/index.html +206 -0
  37. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +499 -0
  38. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +253 -0
  39. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +97 -0
  40. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +121 -0
  41. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +136 -0
  42. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +385 -0
  43. package/coverage/lcov-report/src/api/controllers/public/index.html +191 -0
  44. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +181 -0
  45. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +191 -0
  46. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +124 -0
  47. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +202 -0
  48. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +178 -0
  49. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +163 -0
  50. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +181 -0
  51. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +145 -0
  52. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +328 -0
  53. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +253 -0
  54. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +325 -0
  55. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +220 -0
  56. package/coverage/lcov-report/src/api/controllers/query/import/index.html +116 -0
  57. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +373 -0
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +131 -0
  59. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +379 -0
  60. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +157 -0
  61. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +403 -0
  62. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +146 -0
  63. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +586 -0
  64. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +712 -0
  65. package/coverage/lcov-report/src/api/controllers/query/index.html +131 -0
  66. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +1000 -0
  67. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +235 -0
  68. package/coverage/lcov-report/src/api/controllers/role.ts.html +397 -0
  69. package/coverage/lcov-report/src/api/controllers/routing.ts.html +370 -0
  70. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +2305 -0
  71. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +931 -0
  72. package/coverage/lcov-report/src/api/controllers/row/index.html +206 -0
  73. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +541 -0
  74. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +1609 -0
  75. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +1678 -0
  76. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +595 -0
  77. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +556 -0
  78. package/coverage/lcov-report/src/api/controllers/screen.ts.html +463 -0
  79. package/coverage/lcov-report/src/api/controllers/script.ts.html +121 -0
  80. package/coverage/lcov-report/src/api/controllers/static/index.html +116 -0
  81. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +679 -0
  82. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +649 -0
  83. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +1153 -0
  84. package/coverage/lcov-report/src/api/controllers/table/index.html +176 -0
  85. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +514 -0
  86. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +658 -0
  87. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +1273 -0
  88. package/coverage/lcov-report/src/api/controllers/templates.ts.html +214 -0
  89. package/coverage/lcov-report/src/api/controllers/user.ts.html +634 -0
  90. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +214 -0
  91. package/coverage/lcov-report/src/api/controllers/view/index.html +161 -0
  92. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +661 -0
  93. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +580 -0
  94. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +694 -0
  95. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +385 -0
  96. package/coverage/lcov-report/src/api/index.html +116 -0
  97. package/coverage/lcov-report/src/api/index.ts.html +352 -0
  98. package/coverage/lcov-report/src/api/routes/analytics.ts.html +112 -0
  99. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +121 -0
  100. package/coverage/lcov-report/src/api/routes/application.ts.html +256 -0
  101. package/coverage/lcov-report/src/api/routes/auth.ts.html +109 -0
  102. package/coverage/lcov-report/src/api/routes/automation.ts.html +346 -0
  103. package/coverage/lcov-report/src/api/routes/backup.ts.html +127 -0
  104. package/coverage/lcov-report/src/api/routes/cloud.ts.html +139 -0
  105. package/coverage/lcov-report/src/api/routes/component.ts.html +127 -0
  106. package/coverage/lcov-report/src/api/routes/datasource.ts.html +265 -0
  107. package/coverage/lcov-report/src/api/routes/deploy.ts.html +145 -0
  108. package/coverage/lcov-report/src/api/routes/dev.ts.html +199 -0
  109. package/coverage/lcov-report/src/api/routes/index.html +551 -0
  110. package/coverage/lcov-report/src/api/routes/index.ts.html +298 -0
  111. package/coverage/lcov-report/src/api/routes/integration.ts.html +133 -0
  112. package/coverage/lcov-report/src/api/routes/layout.ts.html +133 -0
  113. package/coverage/lcov-report/src/api/routes/metadata.ts.html +199 -0
  114. package/coverage/lcov-report/src/api/routes/migrations.ts.html +127 -0
  115. package/coverage/lcov-report/src/api/routes/permission.ts.html +208 -0
  116. package/coverage/lcov-report/src/api/routes/plugin.ts.html +151 -0
  117. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +673 -0
  118. package/coverage/lcov-report/src/api/routes/public/index.html +191 -0
  119. package/coverage/lcov-report/src/api/routes/public/index.ts.html +493 -0
  120. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +116 -0
  121. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +340 -0
  122. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +313 -0
  123. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +598 -0
  124. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +586 -0
  125. package/coverage/lcov-report/src/api/routes/public/tests/index.html +116 -0
  126. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +169 -0
  127. package/coverage/lcov-report/src/api/routes/public/users.ts.html +511 -0
  128. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +238 -0
  129. package/coverage/lcov-report/src/api/routes/public/utils/index.html +116 -0
  130. package/coverage/lcov-report/src/api/routes/query.ts.html +268 -0
  131. package/coverage/lcov-report/src/api/routes/role.ts.html +157 -0
  132. package/coverage/lcov-report/src/api/routes/routing.ts.html +127 -0
  133. package/coverage/lcov-report/src/api/routes/row.ts.html +883 -0
  134. package/coverage/lcov-report/src/api/routes/screen.ts.html +154 -0
  135. package/coverage/lcov-report/src/api/routes/script.ts.html +115 -0
  136. package/coverage/lcov-report/src/api/routes/static.ts.html +280 -0
  137. package/coverage/lcov-report/src/api/routes/table.ts.html +595 -0
  138. package/coverage/lcov-report/src/api/routes/templates.ts.html +133 -0
  139. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +550 -0
  140. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +131 -0
  141. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +367 -0
  142. package/coverage/lcov-report/src/api/routes/user.ts.html +238 -0
  143. package/coverage/lcov-report/src/api/routes/utils/index.html +116 -0
  144. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +805 -0
  145. package/coverage/lcov-report/src/api/routes/view.ts.html +187 -0
  146. package/coverage/lcov-report/src/api/routes/webhook.ts.html +166 -0
  147. package/coverage/lcov-report/src/app.ts.html +424 -0
  148. package/coverage/lcov-report/src/automations/actions.ts.html +316 -0
  149. package/coverage/lcov-report/src/automations/automationUtils.ts.html +562 -0
  150. package/coverage/lcov-report/src/automations/bullboard.ts.html +199 -0
  151. package/coverage/lcov-report/src/automations/index.html +191 -0
  152. package/coverage/lcov-report/src/automations/index.ts.html +163 -0
  153. package/coverage/lcov-report/src/automations/logging/index.html +116 -0
  154. package/coverage/lcov-report/src/automations/logging/index.ts.html +199 -0
  155. package/coverage/lcov-report/src/automations/steps/bash.ts.html +319 -0
  156. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +382 -0
  157. package/coverage/lcov-report/src/automations/steps/delay.ts.html +217 -0
  158. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +349 -0
  159. package/coverage/lcov-report/src/automations/steps/discord.ts.html +397 -0
  160. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +370 -0
  161. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +325 -0
  162. package/coverage/lcov-report/src/automations/steps/filter.ts.html +394 -0
  163. package/coverage/lcov-report/src/automations/steps/index.html +371 -0
  164. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +409 -0
  165. package/coverage/lcov-report/src/automations/steps/loop.ts.html +241 -0
  166. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +499 -0
  167. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +664 -0
  168. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +355 -0
  169. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +256 -0
  170. package/coverage/lcov-report/src/automations/steps/slack.ts.html +340 -0
  171. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +439 -0
  172. package/coverage/lcov-report/src/automations/steps/utils.ts.html +223 -0
  173. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +403 -0
  174. package/coverage/lcov-report/src/automations/tests/utilities/index.html +116 -0
  175. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +265 -0
  176. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +196 -0
  177. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +193 -0
  178. package/coverage/lcov-report/src/automations/triggerInfo/index.html +206 -0
  179. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +130 -0
  180. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +196 -0
  181. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +220 -0
  182. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +220 -0
  183. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +208 -0
  184. package/coverage/lcov-report/src/automations/triggers.ts.html +553 -0
  185. package/coverage/lcov-report/src/automations/utils.ts.html +886 -0
  186. package/coverage/lcov-report/src/constants/index.html +146 -0
  187. package/coverage/lcov-report/src/constants/index.ts.html +697 -0
  188. package/coverage/lcov-report/src/constants/layouts.ts.html +526 -0
  189. package/coverage/lcov-report/src/constants/screens.ts.html +229 -0
  190. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +2059 -0
  191. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +541 -0
  192. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +427 -0
  193. package/coverage/lcov-report/src/db/defaultData/index.html +176 -0
  194. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +403 -0
  195. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +559 -0
  196. package/coverage/lcov-report/src/db/dynamoClient.ts.html +526 -0
  197. package/coverage/lcov-report/src/db/inMemoryView.ts.html +250 -0
  198. package/coverage/lcov-report/src/db/index.html +176 -0
  199. package/coverage/lcov-report/src/db/index.ts.html +133 -0
  200. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +1417 -0
  201. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +265 -0
  202. package/coverage/lcov-report/src/db/linkedRows/index.html +161 -0
  203. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +736 -0
  204. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +460 -0
  205. package/coverage/lcov-report/src/db/newid.ts.html +100 -0
  206. package/coverage/lcov-report/src/db/utils.ts.html +913 -0
  207. package/coverage/lcov-report/src/definitions/automations.ts.html +184 -0
  208. package/coverage/lcov-report/src/definitions/index.html +116 -0
  209. package/coverage/lcov-report/src/environment.ts.html +472 -0
  210. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +259 -0
  211. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +172 -0
  212. package/coverage/lcov-report/src/events/index.html +161 -0
  213. package/coverage/lcov-report/src/events/index.ts.html +100 -0
  214. package/coverage/lcov-report/src/events/utils.ts.html +319 -0
  215. package/coverage/lcov-report/src/index.html +191 -0
  216. package/coverage/lcov-report/src/index.ts.html +133 -0
  217. package/coverage/lcov-report/src/integrations/airtable.ts.html +529 -0
  218. package/coverage/lcov-report/src/integrations/arangodb.ts.html +415 -0
  219. package/coverage/lcov-report/src/integrations/base/index.html +161 -0
  220. package/coverage/lcov-report/src/integrations/base/query.ts.html +139 -0
  221. package/coverage/lcov-report/src/integrations/base/sql.ts.html +2017 -0
  222. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +691 -0
  223. package/coverage/lcov-report/src/integrations/base/utils.ts.html +121 -0
  224. package/coverage/lcov-report/src/integrations/couchdb.ts.html +484 -0
  225. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +745 -0
  226. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +646 -0
  227. package/coverage/lcov-report/src/integrations/firebase.ts.html +646 -0
  228. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +1315 -0
  229. package/coverage/lcov-report/src/integrations/index.html +371 -0
  230. package/coverage/lcov-report/src/integrations/index.ts.html +460 -0
  231. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +1012 -0
  232. package/coverage/lcov-report/src/integrations/mongodb.ts.html +1999 -0
  233. package/coverage/lcov-report/src/integrations/mysql.ts.html +979 -0
  234. package/coverage/lcov-report/src/integrations/oracle.ts.html +1387 -0
  235. package/coverage/lcov-report/src/integrations/postgres.ts.html +1087 -0
  236. package/coverage/lcov-report/src/integrations/queries/index.html +116 -0
  237. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +328 -0
  238. package/coverage/lcov-report/src/integrations/redis.ts.html +550 -0
  239. package/coverage/lcov-report/src/integrations/rest.ts.html +1372 -0
  240. package/coverage/lcov-report/src/integrations/s3.ts.html +862 -0
  241. package/coverage/lcov-report/src/integrations/snowflake.ts.html +376 -0
  242. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +85 -0
  243. package/coverage/lcov-report/src/integrations/tests/index.html +116 -0
  244. package/coverage/lcov-report/src/integrations/utils.ts.html +1036 -0
  245. package/coverage/lcov-report/src/middleware/appInfo.ts.html +145 -0
  246. package/coverage/lcov-report/src/middleware/authorized.ts.html +472 -0
  247. package/coverage/lcov-report/src/middleware/builder.ts.html +361 -0
  248. package/coverage/lcov-report/src/middleware/currentapp.ts.html +508 -0
  249. package/coverage/lcov-report/src/middleware/index.html +236 -0
  250. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +205 -0
  251. package/coverage/lcov-report/src/middleware/publicApi.ts.html +148 -0
  252. package/coverage/lcov-report/src/middleware/resourceId.ts.html +283 -0
  253. package/coverage/lcov-report/src/middleware/selfhost.ts.html +121 -0
  254. package/coverage/lcov-report/src/middleware/utils.ts.html +112 -0
  255. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +166 -0
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +163 -0
  257. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +151 -0
  258. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +206 -0
  259. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +172 -0
  260. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +226 -0
  261. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +151 -0
  262. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +151 -0
  263. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +166 -0
  264. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +532 -0
  265. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +286 -0
  266. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +146 -0
  267. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +265 -0
  268. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +232 -0
  269. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +724 -0
  270. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +161 -0
  271. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +106 -0
  272. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +235 -0
  273. package/coverage/lcov-report/src/migrations/functions/index.html +161 -0
  274. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +130 -0
  275. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +520 -0
  276. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +161 -0
  277. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +94 -0
  278. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +127 -0
  279. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +115 -0
  280. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +169 -0
  281. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +124 -0
  282. package/coverage/lcov-report/src/migrations/index.html +116 -0
  283. package/coverage/lcov-report/src/migrations/index.ts.html +430 -0
  284. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +205 -0
  285. package/coverage/lcov-report/src/migrations/tests/index.html +131 -0
  286. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +283 -0
  287. package/coverage/lcov-report/src/sdk/app/applications/index.html +146 -0
  288. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +106 -0
  289. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +268 -0
  290. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +136 -0
  291. package/coverage/lcov-report/src/sdk/app/automations/index.html +131 -0
  292. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +100 -0
  293. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +214 -0
  294. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +91 -0
  295. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +604 -0
  296. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +640 -0
  297. package/coverage/lcov-report/src/sdk/app/backups/index.html +176 -0
  298. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +112 -0
  299. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +292 -0
  300. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +562 -0
  301. package/coverage/lcov-report/src/sdk/app/datasources/index.html +131 -0
  302. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +100 -0
  303. package/coverage/lcov-report/src/sdk/app/queries/index.html +131 -0
  304. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +100 -0
  305. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +235 -0
  306. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +265 -0
  307. package/coverage/lcov-report/src/sdk/app/rows/index.html +146 -0
  308. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +106 -0
  309. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +139 -0
  310. package/coverage/lcov-report/src/sdk/app/tables/index.html +116 -0
  311. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +274 -0
  312. package/coverage/lcov-report/src/sdk/index.html +116 -0
  313. package/coverage/lcov-report/src/sdk/index.ts.html +151 -0
  314. package/coverage/lcov-report/src/sdk/users/index.html +131 -0
  315. package/coverage/lcov-report/src/sdk/users/index.ts.html +100 -0
  316. package/coverage/lcov-report/src/sdk/users/utils.ts.html +277 -0
  317. package/coverage/lcov-report/src/sdk/utils/index.html +116 -0
  318. package/coverage/lcov-report/src/sdk/utils/index.ts.html +133 -0
  319. package/coverage/lcov-report/src/startup.ts.html +484 -0
  320. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +2032 -0
  321. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +127 -0
  322. package/coverage/lcov-report/src/tests/utilities/index.html +161 -0
  323. package/coverage/lcov-report/src/tests/utilities/index.ts.html +118 -0
  324. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +856 -0
  325. package/coverage/lcov-report/src/threads/automation.ts.html +1555 -0
  326. package/coverage/lcov-report/src/threads/index.html +161 -0
  327. package/coverage/lcov-report/src/threads/index.ts.html +418 -0
  328. package/coverage/lcov-report/src/threads/query.ts.html +1000 -0
  329. package/coverage/lcov-report/src/threads/utils.ts.html +373 -0
  330. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +94 -0
  331. package/coverage/lcov-report/src/utilities/centralPath.ts.html +151 -0
  332. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +343 -0
  333. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +547 -0
  334. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +601 -0
  335. package/coverage/lcov-report/src/utilities/fileSystem/index.html +206 -0
  336. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +100 -0
  337. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +277 -0
  338. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +142 -0
  339. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +193 -0
  340. package/coverage/lcov-report/src/utilities/global.ts.html +499 -0
  341. package/coverage/lcov-report/src/utilities/index.html +251 -0
  342. package/coverage/lcov-report/src/utilities/index.ts.html +487 -0
  343. package/coverage/lcov-report/src/utilities/redis.ts.html +343 -0
  344. package/coverage/lcov-report/src/utilities/routing/index.html +116 -0
  345. package/coverage/lcov-report/src/utilities/routing/index.ts.html +181 -0
  346. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +146 -0
  347. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +922 -0
  348. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +373 -0
  349. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +373 -0
  350. package/coverage/lcov-report/src/utilities/schema.ts.html +508 -0
  351. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +169 -0
  352. package/coverage/lcov-report/src/utilities/security.ts.html +280 -0
  353. package/coverage/lcov-report/src/utilities/usageQuota/index.html +131 -0
  354. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +325 -0
  355. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +139 -0
  356. package/coverage/lcov-report/src/utilities/users.ts.html +232 -0
  357. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +646 -0
  358. package/coverage/lcov-report/src/watch.ts.html +196 -0
  359. package/coverage/lcov-report/src/websocket.ts.html +163 -0
  360. package/coverage/lcov.info +21777 -0
  361. package/dist/api/controllers/automation.js +2 -11
  362. package/dist/api/controllers/query/index.js +0 -2
  363. package/dist/api/controllers/row/ExternalRequest.js +2 -4
  364. package/dist/api/controllers/row/external.js +1 -12
  365. package/dist/api/controllers/table/external.js +8 -8
  366. package/dist/api/index.js +21 -1
  367. package/dist/api/routes/automation.js +1 -1
  368. package/dist/api/routes/public/tests/utils.js +33 -0
  369. package/dist/app.js +1 -7
  370. package/dist/constants/index.js +24 -4
  371. package/dist/db/defaultData/datasource_bb_default.js +5 -6
  372. package/dist/db/linkedRows/LinkController.js +8 -9
  373. package/dist/integrations/base/sql.js +3 -10
  374. package/dist/middleware/authorized.js +3 -5
  375. package/dist/middleware/builder.js +3 -6
  376. package/dist/package.json +8 -12
  377. package/dist/sdk/app/backups/exports.js +2 -8
  378. package/dist/sdk/app/datasources/datasources.js +0 -3
  379. package/dist/tsconfig.build.tsbuildinfo +1 -1
  380. package/dist/utilities/redis.js +0 -2
  381. package/jest.config.ts +22 -34
  382. package/package.json +9 -13
  383. package/specs/openapi.json +6 -6
  384. package/specs/openapi.yaml +3 -3
  385. package/specs/resources/query.js +1 -1
  386. package/specs/resources/table.js +1 -1
  387. package/src/api/controllers/automation.ts +2 -13
  388. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  389. package/src/api/controllers/query/index.ts +0 -2
  390. package/src/api/controllers/row/ExternalRequest.ts +2 -6
  391. package/src/api/controllers/row/external.ts +1 -13
  392. package/src/api/controllers/table/external.ts +2 -3
  393. package/src/api/index.ts +22 -3
  394. package/src/api/routes/automation.ts +1 -1
  395. package/src/api/routes/public/applications.ts +1 -0
  396. package/src/api/routes/public/tests/compare.spec.js +1 -1
  397. package/src/api/routes/public/tests/users.spec.js +1 -1
  398. package/src/api/routes/public/tests/utils.ts +8 -25
  399. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  400. package/src/api/routes/tests/analytics.spec.js +1 -4
  401. package/src/api/routes/tests/apikeys.spec.js +1 -1
  402. package/src/api/routes/tests/application.spec.ts +6 -20
  403. package/src/api/routes/tests/auth.spec.js +2 -2
  404. package/src/api/routes/tests/automation.spec.js +2 -6
  405. package/src/api/routes/tests/backup.spec.ts +14 -4
  406. package/src/api/routes/tests/{cloud.seq.spec.ts → cloud.spec.ts} +15 -11
  407. package/src/api/routes/tests/component.spec.js +1 -1
  408. package/src/api/routes/tests/datasource.spec.ts +3 -20
  409. package/src/api/routes/tests/dev.spec.js +1 -1
  410. package/src/api/routes/tests/integration.spec.js +1 -1
  411. package/src/api/routes/tests/layout.spec.js +1 -1
  412. package/src/api/routes/tests/metadata.spec.js +1 -1
  413. package/src/api/routes/tests/misc.spec.js +1 -1
  414. package/src/api/routes/tests/permissions.spec.js +1 -4
  415. package/src/api/routes/tests/{query.seq.spec.js → query.spec.js} +1 -22
  416. package/src/api/routes/tests/role.spec.js +1 -6
  417. package/src/api/routes/tests/routing.spec.js +1 -1
  418. package/src/api/routes/tests/row.spec.js +3 -11
  419. package/src/api/routes/tests/screen.spec.js +1 -1
  420. package/src/api/routes/tests/static.spec.js +13 -2
  421. package/src/api/routes/tests/table.spec.js +1 -1
  422. package/src/api/routes/tests/templates.spec.js +1 -1
  423. package/src/api/routes/tests/user.spec.js +12 -11
  424. package/src/api/routes/tests/utilities/TestFunctions.ts +2 -25
  425. package/src/api/routes/tests/utilities/index.ts +3 -5
  426. package/src/api/routes/tests/view.spec.js +1 -4
  427. package/src/api/routes/tests/webhook.spec.js +2 -11
  428. package/src/app.ts +1 -10
  429. package/src/automations/tests/automation.spec.js +4 -4
  430. package/src/automations/tests/bash.spec.js +1 -1
  431. package/src/automations/tests/discord.spec.js +1 -1
  432. package/src/automations/tests/executeQuery.spec.js +3 -2
  433. package/src/automations/tests/executeScript.spec.js +1 -1
  434. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  435. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  436. package/src/automations/tests/serverLog.spec.js +1 -1
  437. package/src/automations/tests/updateRow.spec.js +1 -1
  438. package/src/automations/tests/zapier.spec.js +1 -1
  439. package/src/constants/index.ts +23 -1
  440. package/src/db/defaultData/datasource_bb_default.ts +10 -6
  441. package/src/db/linkedRows/LinkController.ts +1 -2
  442. package/src/db/tests/linkController.spec.js +1 -4
  443. package/src/db/tests/linkTests.spec.js +1 -1
  444. package/src/integrations/base/sql.ts +5 -15
  445. package/src/integrations/oracle.ts +1 -1
  446. package/src/integrations/tests/couchdb.spec.ts +2 -0
  447. package/src/middleware/authorized.ts +4 -6
  448. package/src/middleware/builder.ts +3 -8
  449. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  450. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  451. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  452. package/src/migrations/tests/index.spec.ts +20 -13
  453. package/src/sdk/app/backups/exports.ts +2 -8
  454. package/src/sdk/app/datasources/datasources.ts +0 -3
  455. package/src/tests/jestEnv.ts +11 -8
  456. package/src/tests/jestSetup.ts +7 -9
  457. package/src/tests/utilities/TestConfiguration.ts +92 -166
  458. package/src/tests/utilities/structures.ts +2 -16
  459. package/src/utilities/redis.ts +0 -2
  460. package/tsconfig.build.json +0 -1
  461. package/builder/assets/blankScreenPreview.72634dd1.png +0 -0
  462. package/builder/assets/index.22724f34.css +0 -6
  463. package/builder/assets/listScreenPreview.599c0aae.png +0 -0
  464. package/dist/ddApm.js +0 -11
  465. package/dist/elasticApm.js +0 -14
  466. package/dist/utilities/retry.js +0 -30
  467. package/jest-testcontainers-config.js +0 -8
  468. package/scripts/load/create-many-apps.js +0 -24
  469. package/scripts/load/create-many-rows.js +0 -30
  470. package/scripts/load/utils.js +0 -66
  471. package/scripts/test.sh +0 -12
  472. package/src/api/routes/tests/environmentVariables.spec.ts +0 -144
  473. package/src/ddApm.ts +0 -7
  474. package/src/elasticApm.ts +0 -10
  475. package/src/integration-test/postgres.spec.ts +0 -762
  476. package/src/tests/logging.ts +0 -34
  477. package/src/utilities/retry.ts +0 -18
@@ -14,22 +14,18 @@ jest.mock("../../../utilities/redis", () => ({
14
14
  import { clearAllApps, checkBuilderEndpoint } from "./utilities/TestFunctions"
15
15
  import * as setup from "./utilities"
16
16
  import { AppStatus } from "../../../db/utils"
17
- import { events, utils } from "@budibase/backend-core"
17
+ import { events } from "@budibase/backend-core"
18
18
  import env from "../../../environment"
19
19
 
20
- jest.setTimeout(15000)
21
-
22
20
  describe("/applications", () => {
23
21
  let request = setup.getRequest()
24
22
  let config = setup.getConfig()
25
23
 
26
24
  afterAll(setup.afterAll)
27
25
 
28
- beforeAll(async () => {
29
- await config.init()
30
- })
31
-
32
26
  beforeEach(async () => {
27
+ await clearAllApps()
28
+ await config.init()
33
29
  jest.clearAllMocks()
34
30
  })
35
31
 
@@ -37,7 +33,7 @@ describe("/applications", () => {
37
33
  it("creates empty app", async () => {
38
34
  const res = await request
39
35
  .post("/api/applications")
40
- .field("name", utils.newid())
36
+ .field("name", "My App")
41
37
  .set(config.defaultHeaders())
42
38
  .expect("Content-Type", /json/)
43
39
  .expect(200)
@@ -48,7 +44,7 @@ describe("/applications", () => {
48
44
  it("creates app from template", async () => {
49
45
  const res = await request
50
46
  .post("/api/applications")
51
- .field("name", utils.newid())
47
+ .field("name", "My App")
52
48
  .field("useTemplate", "true")
53
49
  .field("templateKey", "test")
54
50
  .field("templateString", "{}") // override the file download
@@ -63,7 +59,7 @@ describe("/applications", () => {
63
59
  it("creates app from file", async () => {
64
60
  const res = await request
65
61
  .post("/api/applications")
66
- .field("name", utils.newid())
62
+ .field("name", "My App")
67
63
  .field("useTemplate", "true")
68
64
  .set(config.defaultHeaders())
69
65
  .attach("templateFile", "src/api/routes/tests/data/export.txt")
@@ -110,11 +106,6 @@ describe("/applications", () => {
110
106
  })
111
107
 
112
108
  describe("fetch", () => {
113
- beforeEach(async () => {
114
- // Clean all apps but the onde from config
115
- await clearAllApps(config.getTenantId(), [config.getAppId()!])
116
- })
117
-
118
109
  it("lists all applications", async () => {
119
110
  await config.createApp("app1")
120
111
  await config.createApp("app2")
@@ -275,11 +266,6 @@ describe("/applications", () => {
275
266
  })
276
267
 
277
268
  describe("unpublish", () => {
278
- beforeEach(async () => {
279
- // We want to republish as the unpublish will delete the prod app
280
- await config.publish()
281
- })
282
-
283
269
  it("should unpublish app with dev app ID", async () => {
284
270
  const appId = config.getAppId()
285
271
  await request
@@ -7,7 +7,7 @@ describe("/authenticate", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -18,7 +18,7 @@ describe("/authenticate", () => {
18
18
  .set(config.defaultHeaders())
19
19
  .expect("Content-Type", /json/)
20
20
  .expect(200)
21
- expect(res.body._id).toEqual(generateUserMetadataID(config.user._id))
21
+ expect(res.body._id).toEqual(generateUserMetadataID("us_uuid1"))
22
22
  })
23
23
  })
24
24
  })
@@ -10,16 +10,12 @@ 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
-
16
13
  describe("/automations", () => {
17
14
  let request = setup.getRequest()
18
15
  let config = setup.getConfig()
19
16
 
20
17
  afterAll(setup.afterAll)
21
18
 
22
- // For some reason this cannot be a beforeAll or the test "tests the automation successfully" fail
23
19
  beforeEach(async () => {
24
20
  await config.init()
25
21
  })
@@ -149,7 +145,7 @@ describe("/automations", () => {
149
145
  let elements = await getAllTableRows(config)
150
146
  // don't test it unless there are values to test
151
147
  if (elements.length > 1) {
152
- expect(elements.length).toBeGreaterThanOrEqual(MAX_RETRIES)
148
+ expect(elements.length).toEqual(5)
153
149
  expect(elements[0].name).toEqual("Test")
154
150
  expect(elements[0].description).toEqual("TEST")
155
151
  return
@@ -309,7 +305,7 @@ describe("/automations", () => {
309
305
  .expect('Content-Type', /json/)
310
306
  .expect(200)
311
307
 
312
- expect(res.body[0]).toEqual(expect.objectContaining(autoConfig))
308
+ expect(res.body[0]).toEqual(expect.objectContaining(autoConfig))
313
309
  })
314
310
 
315
311
  it("should apply authorization to endpoint", async () => {
@@ -1,8 +1,17 @@
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
+
1
11
  import * as setup from "./utilities"
2
12
  import { events } from "@budibase/backend-core"
3
13
  import sdk from "../../../sdk"
4
14
  import { checkBuilderEndpoint } from "./utilities/TestFunctions"
5
-
6
15
  describe("/backups", () => {
7
16
  let request = setup.getRequest()
8
17
  let config = setup.getConfig()
@@ -19,6 +28,7 @@ describe("/backups", () => {
19
28
  .get(`/api/backups/export?appId=${config.getAppId()}&appname=test`)
20
29
  .set(config.defaultHeaders())
21
30
  .expect(200)
31
+ expect(res.text).toBeDefined()
22
32
  expect(res.headers["content-type"]).toEqual("application/gzip")
23
33
  expect(events.app.exported).toBeCalledTimes(1)
24
34
  })
@@ -34,9 +44,9 @@ describe("/backups", () => {
34
44
 
35
45
  describe("calculateBackupStats", () => {
36
46
  it("should be able to calculate the backup statistics", async () => {
37
- await config.createAutomation()
38
- await config.createScreen()
39
- let res = await sdk.backups.calculateBackupStats(config.getAppId()!)
47
+ config.createAutomation()
48
+ config.createScreen()
49
+ let res = await sdk.backups.calculateBackupStats(config.getAppId())
40
50
  expect(res.automations).toEqual(1)
41
51
  expect(res.datasources).toEqual(1)
42
52
  expect(res.screens).toEqual(1)
@@ -1,22 +1,14 @@
1
- jest.setTimeout(30000)
2
-
1
+ import { db as dbCore } from "@budibase/backend-core"
3
2
  import { AppStatus } from "../../../db/utils"
4
3
 
5
4
  import * as setup from "./utilities"
6
5
 
7
- import { wipeDb } from "./utilities/TestFunctions"
8
-
9
6
  describe("/cloud", () => {
10
- let request = setup.getRequest()!
7
+ let request = setup.getRequest()
11
8
  let config = setup.getConfig()
12
9
 
13
10
  afterAll(setup.afterAll)
14
11
 
15
- beforeAll(() => {
16
- // Importing is only allowed in self hosted environments
17
- config.modeSelf()
18
- })
19
-
20
12
  beforeEach(async () => {
21
13
  await config.init()
22
14
  })
@@ -30,7 +22,19 @@ describe("/cloud", () => {
30
22
  it("should be able to import apps", async () => {
31
23
  // first we need to delete any existing apps on the system so it looks clean otherwise the
32
24
  // import will not run
33
- await wipeDb()
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)
34
38
 
35
39
  // get a count of apps before the import
36
40
  const preImportApps = await request
@@ -7,7 +7,7 @@ describe("/component", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -5,10 +5,6 @@ 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
-
12
8
  let { basicDatasource } = setup.structures
13
9
  const pg = require("pg")
14
10
 
@@ -19,13 +15,11 @@ describe("/datasources", () => {
19
15
 
20
16
  afterAll(setup.afterAll)
21
17
 
22
- async function setupTest() {
18
+ beforeEach(async () => {
23
19
  await config.init()
24
20
  datasource = await config.createDatasource()
25
21
  jest.clearAllMocks()
26
- }
27
-
28
- beforeAll(setupTest)
22
+ })
29
23
 
30
24
  describe("create", () => {
31
25
  it("should create a new datasource", async () => {
@@ -62,14 +56,7 @@ describe("/datasources", () => {
62
56
  datasource: any,
63
57
  fields: { path: string; queryString: string }
64
58
  ) {
65
- return config.previewQuery(
66
- request,
67
- config,
68
- datasource,
69
- fields,
70
- undefined,
71
- ""
72
- )
59
+ return config.previewQuery(request, config, datasource, fields)
73
60
  }
74
61
 
75
62
  it("should invalidate changed or removed variables", async () => {
@@ -104,8 +91,6 @@ describe("/datasources", () => {
104
91
  })
105
92
 
106
93
  describe("fetch", () => {
107
- beforeAll(setupTest)
108
-
109
94
  it("returns all the datasources from the server", async () => {
110
95
  const res = await request
111
96
  .get(`/api/datasources`)
@@ -174,8 +159,6 @@ describe("/datasources", () => {
174
159
  })
175
160
 
176
161
  describe("destroy", () => {
177
- beforeAll(setupTest)
178
-
179
162
  it("deletes queries for the datasource after deletion and returns a success message", async () => {
180
163
  await config.createQuery()
181
164
 
@@ -8,7 +8,7 @@ describe("/dev", () => {
8
8
 
9
9
  afterAll(setup.afterAll)
10
10
 
11
- beforeAll(async () => {
11
+ beforeEach(async () => {
12
12
  await config.init()
13
13
  jest.clearAllMocks()
14
14
  })
@@ -7,7 +7,7 @@ describe("/integrations", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeAll(async () => {
10
+ beforeEach(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
- beforeAll(async () => {
13
+ beforeEach(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
- beforeAll(async () => {
12
+ beforeEach(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
- beforeAll(async () => {
10
+ beforeEach(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -15,11 +15,8 @@ describe("/permission", () => {
15
15
 
16
16
  afterAll(setup.afterAll)
17
17
 
18
- beforeAll(async () => {
19
- await config.init()
20
- })
21
-
22
18
  beforeEach(async () => {
19
+ await config.init()
23
20
  table = await config.createTable()
24
21
  row = await config.createRow()
25
22
  perms = await config.addPermission(STD_ROLE_ID, table._id)
@@ -1,6 +1,3 @@
1
- const tk = require( "timekeeper")
2
- tk.freeze(Date.now())
3
-
4
1
  // Mock out postgres for this
5
2
  jest.mock("pg")
6
3
  jest.mock("node-fetch")
@@ -30,15 +27,10 @@ describe("/queries", () => {
30
27
 
31
28
  afterAll(setup.afterAll)
32
29
 
33
- const setupTest = async()=>{
34
-
30
+ beforeEach(async () => {
35
31
  await config.init()
36
32
  datasource = await config.createDatasource()
37
33
  query = await config.createQuery()
38
- }
39
-
40
- beforeAll(async () => {
41
- await setupTest()
42
34
  })
43
35
 
44
36
  async function createInvalidIntegration() {
@@ -109,10 +101,6 @@ describe("/queries", () => {
109
101
  })
110
102
 
111
103
  describe("fetch", () => {
112
- beforeEach(async() => {
113
- await setupTest()
114
- })
115
-
116
104
  it("returns all the queries from the server", async () => {
117
105
  const res = await request
118
106
  .get(`/api/queries`)
@@ -190,10 +178,6 @@ describe("/queries", () => {
190
178
  })
191
179
 
192
180
  describe("destroy", () => {
193
- beforeEach(async() => {
194
- await setupTest()
195
- })
196
-
197
181
  it("deletes a query and returns a success message", async () => {
198
182
  await request
199
183
  .delete(`/api/queries/${query._id}/${query._rev}`)
@@ -242,7 +226,6 @@ describe("/queries", () => {
242
226
  })
243
227
  expect(res.body.rows.length).toEqual(1)
244
228
  expect(events.query.previewed).toBeCalledTimes(1)
245
- delete datasource.config
246
229
  expect(events.query.previewed).toBeCalledWith(datasource, query)
247
230
  })
248
231
 
@@ -256,10 +239,6 @@ describe("/queries", () => {
256
239
  })
257
240
 
258
241
  describe("execute", () => {
259
- beforeEach(async() => {
260
- await setupTest()
261
- })
262
-
263
242
  it("should be able to execute the query", async () => {
264
243
  const res = await request
265
244
  .post(`/api/queries/${query._id}`)
@@ -10,7 +10,7 @@ describe("/roles", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeAll(async () => {
13
+ beforeEach(async () => {
14
14
  await config.init()
15
15
  })
16
16
 
@@ -60,11 +60,6 @@ describe("/roles", () => {
60
60
  })
61
61
 
62
62
  describe("fetch", () => {
63
- beforeAll(async () => {
64
- // Recreate the app
65
- await config.init()
66
- })
67
-
68
63
  it("should list custom roles, plus 2 default roles", async () => {
69
64
  const customRole = await config.createRole()
70
65
 
@@ -16,7 +16,7 @@ describe("/routing", () => {
16
16
 
17
17
  afterAll(setup.afterAll)
18
18
 
19
- beforeAll(async () => {
19
+ beforeEach(async () => {
20
20
  await config.init()
21
21
  screen = basicScreen()
22
22
  screen.routing.route = route
@@ -1,8 +1,3 @@
1
- const tk = require( "timekeeper")
2
- const timestamp = new Date("2023-01-26T11:48:57.597Z").toISOString()
3
- tk.freeze(timestamp)
4
-
5
-
6
1
  const { outputProcessing } = require("../../../utilities/rowProcessor")
7
2
  const setup = require("./utilities")
8
3
  const { basicRow } = setup.structures
@@ -25,11 +20,8 @@ describe("/rows", () => {
25
20
 
26
21
  afterAll(setup.afterAll)
27
22
 
28
- beforeAll(async () => {
23
+ beforeEach(async () => {
29
24
  await config.init()
30
- })
31
-
32
- beforeEach(async()=>{
33
25
  table = await config.createTable()
34
26
  row = basicRow(table._id)
35
27
  })
@@ -119,8 +111,8 @@ describe("/rows", () => {
119
111
  _id: existing._id,
120
112
  _rev: existing._rev,
121
113
  type: "row",
122
- createdAt: timestamp,
123
- updatedAt: timestamp,
114
+ createdAt: "2020-01-01T00:00:00.000Z",
115
+ updatedAt: "2020-01-01T00:00:00.000Z",
124
116
  })
125
117
  await assertQueryUsage(queryUsage + 1)
126
118
  })
@@ -10,7 +10,7 @@ describe("/screens", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeAll(async () => {
13
+ beforeEach(async () => {
14
14
  await config.init()
15
15
  screen = await config.createScreen()
16
16
  })
@@ -8,11 +8,22 @@ describe("/static", () => {
8
8
 
9
9
  afterAll(setup.afterAll)
10
10
 
11
- beforeAll(async () => {
12
- config.modeSelf()
11
+ beforeEach(async () => {
13
12
  app = await config.init()
14
13
  })
15
14
 
15
+ describe("/builder", () => {
16
+ it("should serve the builder", async () => {
17
+ const res = await request
18
+ .get("/builder/portal")
19
+ .set(config.defaultHeaders())
20
+ .expect("Content-Type", /text\/html/)
21
+ .expect(200)
22
+
23
+ expect(res.text).toContain("<title>Budibase</title>")
24
+ })
25
+ })
26
+
16
27
  describe("/app", () => {
17
28
  beforeEach(() => {
18
29
  jest.clearAllMocks()
@@ -10,7 +10,7 @@ describe("/tables", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeAll(async () => {
13
+ beforeEach(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
- beforeAll(async () => {
9
+ beforeEach(async () => {
10
10
  await config.init()
11
11
  })
12
12
 
@@ -3,8 +3,6 @@ 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
-
8
6
  jest.mock("../../../utilities/workerRequests", () => ({
9
7
  getGlobalUsers: jest.fn(() => {
10
8
  return {}
@@ -21,14 +19,14 @@ describe("/users", () => {
21
19
 
22
20
  afterAll(setup.afterAll)
23
21
 
24
- beforeAll(async () => {
22
+ beforeEach(async () => {
25
23
  await config.init()
26
24
  })
27
25
 
28
26
  describe("fetch", () => {
29
27
  it("returns a list of users from an instance db", async () => {
30
- await config.createUser({ id: "uuidx" })
31
- await config.createUser({ id: "uuidy" })
28
+ await config.createUser("uuidx")
29
+ await config.createUser("uuidy")
32
30
  const res = await request
33
31
  .get(`/api/users/metadata`)
34
32
  .set(config.defaultHeaders())
@@ -55,7 +53,7 @@ describe("/users", () => {
55
53
 
56
54
  describe("update", () => {
57
55
  it("should be able to update the user", async () => {
58
- const user = await config.createUser({ id: `us_update${Math.random()}` })
56
+ const user = await config.createUser()
59
57
  user.roleId = BUILTIN_ROLE_IDS.BASIC
60
58
  const res = await request
61
59
  .put(`/api/users/metadata`)
@@ -179,11 +177,14 @@ describe("/users", () => {
179
177
  const app1 = await config.createApp('App 1')
180
178
  const app2 = await config.createApp('App 2')
181
179
 
182
- let user = await config.createUser({
183
- builder: false,
184
- admin: true,
185
- roles: { [app1.appId]: 'ADMIN' }
186
- })
180
+ let user = await config.createUser(
181
+ undefined,
182
+ undefined,
183
+ undefined,
184
+ undefined,
185
+ false,
186
+ true,
187
+ { [app1.appId]: 'ADMIN' })
187
188
  let res = await request
188
189
  .post(`/api/users/metadata/sync/${user._id}`)
189
190
  .set(config.defaultHeaders())
@@ -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) {