@budibase/server 2.2.26 → 2.2.27-alpha.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 (657) hide show
  1. package/Dockerfile +1 -1
  2. package/__mocks__/aws-sdk.ts +19 -0
  3. package/__mocks__/node-fetch.ts +80 -0
  4. package/builder/assets/{bb-emblem.4e4717da.svg → bb-emblem.05f7ae7a.svg} +1 -1
  5. package/builder/assets/bg.29e85dd5.png +0 -0
  6. package/builder/assets/bulgaria.bd68393d.png +0 -0
  7. package/builder/assets/covanta.72c46c1e.png +0 -0
  8. package/builder/assets/index.3dd03883.css +6 -0
  9. package/builder/assets/index.f9b8b175.js +1802 -0
  10. package/builder/assets/schnellecke.cf1837a8.png +0 -0
  11. package/builder/index.html +3 -3
  12. package/coverage/clover.xml +6618 -6528
  13. package/coverage/coverage-final.json +282 -276
  14. package/coverage/lcov-report/index.html +489 -444
  15. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +9 -9
  16. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +6 -6
  17. package/coverage/lcov-report/src/api/controllers/application.ts.html +362 -266
  18. package/coverage/lcov-report/src/api/controllers/auth.ts.html +12 -12
  19. package/coverage/lcov-report/src/api/controllers/automation.ts.html +61 -61
  20. package/coverage/lcov-report/src/api/controllers/backup.ts.html +8 -8
  21. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +93 -81
  22. package/coverage/lcov-report/src/api/controllers/component.ts.html +12 -12
  23. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +122 -98
  24. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +21 -18
  25. package/coverage/lcov-report/src/api/controllers/deploy/index.html +21 -21
  26. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +142 -196
  27. package/coverage/lcov-report/src/api/controllers/dev.ts.html +28 -28
  28. package/coverage/lcov-report/src/api/controllers/index.html +115 -115
  29. package/coverage/lcov-report/src/api/controllers/integration.ts.html +5 -5
  30. package/coverage/lcov-report/src/api/controllers/layout.ts.html +9 -9
  31. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +11 -11
  32. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +6 -6
  33. package/coverage/lcov-report/src/api/controllers/permission.ts.html +14 -14
  34. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +20 -20
  35. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +62 -62
  36. package/coverage/lcov-report/src/api/controllers/plugin/index.html +72 -72
  37. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +150 -135
  38. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +56 -56
  39. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +11 -11
  40. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +18 -18
  41. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +20 -20
  42. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +75 -24
  43. package/coverage/lcov-report/src/api/controllers/public/index.html +58 -58
  44. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +7 -7
  45. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +25 -25
  46. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +9 -9
  47. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +8 -8
  48. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +4 -4
  49. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +4 -4
  50. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +4 -4
  51. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +15 -15
  52. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +21 -21
  53. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +21 -21
  54. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +27 -27
  55. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +8 -8
  56. package/coverage/lcov-report/src/api/controllers/query/import/index.html +8 -8
  57. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +11 -11
  58. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +14 -14
  59. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +14 -14
  60. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +8 -8
  61. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +12 -12
  62. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +23 -23
  63. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +16 -16
  64. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +20 -20
  65. package/coverage/lcov-report/src/api/controllers/query/index.html +20 -20
  66. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +131 -107
  67. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +11 -11
  68. package/coverage/lcov-report/src/api/controllers/role.ts.html +9 -9
  69. package/coverage/lcov-report/src/api/controllers/routing.ts.html +10 -10
  70. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +56 -41
  71. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +87 -57
  72. package/coverage/lcov-report/src/api/controllers/row/index.html +66 -66
  73. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +37 -37
  74. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +181 -106
  75. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +146 -146
  76. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +44 -35
  77. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +156 -39
  78. package/coverage/lcov-report/src/api/controllers/screen.ts.html +31 -31
  79. package/coverage/lcov-report/src/api/controllers/script.ts.html +19 -19
  80. package/coverage/lcov-report/src/api/controllers/static/index.html +18 -18
  81. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +56 -71
  82. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +60 -60
  83. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +56 -50
  84. package/coverage/lcov-report/src/api/controllers/table/index.html +48 -48
  85. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +157 -70
  86. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +58 -61
  87. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +109 -112
  88. package/coverage/lcov-report/src/api/controllers/templates.ts.html +21 -21
  89. package/coverage/lcov-report/src/api/controllers/user.ts.html +159 -135
  90. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +64 -19
  91. package/coverage/lcov-report/src/api/controllers/view/index.html +38 -38
  92. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +97 -133
  93. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +31 -31
  94. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +37 -37
  95. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +69 -63
  96. package/coverage/lcov-report/src/api/index.html +15 -15
  97. package/coverage/lcov-report/src/api/index.ts.html +40 -40
  98. package/coverage/lcov-report/src/api/routes/analytics.ts.html +10 -10
  99. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +11 -11
  100. package/coverage/lcov-report/src/api/routes/application.ts.html +46 -13
  101. package/coverage/lcov-report/src/api/routes/auth.ts.html +9 -9
  102. package/coverage/lcov-report/src/api/routes/automation.ts.html +14 -14
  103. package/coverage/lcov-report/src/api/routes/backup.ts.html +11 -11
  104. package/coverage/lcov-report/src/api/routes/cloud.ts.html +11 -11
  105. package/coverage/lcov-report/src/api/routes/component.ts.html +11 -11
  106. package/coverage/lcov-report/src/api/routes/datasource.ts.html +12 -12
  107. package/coverage/lcov-report/src/api/routes/deploy.ts.html +11 -14
  108. package/coverage/lcov-report/src/api/routes/dev.ts.html +17 -17
  109. package/coverage/lcov-report/src/api/routes/index.html +68 -68
  110. package/coverage/lcov-report/src/api/routes/index.ts.html +49 -40
  111. package/coverage/lcov-report/src/api/routes/integration.ts.html +11 -11
  112. package/coverage/lcov-report/src/api/routes/layout.ts.html +11 -11
  113. package/coverage/lcov-report/src/api/routes/metadata.ts.html +12 -12
  114. package/coverage/lcov-report/src/api/routes/migrations.ts.html +10 -10
  115. package/coverage/lcov-report/src/api/routes/permission.ts.html +12 -12
  116. package/coverage/lcov-report/src/api/routes/plugin.ts.html +10 -10
  117. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +147 -15
  118. package/coverage/lcov-report/src/api/routes/public/index.html +27 -27
  119. package/coverage/lcov-report/src/api/routes/public/index.ts.html +60 -60
  120. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +15 -15
  121. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +28 -16
  122. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +11 -11
  123. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +14 -14
  124. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +14 -14
  125. package/coverage/lcov-report/src/api/routes/public/tests/index.html +7 -7
  126. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +5 -5
  127. package/coverage/lcov-report/src/api/routes/public/users.ts.html +14 -14
  128. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +21 -21
  129. package/coverage/lcov-report/src/api/routes/public/utils/index.html +5 -5
  130. package/coverage/lcov-report/src/api/routes/query.ts.html +14 -14
  131. package/coverage/lcov-report/src/api/routes/role.ts.html +12 -12
  132. package/coverage/lcov-report/src/api/routes/routing.ts.html +11 -11
  133. package/coverage/lcov-report/src/api/routes/row.ts.html +14 -14
  134. package/coverage/lcov-report/src/api/routes/screen.ts.html +12 -12
  135. package/coverage/lcov-report/src/api/routes/script.ts.html +13 -13
  136. package/coverage/lcov-report/src/api/routes/static.ts.html +18 -18
  137. package/coverage/lcov-report/src/api/routes/table.ts.html +29 -98
  138. package/coverage/lcov-report/src/api/routes/templates.ts.html +11 -11
  139. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +27 -27
  140. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +23 -23
  141. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +33 -33
  142. package/coverage/lcov-report/src/api/routes/user.ts.html +12 -12
  143. package/coverage/lcov-report/src/api/routes/utils/index.html +3 -3
  144. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +44 -44
  145. package/coverage/lcov-report/src/api/routes/view.ts.html +13 -13
  146. package/coverage/lcov-report/src/api/routes/webhook.ts.html +13 -13
  147. package/coverage/lcov-report/src/app.ts.html +53 -47
  148. package/coverage/lcov-report/src/automations/actions.ts.html +31 -31
  149. package/coverage/lcov-report/src/automations/automationUtils.ts.html +127 -55
  150. package/coverage/lcov-report/src/automations/bullboard.ts.html +19 -19
  151. package/coverage/lcov-report/src/automations/index.html +54 -54
  152. package/coverage/lcov-report/src/automations/index.ts.html +23 -23
  153. package/coverage/lcov-report/src/automations/logging/index.html +3 -3
  154. package/coverage/lcov-report/src/automations/logging/index.ts.html +15 -15
  155. package/coverage/lcov-report/src/automations/steps/bash.ts.html +34 -34
  156. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +9 -9
  157. package/coverage/lcov-report/src/automations/steps/delay.ts.html +7 -7
  158. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +9 -9
  159. package/coverage/lcov-report/src/automations/steps/discord.ts.html +33 -33
  160. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +35 -35
  161. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +31 -31
  162. package/coverage/lcov-report/src/automations/steps/filter.ts.html +12 -12
  163. package/coverage/lcov-report/src/automations/steps/index.html +129 -129
  164. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +10 -10
  165. package/coverage/lcov-report/src/automations/steps/loop.ts.html +5 -5
  166. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +19 -19
  167. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +43 -43
  168. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +28 -28
  169. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +19 -19
  170. package/coverage/lcov-report/src/automations/steps/slack.ts.html +10 -10
  171. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +12 -12
  172. package/coverage/lcov-report/src/automations/steps/utils.ts.html +18 -18
  173. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +22 -22
  174. package/coverage/lcov-report/src/automations/tests/utilities/index.html +15 -15
  175. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +32 -32
  176. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +6 -6
  177. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +6 -6
  178. package/coverage/lcov-report/src/automations/triggerInfo/index.html +17 -17
  179. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +10 -10
  180. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +6 -6
  181. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +6 -6
  182. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +6 -6
  183. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +6 -6
  184. package/coverage/lcov-report/src/automations/triggers.ts.html +53 -38
  185. package/coverage/lcov-report/src/automations/utils.ts.html +80 -80
  186. package/coverage/lcov-report/src/constants/index.html +19 -19
  187. package/coverage/lcov-report/src/constants/index.ts.html +103 -103
  188. package/coverage/lcov-report/src/constants/layouts.ts.html +9 -9
  189. package/coverage/lcov-report/src/constants/screens.ts.html +5 -5
  190. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +45 -45
  191. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +8 -8
  192. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +8 -8
  193. package/coverage/lcov-report/src/db/defaultData/index.html +43 -43
  194. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +8 -8
  195. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +8 -8
  196. package/coverage/lcov-report/src/db/dynamoClient.ts.html +26 -26
  197. package/coverage/lcov-report/src/db/inMemoryView.ts.html +13 -13
  198. package/coverage/lcov-report/src/db/index.html +34 -34
  199. package/coverage/lcov-report/src/db/index.ts.html +10 -10
  200. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +38 -38
  201. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +7 -7
  202. package/coverage/lcov-report/src/db/linkedRows/index.html +37 -37
  203. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +40 -40
  204. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +25 -25
  205. package/coverage/lcov-report/src/db/newid.ts.html +5 -5
  206. package/coverage/lcov-report/src/db/utils.ts.html +90 -90
  207. package/coverage/lcov-report/src/definitions/automations.ts.html +9 -6
  208. package/coverage/lcov-report/src/definitions/index.html +5 -20
  209. package/coverage/lcov-report/src/environment.ts.html +44 -32
  210. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +14 -14
  211. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +8 -8
  212. package/coverage/lcov-report/src/events/index.html +20 -20
  213. package/coverage/lcov-report/src/events/index.ts.html +7 -7
  214. package/coverage/lcov-report/src/events/utils.ts.html +11 -11
  215. package/coverage/lcov-report/src/index.html +47 -47
  216. package/coverage/lcov-report/src/index.ts.html +8 -8
  217. package/coverage/lcov-report/src/integrations/airtable.ts.html +10 -10
  218. package/coverage/lcov-report/src/integrations/arangodb.ts.html +9 -9
  219. package/coverage/lcov-report/src/integrations/base/index.html +29 -29
  220. package/coverage/lcov-report/src/integrations/base/query.ts.html +15 -9
  221. package/coverage/lcov-report/src/integrations/base/sql.ts.html +38 -38
  222. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +23 -23
  223. package/coverage/lcov-report/src/integrations/base/utils.ts.html +5 -5
  224. package/coverage/lcov-report/src/integrations/couchdb.ts.html +109 -31
  225. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +17 -17
  226. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +27 -15
  227. package/coverage/lcov-report/src/integrations/firebase.ts.html +12 -12
  228. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +42 -42
  229. package/coverage/lcov-report/src/integrations/index.html +130 -130
  230. package/coverage/lcov-report/src/integrations/index.ts.html +50 -62
  231. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +31 -31
  232. package/coverage/lcov-report/src/integrations/mongodb.ts.html +421 -289
  233. package/coverage/lcov-report/src/integrations/mysql.ts.html +28 -28
  234. package/coverage/lcov-report/src/integrations/oracle.ts.html +31 -31
  235. package/coverage/lcov-report/src/integrations/postgres.ts.html +54 -54
  236. package/coverage/lcov-report/src/integrations/queries/index.html +19 -19
  237. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +24 -159
  238. package/coverage/lcov-report/src/integrations/redis.ts.html +8 -8
  239. package/coverage/lcov-report/src/integrations/rest.ts.html +43 -52
  240. package/coverage/lcov-report/src/integrations/s3.ts.html +17 -17
  241. package/coverage/lcov-report/src/integrations/snowflake.ts.html +15 -15
  242. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +1 -1
  243. package/coverage/lcov-report/src/integrations/tests/index.html +1 -1
  244. package/coverage/lcov-report/src/integrations/utils.ts.html +54 -54
  245. package/coverage/lcov-report/src/middleware/appInfo.ts.html +11 -11
  246. package/coverage/lcov-report/src/middleware/authorized.ts.html +49 -37
  247. package/coverage/lcov-report/src/middleware/builder.ts.html +26 -26
  248. package/coverage/lcov-report/src/middleware/currentapp.ts.html +50 -47
  249. package/coverage/lcov-report/src/middleware/index.html +40 -40
  250. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +10 -10
  251. package/coverage/lcov-report/src/middleware/publicApi.ts.html +9 -9
  252. package/coverage/lcov-report/src/middleware/resourceId.ts.html +23 -23
  253. package/coverage/lcov-report/src/middleware/selfhost.ts.html +2 -2
  254. package/coverage/lcov-report/src/middleware/utils.ts.html +4 -4
  255. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +6 -6
  256. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +7 -7
  257. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +7 -7
  258. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +31 -31
  259. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +8 -8
  260. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +13 -13
  261. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +7 -7
  262. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +7 -7
  263. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +8 -8
  264. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +21 -21
  265. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +17 -14
  266. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +19 -19
  267. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +9 -9
  268. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +13 -13
  269. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +23 -23
  270. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +26 -26
  271. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +7 -7
  272. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +14 -14
  273. package/coverage/lcov-report/src/migrations/functions/index.html +18 -18
  274. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +8 -8
  275. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +11 -11
  276. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +11 -11
  277. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +3 -3
  278. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +6 -6
  279. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +8 -8
  280. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +7 -7
  281. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +4 -4
  282. package/coverage/lcov-report/src/migrations/index.html +15 -15
  283. package/coverage/lcov-report/src/migrations/index.ts.html +43 -43
  284. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +4 -4
  285. package/coverage/lcov-report/src/migrations/tests/index.html +6 -6
  286. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +3 -3
  287. package/coverage/lcov-report/src/sdk/app/applications/index.html +20 -20
  288. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +6 -6
  289. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +34 -34
  290. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +15 -15
  291. package/coverage/lcov-report/src/sdk/app/automations/index.html +7 -7
  292. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +5 -5
  293. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +8 -8
  294. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +5 -5
  295. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +30 -30
  296. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +45 -57
  297. package/coverage/lcov-report/src/sdk/app/backups/index.html +42 -42
  298. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +7 -7
  299. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +73 -73
  300. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +493 -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/{utilities/statusCodes.ts.html → sdk/app/queries/index.ts.html} +22 -28
  305. package/coverage/lcov-report/src/{definitions/datasource.ts.html → sdk/app/queries/queries.ts.html} +82 -82
  306. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +8 -8
  307. package/coverage/lcov-report/src/sdk/app/rows/index.html +8 -8
  308. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +6 -6
  309. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +4 -4
  310. package/coverage/lcov-report/src/sdk/app/tables/index.html +15 -15
  311. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +29 -20
  312. package/coverage/lcov-report/src/sdk/index.html +7 -7
  313. package/coverage/lcov-report/src/sdk/index.ts.html +24 -12
  314. package/coverage/lcov-report/src/sdk/users/index.html +10 -10
  315. package/coverage/lcov-report/src/sdk/users/index.ts.html +5 -5
  316. package/coverage/lcov-report/src/sdk/users/utils.ts.html +35 -35
  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 +48 -63
  320. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +218 -152
  321. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +20 -20
  322. package/coverage/lcov-report/src/tests/utilities/index.html +33 -33
  323. package/coverage/lcov-report/src/tests/utilities/index.ts.html +2 -2
  324. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +235 -46
  325. package/coverage/lcov-report/src/threads/automation.ts.html +212 -251
  326. package/coverage/lcov-report/src/threads/index.html +46 -46
  327. package/coverage/lcov-report/src/threads/index.ts.html +39 -39
  328. package/coverage/lcov-report/src/threads/query.ts.html +140 -101
  329. package/coverage/lcov-report/src/threads/utils.ts.html +29 -29
  330. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +5 -5
  331. package/coverage/lcov-report/src/utilities/centralPath.ts.html +11 -11
  332. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +343 -0
  333. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +20 -20
  334. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +601 -0
  335. package/coverage/lcov-report/src/utilities/fileSystem/index.html +88 -28
  336. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +20 -1049
  337. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +277 -0
  338. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +9 -9
  339. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +193 -0
  340. package/coverage/lcov-report/src/utilities/global.ts.html +60 -60
  341. package/coverage/lcov-report/src/utilities/index.html +89 -119
  342. package/coverage/lcov-report/src/utilities/index.ts.html +40 -172
  343. package/coverage/lcov-report/src/utilities/redis.ts.html +38 -38
  344. package/coverage/lcov-report/src/utilities/routing/index.html +1 -1
  345. package/coverage/lcov-report/src/utilities/routing/index.ts.html +5 -5
  346. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +34 -34
  347. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +102 -75
  348. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +9 -9
  349. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +54 -54
  350. package/coverage/lcov-report/src/utilities/{csvParser.ts.html → schema.ts.html} +174 -234
  351. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +33 -33
  352. package/coverage/lcov-report/src/utilities/security.ts.html +13 -13
  353. package/coverage/lcov-report/src/utilities/usageQuota/index.html +9 -9
  354. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +38 -38
  355. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +3 -3
  356. package/coverage/lcov-report/src/utilities/users.ts.html +7 -7
  357. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +89 -62
  358. package/coverage/lcov-report/src/watch.ts.html +20 -20
  359. package/coverage/lcov-report/src/websocket.ts.html +15 -15
  360. package/coverage/lcov.info +13499 -12800
  361. package/dist/api/controllers/application.js +120 -109
  362. package/dist/api/controllers/cloud.js +6 -2
  363. package/dist/api/controllers/datasource.js +24 -15
  364. package/dist/api/controllers/deploy/index.js +43 -60
  365. package/dist/api/controllers/plugin/index.js +6 -6
  366. package/dist/api/controllers/public/applications.js +22 -1
  367. package/dist/api/controllers/query/index.js +23 -13
  368. package/dist/api/controllers/row/ExternalRequest.js +12 -4
  369. package/dist/api/controllers/row/external.js +20 -13
  370. package/dist/api/controllers/row/internal.js +52 -27
  371. package/dist/api/controllers/row/staticFormula.js +1 -1
  372. package/dist/api/controllers/row/utils.js +35 -3
  373. package/dist/api/controllers/static/index.js +47 -47
  374. package/dist/api/controllers/static/templates/BudibaseApp.svelte +0 -1
  375. package/dist/api/controllers/table/external.js +16 -35
  376. package/dist/api/controllers/table/index.js +44 -15
  377. package/dist/api/controllers/table/internal.js +6 -7
  378. package/dist/api/controllers/table/utils.js +9 -9
  379. package/dist/api/controllers/user.js +14 -6
  380. package/dist/api/controllers/view/exporters.js +22 -6
  381. package/dist/api/controllers/view/index.js +23 -58
  382. package/dist/api/controllers/view/viewBuilder.js +15 -2
  383. package/dist/api/controllers/webhook.js +45 -43
  384. package/dist/api/routes/analytics.js +2 -1
  385. package/dist/api/routes/apikeys.js +2 -1
  386. package/dist/api/routes/application.js +5 -1
  387. package/dist/api/routes/auth.js +2 -1
  388. package/dist/api/routes/automation.js +2 -1
  389. package/dist/api/routes/backup.js +2 -1
  390. package/dist/api/routes/cloud.js +2 -1
  391. package/dist/api/routes/component.js +2 -1
  392. package/dist/api/routes/datasource.js +2 -1
  393. package/dist/api/routes/deploy.js +3 -3
  394. package/dist/api/routes/dev.js +2 -1
  395. package/dist/api/routes/index.js +2 -0
  396. package/dist/api/routes/integration.js +2 -1
  397. package/dist/api/routes/layout.js +2 -1
  398. package/dist/api/routes/metadata.js +2 -1
  399. package/dist/api/routes/migrations.js +2 -1
  400. package/dist/api/routes/permission.js +2 -1
  401. package/dist/api/routes/public/applications.js +37 -0
  402. package/dist/api/routes/public/middleware/mapper.js +3 -0
  403. package/dist/api/routes/query.js +2 -1
  404. package/dist/api/routes/role.js +2 -1
  405. package/dist/api/routes/routing.js +2 -1
  406. package/dist/api/routes/row.js +2 -2
  407. package/dist/api/routes/screen.js +2 -1
  408. package/dist/api/routes/script.js +2 -1
  409. package/dist/api/routes/static.js +6 -5
  410. package/dist/api/routes/table.js +8 -38
  411. package/dist/api/routes/templates.js +2 -1
  412. package/dist/api/routes/user.js +2 -1
  413. package/dist/api/routes/utils/validators.js +1 -1
  414. package/dist/api/routes/view.js +2 -1
  415. package/dist/api/routes/webhook.js +2 -1
  416. package/dist/app.js +9 -7
  417. package/dist/automations/automationUtils.js +26 -1
  418. package/dist/automations/logging/index.js +5 -25
  419. package/dist/automations/triggers.js +1 -0
  420. package/dist/db/index.js +5 -2
  421. package/dist/db/linkedRows/LinkController.js +2 -1
  422. package/dist/db/linkedRows/LinkDocument.js +2 -1
  423. package/dist/db/newid.js +4 -2
  424. package/dist/definitions/datasource.js +0 -6
  425. package/dist/environment.js +7 -2
  426. package/dist/events/AutomationEmitter.js +2 -1
  427. package/dist/events/BudibaseEmitter.js +2 -1
  428. package/dist/events/index.js +2 -1
  429. package/dist/index.js +2 -2
  430. package/dist/integrations/base/query.js +7 -2
  431. package/dist/integrations/base/sqlTable.js +14 -14
  432. package/dist/integrations/couchdb.js +34 -8
  433. package/dist/integrations/dynamodb.js +8 -5
  434. package/dist/integrations/elasticsearch.js +7 -3
  435. package/dist/integrations/googlesheets.js +1 -1
  436. package/dist/integrations/index.js +6 -7
  437. package/dist/integrations/mongodb.js +311 -271
  438. package/dist/integrations/mysql.js +2 -2
  439. package/dist/integrations/queries/sql.js +73 -100
  440. package/dist/integrations/rest.js +16 -18
  441. package/dist/middleware/authorized.js +2 -1
  442. package/dist/middleware/builder.js +4 -2
  443. package/dist/middleware/currentapp.js +6 -3
  444. package/dist/middleware/publicApi.js +4 -2
  445. package/dist/middleware/selfhost.js +4 -1
  446. package/dist/migrations/functions/backfill/global/configs.js +4 -4
  447. package/dist/package.json +12 -8
  448. package/dist/sdk/app/backups/imports.js +2 -6
  449. package/dist/sdk/app/datasources/datasources.js +147 -0
  450. package/dist/sdk/app/datasources/index.js +27 -0
  451. package/dist/sdk/app/queries/index.js +27 -0
  452. package/dist/sdk/app/queries/queries.js +60 -0
  453. package/dist/sdk/app/tables/index.js +6 -2
  454. package/dist/sdk/index.js +4 -0
  455. package/dist/sdk/utils/index.js +29 -0
  456. package/dist/startup.js +17 -17
  457. package/dist/threads/automation.js +22 -35
  458. package/dist/threads/index.js +4 -4
  459. package/dist/threads/query.js +27 -13
  460. package/dist/tsconfig.build.tsbuildinfo +1 -1
  461. package/dist/utilities/fileSystem/app.js +97 -0
  462. package/dist/utilities/fileSystem/clientLibrary.js +3 -3
  463. package/dist/utilities/fileSystem/filesystem.js +184 -0
  464. package/dist/utilities/fileSystem/index.js +18 -342
  465. package/dist/utilities/fileSystem/plugin.js +66 -0
  466. package/dist/utilities/fileSystem/template.js +47 -0
  467. package/dist/utilities/index.js +1 -44
  468. package/dist/utilities/rowProcessor/index.js +12 -4
  469. package/dist/utilities/schema.js +108 -0
  470. package/dist/utilities/scriptRunner.js +2 -1
  471. package/dist/utilities/statusCodes.js +2 -1
  472. package/dist/utilities/workerRequests.js +2 -0
  473. package/dist/watch.js +2 -25
  474. package/jest.config.ts +5 -2
  475. package/package.json +13 -9
  476. package/scripts/dev/manage.js +3 -2
  477. package/specs/openapi.json +84 -0
  478. package/specs/openapi.yaml +53 -0
  479. package/specs/resources/application.js +19 -0
  480. package/src/api/controllers/application.ts +142 -110
  481. package/src/api/controllers/auth.ts +2 -2
  482. package/src/api/controllers/cloud.ts +10 -6
  483. package/src/api/controllers/datasource.ts +33 -25
  484. package/src/api/controllers/deploy/Deployment.ts +1 -0
  485. package/src/api/controllers/deploy/index.ts +40 -58
  486. package/src/api/controllers/plugin/index.ts +14 -9
  487. package/src/api/controllers/public/applications.ts +17 -0
  488. package/src/api/controllers/query/index.ts +49 -41
  489. package/src/api/controllers/row/ExternalRequest.ts +8 -3
  490. package/src/api/controllers/row/external.ts +24 -14
  491. package/src/api/controllers/row/internal.ts +66 -41
  492. package/src/api/controllers/row/staticFormula.ts +5 -2
  493. package/src/api/controllers/row/utils.ts +42 -3
  494. package/src/api/controllers/static/index.ts +22 -27
  495. package/src/api/controllers/static/templates/BudibaseApp.svelte +0 -1
  496. package/src/api/controllers/table/external.ts +18 -16
  497. package/src/api/controllers/table/index.ts +46 -17
  498. package/src/api/controllers/table/internal.ts +6 -7
  499. package/src/api/controllers/table/utils.ts +12 -13
  500. package/src/api/controllers/user.ts +21 -13
  501. package/src/api/controllers/view/exporters.ts +20 -5
  502. package/src/api/controllers/view/index.ts +30 -42
  503. package/src/api/controllers/view/tests/viewBuilder.spec.js +1 -1
  504. package/src/api/controllers/view/viewBuilder.ts +1 -1
  505. package/src/api/controllers/webhook.ts +48 -46
  506. package/src/api/routes/analytics.ts +1 -1
  507. package/src/api/routes/apikeys.ts +1 -1
  508. package/src/api/routes/application.ts +12 -1
  509. package/src/api/routes/auth.ts +1 -1
  510. package/src/api/routes/automation.ts +1 -1
  511. package/src/api/routes/backup.ts +1 -1
  512. package/src/api/routes/cloud.ts +1 -1
  513. package/src/api/routes/component.ts +1 -1
  514. package/src/api/routes/datasource.ts +1 -1
  515. package/src/api/routes/deploy.ts +1 -2
  516. package/src/api/routes/dev.ts +1 -1
  517. package/src/api/routes/index.ts +6 -3
  518. package/src/api/routes/integration.ts +1 -1
  519. package/src/api/routes/layout.ts +1 -1
  520. package/src/api/routes/metadata.ts +1 -1
  521. package/src/api/routes/migrations.ts +1 -1
  522. package/src/api/routes/permission.ts +1 -1
  523. package/src/api/routes/public/applications.ts +44 -0
  524. package/src/api/routes/public/middleware/mapper.ts +4 -0
  525. package/src/api/routes/query.ts +1 -1
  526. package/src/api/routes/role.ts +1 -1
  527. package/src/api/routes/routing.ts +1 -1
  528. package/src/api/routes/row.ts +1 -1
  529. package/src/api/routes/screen.ts +1 -1
  530. package/src/api/routes/script.ts +1 -1
  531. package/src/api/routes/static.ts +2 -2
  532. package/src/api/routes/table.ts +16 -39
  533. package/src/api/routes/templates.ts +1 -1
  534. package/src/api/routes/tests/__snapshots__/{datasource.spec.js.snap → datasource.spec.ts.snap} +0 -0
  535. package/src/api/routes/tests/{application.spec.js → application.spec.ts} +94 -18
  536. package/src/api/routes/tests/{backup.spec.js → backup.spec.ts} +17 -6
  537. package/src/api/routes/tests/cloud.spec.ts +65 -0
  538. package/src/api/routes/tests/data/budibase-component-1.0.1.tgz +0 -0
  539. package/src/api/routes/tests/data/comment-box-1.0.2.tar.gz +0 -0
  540. package/src/api/routes/tests/data/export-test.tar.gz +0 -0
  541. package/src/api/routes/tests/{datasource.spec.js → datasource.spec.ts} +56 -14
  542. package/src/api/routes/tests/misc.spec.js +4 -10
  543. package/src/api/routes/tests/permissions.spec.js +1 -1
  544. package/src/api/routes/tests/plugin.spec.ts +179 -0
  545. package/src/api/routes/tests/routing.spec.js +1 -2
  546. package/src/api/routes/tests/row.spec.js +4 -2
  547. package/src/api/routes/tests/static.spec.js +2 -17
  548. package/src/api/routes/tests/table.spec.js +16 -32
  549. package/src/api/routes/tests/user.spec.js +105 -0
  550. package/src/api/routes/tests/utilities/TestFunctions.ts +1 -1
  551. package/src/api/routes/tests/utilities/index.ts +2 -2
  552. package/src/api/routes/tests/webhook.spec.js +1 -1
  553. package/src/api/routes/user.ts +1 -1
  554. package/src/api/routes/utils/validators.ts +1 -1
  555. package/src/api/routes/view.ts +1 -1
  556. package/src/api/routes/webhook.ts +1 -1
  557. package/src/app.ts +5 -3
  558. package/src/automations/automationUtils.ts +24 -0
  559. package/src/automations/logging/index.ts +1 -1
  560. package/src/automations/tests/bash.spec.js +34 -0
  561. package/src/automations/tests/discord.spec.js +27 -0
  562. package/src/automations/tests/executeQuery.spec.js +49 -0
  563. package/src/automations/tests/executeScript.spec.js +48 -0
  564. package/src/automations/tests/loop.spec.ts +45 -0
  565. package/src/automations/tests/sendSmtpEmail.spec.js +71 -0
  566. package/src/automations/tests/serverLog.spec.js +22 -0
  567. package/src/automations/tests/utilities/index.ts +2 -2
  568. package/src/automations/tests/zapier.spec.js +27 -0
  569. package/src/automations/triggers.ts +6 -1
  570. package/src/automations/unitTests/automationUtils.spec.ts +65 -0
  571. package/src/db/index.ts +1 -1
  572. package/src/db/linkedRows/LinkController.ts +1 -1
  573. package/src/db/linkedRows/LinkDocument.ts +1 -1
  574. package/src/db/newid.ts +1 -1
  575. package/src/db/tests/linkController.spec.js +1 -1
  576. package/src/definitions/automations.ts +1 -0
  577. package/src/definitions/datasource.ts +0 -41
  578. package/src/definitions/openapi.ts +10 -0
  579. package/src/environment.ts +6 -2
  580. package/src/events/AutomationEmitter.ts +1 -1
  581. package/src/events/BudibaseEmitter.ts +1 -1
  582. package/src/events/index.ts +1 -1
  583. package/src/index.ts +1 -1
  584. package/src/integrations/base/query.ts +3 -1
  585. package/src/integrations/base/sqlTable.ts +1 -1
  586. package/src/integrations/couchdb.ts +40 -14
  587. package/src/integrations/dynamodb.ts +3 -3
  588. package/src/integrations/elasticsearch.ts +8 -4
  589. package/src/integrations/googlesheets.ts +1 -1
  590. package/src/integrations/index.ts +5 -9
  591. package/src/integrations/mongodb.ts +315 -271
  592. package/src/integrations/mysql.ts +1 -1
  593. package/src/integrations/queries/sql.ts +5 -50
  594. package/src/integrations/rest.ts +16 -19
  595. package/src/integrations/tests/couchdb.spec.ts +33 -21
  596. package/src/integrations/tests/rest.spec.ts +19 -15
  597. package/src/middleware/authorized.ts +5 -1
  598. package/src/middleware/builder.ts +1 -1
  599. package/src/middleware/currentapp.ts +4 -3
  600. package/src/middleware/publicApi.ts +1 -1
  601. package/src/middleware/selfhost.ts +1 -1
  602. package/src/middleware/tests/authorized.spec.js +1 -1
  603. package/src/middleware/tests/currentapp.spec.js +1 -1
  604. package/src/middleware/tests/selfhost.spec.js +1 -1
  605. package/src/migrations/functions/backfill/global/configs.ts +5 -4
  606. package/src/migrations/functions/usageQuotas/tests/syncRows.spec.ts +10 -6
  607. package/src/sdk/app/backups/imports.ts +2 -6
  608. package/src/sdk/app/datasources/datasources.ts +136 -0
  609. package/src/sdk/app/datasources/index.ts +5 -0
  610. package/src/sdk/app/queries/index.ts +5 -0
  611. package/src/sdk/app/queries/queries.ts +50 -0
  612. package/src/sdk/app/tables/index.ts +6 -3
  613. package/src/sdk/index.ts +4 -0
  614. package/src/sdk/tests/attachments.spec.ts +1 -4
  615. package/src/sdk/utils/index.ts +16 -0
  616. package/src/startup.ts +3 -8
  617. package/src/tests/jestEnv.ts +13 -0
  618. package/src/tests/jestSetup.ts +4 -15
  619. package/src/tests/utilities/TestConfiguration.ts +38 -16
  620. package/src/tests/utilities/structures.ts +65 -2
  621. package/src/threads/automation.ts +22 -35
  622. package/src/threads/definitions.ts +3 -0
  623. package/src/threads/index.ts +1 -1
  624. package/src/threads/query.ts +28 -15
  625. package/src/utilities/fileSystem/app.ts +86 -0
  626. package/src/utilities/fileSystem/clientLibrary.ts +1 -1
  627. package/src/utilities/fileSystem/filesystem.ts +172 -0
  628. package/src/utilities/fileSystem/index.ts +5 -348
  629. package/src/utilities/fileSystem/plugin.ts +64 -0
  630. package/src/utilities/fileSystem/template.ts +36 -0
  631. package/src/utilities/index.ts +1 -45
  632. package/src/utilities/rowProcessor/index.ts +17 -8
  633. package/src/utilities/rowProcessor/tests/utils.spec.ts +57 -0
  634. package/src/utilities/schema.ts +141 -0
  635. package/src/utilities/scriptRunner.ts +1 -1
  636. package/src/utilities/statusCodes.ts +1 -1
  637. package/src/utilities/workerRequests.ts +10 -1
  638. package/src/watch.ts +1 -1
  639. package/tsconfig.build.json +2 -0
  640. package/tsconfig.json +2 -1
  641. package/builder/assets/index.96b9ffed.css +0 -6
  642. package/builder/assets/index.fae8f9eb.js +0 -1024
  643. package/coverage/lcov-report/src/utilities/plugins.ts.html +0 -151
  644. package/dist/api/routes/tests/utilities/TestFunctions.js +0 -167
  645. package/dist/api/routes/tests/utilities/index.js +0 -131
  646. package/dist/automations/tests/utilities/index.js +0 -81
  647. package/dist/tests/utilities/TestConfiguration.js +0 -562
  648. package/dist/tests/utilities/controllers.js +0 -40
  649. package/dist/tests/utilities/structures.js +0 -168
  650. package/dist/utilities/csvParser.js +0 -152
  651. package/dist/utilities/plugins.js +0 -26
  652. package/src/api/routes/tests/deployment.spec.ts +0 -25
  653. package/src/automations/unitTests/automationUtils.spec.js +0 -17
  654. package/src/utilities/csvParser.ts +0 -161
  655. package/src/utilities/plugins.ts +0 -22
  656. package/src/utilities/tests/__snapshots__/csvParser.spec.js.snap +0 -15
  657. package/src/utilities/tests/csvParser.spec.js +0 -112
@@ -92,7 +92,7 @@ describe("/permission", () => {
92
92
  describe("check public user allowed", () => {
93
93
  it("should be able to read the row", async () => {
94
94
  // replicate changes before checking permissions
95
- await config.deploy()
95
+ await config.publish()
96
96
 
97
97
  const res = await request
98
98
  .get(`/api/${table._id}/rows`)
@@ -0,0 +1,179 @@
1
+ jest.mock("@budibase/backend-core", () => {
2
+ const core = jest.requireActual("@budibase/backend-core")
3
+ return {
4
+ ...core,
5
+ objectStore: {
6
+ ...core.objectStore,
7
+ upload: jest.fn(),
8
+ uploadDirectory: jest.fn().mockImplementation(() => {
9
+ return [{ name: "test.js" }]
10
+ }),
11
+ deleteFolder: jest.fn().mockImplementation(),
12
+ },
13
+ }
14
+ })
15
+
16
+ import { events, objectStore } from "@budibase/backend-core"
17
+ import * as setup from "./utilities"
18
+
19
+ const mockUploadDirectory = objectStore.uploadDirectory as jest.Mock
20
+ const mockDeleteFolder = objectStore.deleteFolder as jest.Mock
21
+
22
+ describe("/plugins", () => {
23
+ let request = setup.getRequest()
24
+ let config = setup.getConfig()
25
+
26
+ afterAll(setup.afterAll)
27
+
28
+ beforeEach(async () => {
29
+ await config.init()
30
+ jest.clearAllMocks()
31
+ })
32
+
33
+ const createPlugin = async (status?: number) => {
34
+ return request
35
+ .post(`/api/plugin/upload`)
36
+ .attach("file", "src/api/routes/tests/data/comment-box-1.0.2.tar.gz")
37
+ .set(config.defaultHeaders())
38
+ .expect("Content-Type", /json/)
39
+ .expect(status ? status : 200)
40
+ }
41
+
42
+ const getPlugins = async (status?: number) => {
43
+ return request
44
+ .get(`/api/plugin`)
45
+ .set(config.defaultHeaders())
46
+ .expect("Content-Type", /json/)
47
+ .expect(status ? status : 200)
48
+ }
49
+
50
+ describe("upload", () => {
51
+ it("should be able to upload a plugin", async () => {
52
+ let res = await createPlugin()
53
+ expect(res.body).toBeDefined()
54
+ expect(res.body.plugins).toBeDefined()
55
+ expect(res.body.plugins[0]._id).toEqual("plg_comment-box")
56
+ expect(events.plugin.imported).toHaveBeenCalledTimes(1)
57
+ })
58
+
59
+ it("should not be able to create a plugin if there is an error", async () => {
60
+ mockUploadDirectory.mockImplementationOnce(() => {
61
+ throw new Error()
62
+ })
63
+ let res = await createPlugin(400)
64
+ expect(res.body.message).toEqual("Failed to import plugin: Error")
65
+ expect(events.plugin.imported).toHaveBeenCalledTimes(0)
66
+ })
67
+ })
68
+
69
+ describe("fetch", () => {
70
+ it("should be able to fetch plugins", async () => {
71
+ await createPlugin()
72
+ const res = await getPlugins()
73
+ expect(res.body).toBeDefined()
74
+ expect(res.body[0]._id).toEqual("plg_comment-box")
75
+ })
76
+ })
77
+
78
+ describe("destroy", () => {
79
+ it("should be able to delete a plugin", async () => {
80
+ await createPlugin()
81
+ const res = await request
82
+ .delete(`/api/plugin/plg_comment-box`)
83
+ .set(config.defaultHeaders())
84
+ .expect("Content-Type", /json/)
85
+ .expect(200)
86
+ expect(res.body).toBeDefined()
87
+ expect(res.body.message).toEqual("Plugin plg_comment-box deleted.")
88
+
89
+ const plugins = await getPlugins()
90
+ expect(plugins.body).toBeDefined()
91
+ expect(plugins.body.length).toEqual(0)
92
+ expect(events.plugin.deleted).toHaveBeenCalledTimes(1)
93
+ })
94
+ it("should handle an error deleting a plugin", async () => {
95
+ mockDeleteFolder.mockImplementationOnce(() => {
96
+ throw new Error()
97
+ })
98
+
99
+ await createPlugin()
100
+ const res = await request
101
+ .delete(`/api/plugin/plg_comment-box`)
102
+ .set(config.defaultHeaders())
103
+ .expect("Content-Type", /json/)
104
+ .expect(400)
105
+
106
+ expect(res.body.message).toEqual("Failed to delete plugin: Error")
107
+ expect(events.plugin.deleted).toHaveBeenCalledTimes(0)
108
+ const plugins = await getPlugins()
109
+ expect(plugins.body).toBeDefined()
110
+ expect(plugins.body.length).toEqual(1)
111
+ })
112
+ })
113
+
114
+ describe("github", () => {
115
+ const createGithubPlugin = async (status?: number, url?: string) => {
116
+ return await request
117
+ .post(`/api/plugin`)
118
+ .send({
119
+ source: "Github",
120
+ url,
121
+ githubToken: "token",
122
+ })
123
+ .set(config.defaultHeaders())
124
+ .expect("Content-Type", /json/)
125
+ .expect(status ? status : 200)
126
+ }
127
+ it("should be able to create a plugin from github", async () => {
128
+ const res = await createGithubPlugin(
129
+ 200,
130
+ "https://github.com/my-repo/budibase-comment-box.git"
131
+ )
132
+ expect(res.body).toBeDefined()
133
+ expect(res.body.plugin).toBeDefined()
134
+ expect(res.body.plugin._id).toEqual("plg_comment-box")
135
+ })
136
+ it("should fail if the url is not from github", async () => {
137
+ const res = await createGithubPlugin(
138
+ 400,
139
+ "https://notgithub.com/my-repo/budibase-comment-box"
140
+ )
141
+ expect(res.body.message).toEqual(
142
+ "Failed to import plugin: The plugin origin must be from Github"
143
+ )
144
+ })
145
+ })
146
+ describe("npm", () => {
147
+ it("should be able to create a plugin from npm", async () => {
148
+ const res = await request
149
+ .post(`/api/plugin`)
150
+ .send({
151
+ source: "NPM",
152
+ url: "https://www.npmjs.com/package/budibase-component",
153
+ })
154
+ .set(config.defaultHeaders())
155
+ .expect("Content-Type", /json/)
156
+ .expect(200)
157
+ expect(res.body).toBeDefined()
158
+ expect(res.body.plugin._id).toEqual("plg_budibase-component")
159
+ expect(events.plugin.imported).toHaveBeenCalled()
160
+ })
161
+ })
162
+
163
+ describe("url", () => {
164
+ it("should be able to create a plugin from a URL", async () => {
165
+ const res = await request
166
+ .post(`/api/plugin`)
167
+ .send({
168
+ source: "URL",
169
+ url: "https://www.someurl.com/comment-box/comment-box-1.0.2.tar.gz",
170
+ })
171
+ .set(config.defaultHeaders())
172
+ .expect("Content-Type", /json/)
173
+ .expect(200)
174
+ expect(res.body).toBeDefined()
175
+ expect(res.body.plugin._id).toEqual("plg_comment-box")
176
+ expect(events.plugin.imported).toHaveBeenCalledTimes(1)
177
+ })
178
+ })
179
+ })
@@ -9,7 +9,6 @@ const route = "/test"
9
9
  // there are checks which are disabled in test env,
10
10
  // these checks need to be enabled for this test
11
11
 
12
-
13
12
  describe("/routing", () => {
14
13
  let request = setup.getRequest()
15
14
  let config = setup.getConfig()
@@ -26,7 +25,7 @@ describe("/routing", () => {
26
25
  screen2.routing.roleId = BUILTIN_ROLE_IDS.POWER
27
26
  screen2.routing.route = route
28
27
  screen2 = await config.createScreen(screen2)
29
- await config.deploy()
28
+ await config.publish()
30
29
  })
31
30
 
32
31
  describe("fetch", () => {
@@ -10,6 +10,7 @@ const {
10
10
  StaticQuotaName,
11
11
  MonthlyQuotaName,
12
12
  } = require("@budibase/types")
13
+ const { structures } = require("@budibase/backend-core/tests");
13
14
 
14
15
  describe("/rows", () => {
15
16
  let request = setup.getRequest()
@@ -494,12 +495,13 @@ describe("/rows", () => {
494
495
  describe("attachments", () => {
495
496
  it("should allow enriching attachment rows", async () => {
496
497
  const table = await config.createAttachmentTable()
498
+ const attachmentId = `${structures.uuid()}.csv`
497
499
  const row = await config.createRow({
498
500
  name: "test",
499
501
  description: "test",
500
502
  attachment: [
501
503
  {
502
- key: `${config.getAppId()}/attachments/test/thing.csv`,
504
+ key: `${config.getAppId()}/attachments/${attachmentId}`,
503
505
  },
504
506
  ],
505
507
  tableId: table._id,
@@ -509,7 +511,7 @@ describe("/rows", () => {
509
511
  context.doInAppContext(config.getAppId(), async () => {
510
512
  const enriched = await outputProcessing(table, [row])
511
513
  expect(enriched[0].attachment[0].url).toBe(
512
- `/prod-budi-app-assets/${config.getAppId()}/attachments/test/thing.csv`
514
+ `/files/signed/prod-budi-app-assets/${config.getProdAppId()}/attachments/${attachmentId}`
513
515
  )
514
516
  })
515
517
  })
@@ -1,20 +1,5 @@
1
- jest.mock("node-fetch")
2
- jest.mock("aws-sdk", () => ({
3
- config: {
4
- update: jest.fn(),
5
- },
6
- DynamoDB: {
7
- DocumentClient: jest.fn(),
8
- },
9
- S3: jest.fn(() => ({
10
- getSignedUrl: jest.fn(() => {
11
- return "my-url"
12
- }),
13
- })),
14
- }))
15
-
16
1
  const setup = require("./utilities")
17
- const { events, constants } = require("@budibase/backend-core")
2
+ const { constants } = require("@budibase/backend-core")
18
3
 
19
4
  describe("/static", () => {
20
5
  let request = setup.getRequest()
@@ -102,7 +87,7 @@ describe("/static", () => {
102
87
  .set(config.defaultHeaders())
103
88
  .expect("Content-Type", /json/)
104
89
  .expect(200)
105
- expect(res.body.signedUrl).toEqual("my-url")
90
+ expect(res.body.signedUrl).toEqual("http://test.com/foo/bar")
106
91
  expect(res.body.publicUrl).toEqual(
107
92
  `https://${bucket}.s3.eu-west-1.amazonaws.com/${key}`
108
93
  )
@@ -43,21 +43,18 @@ describe("/tables", () => {
43
43
  expect(events.table.created).toBeCalledWith(res.body)
44
44
  })
45
45
 
46
- it("creates a table via data import CSV", async () => {
46
+ it("creates a table via data import", async () => {
47
47
  const table = basicTable()
48
- table.dataImport = {
49
- csvString: "\"name\",\"description\"\n\"test-name\",\"test-desc\"",
50
- }
51
- table.dataImport.schema = table.schema
48
+ table.rows = [{ name: 'test-name', description: 'test-desc' }]
52
49
 
53
50
  const res = await createTable(table)
54
-
51
+
55
52
  expect(events.table.created).toBeCalledTimes(1)
56
53
  expect(events.table.created).toBeCalledWith(res.body)
57
54
  expect(events.table.imported).toBeCalledTimes(1)
58
- expect(events.table.imported).toBeCalledWith(res.body, "csv")
55
+ expect(events.table.imported).toBeCalledWith(res.body)
59
56
  expect(events.rows.imported).toBeCalledTimes(1)
60
- expect(events.rows.imported).toBeCalledWith(res.body, "csv", 1)
57
+ expect(events.rows.imported).toBeCalledWith(res.body, 1)
61
58
  })
62
59
 
63
60
  it("should apply authorization to endpoint", async () => {
@@ -87,6 +84,12 @@ describe("/tables", () => {
87
84
 
88
85
  it("updates all the row fields for a table when a schema key is renamed", async () => {
89
86
  const testTable = await config.createTable()
87
+ await config.createView({
88
+ name: "TestView",
89
+ field: "Price",
90
+ calculation: "stats",
91
+ tableId: testTable._id,
92
+ })
90
93
 
91
94
  const testRow = await request
92
95
  .post(`/api/${testTable._id}/rows`)
@@ -109,7 +112,7 @@ describe("/tables", () => {
109
112
  updated: "updatedName"
110
113
  },
111
114
  schema: {
112
- updatedName: {type: "string"}
115
+ updatedName: { type: "string" }
113
116
  }
114
117
  })
115
118
  .set(config.defaultHeaders())
@@ -149,11 +152,10 @@ describe("/tables", () => {
149
152
  it("imports rows successfully", async () => {
150
153
  const table = await config.createTable()
151
154
  const importRequest = {
152
- dataImport: {
153
- csvString: "\"name\",\"description\"\n\"test-name\",\"test-desc\"",
154
- schema: table.schema
155
- }
155
+ schema: table.schema,
156
+ rows: [{ name: 'test-name', description: 'test-desc' }]
156
157
  }
158
+
157
159
  jest.clearAllMocks()
158
160
 
159
161
  await request
@@ -165,7 +167,7 @@ describe("/tables", () => {
165
167
 
166
168
  expect(events.table.created).not.toHaveBeenCalled()
167
169
  expect(events.rows.imported).toBeCalledTimes(1)
168
- expect(events.rows.imported).toBeCalledWith(table, "csv", 1)
170
+ expect(events.rows.imported).toBeCalledWith(table, 1)
169
171
  })
170
172
  })
171
173
 
@@ -200,24 +202,6 @@ describe("/tables", () => {
200
202
  })
201
203
  })
202
204
 
203
- describe("validate csv", () => {
204
- it("should be able to validate a CSV layout", async () => {
205
- const res = await request
206
- .post(`/api/tables/csv/validate`)
207
- .send({
208
- csvString: "a,b,c,d\n1,2,3,4"
209
- })
210
- .set(config.defaultHeaders())
211
- .expect('Content-Type', /json/)
212
- .expect(200)
213
- expect(res.body.schema).toBeDefined()
214
- expect(res.body.schema.a).toEqual({
215
- type: "string",
216
- success: true,
217
- })
218
- })
219
- })
220
-
221
205
  describe("indexing", () => {
222
206
  it("should be able to create a table with indexes", async () => {
223
207
  await context.doInAppContext(appId, async () => {
@@ -90,4 +90,109 @@ describe("/users", () => {
90
90
  expect(res.body.tableId).toBeDefined()
91
91
  })
92
92
  })
93
+ describe("setFlag", () => {
94
+ it("should throw an error if a flag is not provided", async () => {
95
+ await config.createUser()
96
+ const res = await request
97
+ .post(`/api/users/flags`)
98
+ .set(config.defaultHeaders())
99
+ .send({ value: "test" })
100
+ .expect(400)
101
+ .expect("Content-Type", /json/)
102
+ expect(res.body.message).toEqual("Must supply a 'flag' field in request body.")
103
+
104
+ })
105
+
106
+ it("should be able to set a flag on the user", async () => {
107
+ await config.createUser()
108
+ const res = await request
109
+ .post(`/api/users/flags`)
110
+ .set(config.defaultHeaders())
111
+ .send({ value: "test", flag: "test" })
112
+ .expect(200)
113
+ .expect("Content-Type", /json/)
114
+ expect(res.body.message).toEqual("Flag set successfully")
115
+ })
116
+ })
117
+
118
+ describe("getFlags", () => {
119
+ it("should get flags for a specific user", async () => {
120
+ let flagData = { value: "test", flag: "test" }
121
+ await config.createUser()
122
+ await request
123
+ .post(`/api/users/flags`)
124
+ .set(config.defaultHeaders())
125
+ .send(flagData)
126
+ .expect(200)
127
+ .expect("Content-Type", /json/)
128
+
129
+ const res = await request
130
+ .get(`/api/users/flags`)
131
+ .set(config.defaultHeaders())
132
+ .expect(200)
133
+ .expect("Content-Type", /json/)
134
+ expect(res.body[flagData.value]).toEqual(flagData.flag)
135
+ })
136
+ })
137
+
138
+ describe("setFlag", () => {
139
+ it("should throw an error if a flag is not provided", async () => {
140
+ await config.createUser()
141
+ const res = await request
142
+ .post(`/api/users/flags`)
143
+ .set(config.defaultHeaders())
144
+ .send({ value: "test" })
145
+ .expect(400)
146
+ .expect("Content-Type", /json/)
147
+ expect(res.body.message).toEqual("Must supply a 'flag' field in request body.")
148
+
149
+ })
150
+
151
+ it("should be able to set a flag on the user", async () => {
152
+ await config.createUser()
153
+ const res = await request
154
+ .post(`/api/users/flags`)
155
+ .set(config.defaultHeaders())
156
+ .send({ value: "test", flag: "test" })
157
+ .expect(200)
158
+ .expect("Content-Type", /json/)
159
+ expect(res.body.message).toEqual("Flag set successfully")
160
+ })
161
+ })
162
+
163
+ describe("syncUser", () => {
164
+ it("should sync the user", async () => {
165
+ let user = await config.createUser()
166
+ await config.createApp('New App')
167
+ let res = await request
168
+ .post(`/api/users/metadata/sync/${user._id}`)
169
+ .set(config.defaultHeaders())
170
+ .expect(200)
171
+ .expect("Content-Type", /json/)
172
+ expect(res.body.message).toEqual('User synced.')
173
+ })
174
+
175
+
176
+ it("should sync the user when a previous user is specified", async () => {
177
+ const app1 = await config.createApp('App 1')
178
+ const app2 = await config.createApp('App 2')
179
+
180
+ let user = await config.createUser(
181
+ undefined,
182
+ undefined,
183
+ undefined,
184
+ undefined,
185
+ false,
186
+ true,
187
+ { [app1.appId]: 'ADMIN' })
188
+ let res = await request
189
+ .post(`/api/users/metadata/sync/${user._id}`)
190
+ .set(config.defaultHeaders())
191
+ .send({ previousUser: { ...user, roles: { ...user.roles, [app2.appId]: 'BASIC' } } })
192
+ .expect(200)
193
+ .expect("Content-Type", /json/)
194
+
195
+ expect(res.body.message).toEqual('User synced.')
196
+ })
197
+ })
93
198
  })
@@ -3,7 +3,7 @@ import * as appController from "../../../controllers/application"
3
3
  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
- import * as env from "../../../../environment"
6
+ import env from "../../../../environment"
7
7
 
8
8
  class Request {
9
9
  appId: any
@@ -63,14 +63,14 @@ export function afterAll() {
63
63
 
64
64
  export function getRequest() {
65
65
  if (!request) {
66
- exports.beforeAll()
66
+ beforeAll()
67
67
  }
68
68
  return request
69
69
  }
70
70
 
71
71
  export function getConfig() {
72
72
  if (!config) {
73
- exports.beforeAll()
73
+ beforeAll()
74
74
  }
75
75
  return config
76
76
  }
@@ -113,7 +113,7 @@ describe("/webhooks", () => {
113
113
  describe("trigger", () => {
114
114
  it("should allow triggering from public", async () => {
115
115
  // replicate changes before checking webhook
116
- await config.deploy()
116
+ await config.publish()
117
117
 
118
118
  const res = await request
119
119
  .post(`/api/webhooks/trigger/${config.prodAppId}/${webhook._id}`)
@@ -48,4 +48,4 @@ router
48
48
  controller.getFlags
49
49
  )
50
50
 
51
- export = router
51
+ export default router
@@ -18,7 +18,7 @@ export function tableValidator() {
18
18
  schema: Joi.object().required(),
19
19
  name: Joi.string().required(),
20
20
  views: Joi.object(),
21
- dataImport: Joi.object(),
21
+ rows: Joi.array(),
22
22
  }).unknown(true))
23
23
  }
24
24
 
@@ -31,4 +31,4 @@ router
31
31
  )
32
32
  .post("/api/views", authorized(permissions.BUILDER), viewController.save)
33
33
 
34
- export = router
34
+ export default router
@@ -24,4 +24,4 @@ router
24
24
  // this shouldn't have authorisation, right now its always public
25
25
  .post("/api/webhooks/trigger/:instance/:id", controller.trigger)
26
26
 
27
- export = router
27
+ export default router
package/src/app.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  // need to load environment first
2
- import * as env from "./environment"
2
+ import env from "./environment"
3
3
 
4
4
  // enable APM if configured
5
5
  if (process.env.ELASTIC_APM_ENABLED) {
@@ -19,7 +19,7 @@ import * as api from "./api"
19
19
  import * as automations from "./automations"
20
20
  import { Thread } from "./threads"
21
21
  import * as redis from "./utilities/redis"
22
- import { events, logging } from "@budibase/backend-core"
22
+ import { events, logging, middleware } from "@budibase/backend-core"
23
23
  import { initialise as initialiseWebsockets } from "./websocket"
24
24
  import { startup } from "./startup"
25
25
  const Sentry = require("@sentry/node")
@@ -40,6 +40,8 @@ app.use(
40
40
  })
41
41
  )
42
42
 
43
+ app.use(middleware.logging)
44
+
43
45
  if (env.isProd()) {
44
46
  env._set("NODE_ENV", "production")
45
47
  Sentry.init()
@@ -77,7 +79,7 @@ server.on("close", async () => {
77
79
  }
78
80
  })
79
81
 
80
- export = server.listen(env.PORT || 0, async () => {
82
+ export default server.listen(env.PORT || 0, async () => {
81
83
  await startup(app, server)
82
84
  })
83
85
 
@@ -5,6 +5,7 @@ import {
5
5
  } from "@budibase/string-templates"
6
6
  import sdk from "../sdk"
7
7
  import { Row } from "@budibase/types"
8
+ import { LoopStep, LoopStepType, LoopInput } from "../definitions/automations"
8
9
 
9
10
  /**
10
11
  * When values are input to the system generally they will be of type string as this is required for template strings.
@@ -133,3 +134,26 @@ export function stringSplit(value: string | string[]) {
133
134
  }
134
135
  return value
135
136
  }
137
+
138
+ export function typecastForLooping(loopStep: LoopStep, input: LoopInput) {
139
+ if (!input || !input.binding) {
140
+ return null
141
+ }
142
+ try {
143
+ switch (loopStep.inputs.option) {
144
+ case LoopStepType.ARRAY:
145
+ if (typeof input.binding === "string") {
146
+ return JSON.parse(input.binding)
147
+ }
148
+ break
149
+ case LoopStepType.STRING:
150
+ if (Array.isArray(input.binding)) {
151
+ return input.binding.join(",")
152
+ }
153
+ break
154
+ }
155
+ } catch (err) {
156
+ throw new Error("Unable to cast to correct type")
157
+ }
158
+ return input.binding
159
+ }
@@ -1,4 +1,4 @@
1
- import * as env from "../../environment"
1
+ import env from "../../environment"
2
2
  import { AutomationResults, Automation, App } from "@budibase/types"
3
3
  import { automations } from "@budibase/pro"
4
4
  import { db as dbUtils } from "@budibase/backend-core"
@@ -0,0 +1,34 @@
1
+ const setup = require("./utilities")
2
+
3
+ describe("test the bash action", () => {
4
+ let config = setup.getConfig()
5
+
6
+ beforeEach(async () => {
7
+ await config.init()
8
+ })
9
+ afterAll(setup.afterAll)
10
+
11
+ it("should be able to execute a script", async () => {
12
+
13
+ let res = await setup.runStep("EXECUTE_BASH",
14
+ inputs = {
15
+ code: "echo 'test'"
16
+ }
17
+
18
+ )
19
+ expect(res.stdout).toEqual("test\n")
20
+ expect(res.success).toEqual(true)
21
+ })
22
+
23
+ it("should handle a null value", async () => {
24
+
25
+ let res = await setup.runStep("EXECUTE_BASH",
26
+ inputs = {
27
+ code: null
28
+ }
29
+
30
+
31
+ )
32
+ expect(res.stdout).toEqual("Budibase bash automation failed: Invalid inputs")
33
+ })
34
+ })