@budibase/server 2.3.17 → 2.3.18-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 (463) hide show
  1. package/__mocks__/aws-sdk.ts +1 -1
  2. package/builder/assets/{index.4488f38d.css → index.7e76c039.css} +1 -1
  3. package/builder/assets/{index.06e34d35.js → index.e7d5703a.js} +361 -361
  4. package/builder/index.html +2 -2
  5. package/dist/api/controllers/query/index.js +2 -0
  6. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  7. package/dist/api/controllers/row/external.js +12 -1
  8. package/dist/api/controllers/row/staticFormula.js +5 -1
  9. package/dist/api/controllers/table/external.js +8 -8
  10. package/dist/api/index.js +1 -21
  11. package/dist/app.js +7 -1
  12. package/dist/constants/index.js +4 -24
  13. package/dist/db/defaultData/datasource_bb_default.js +6 -5
  14. package/dist/db/linkedRows/LinkController.js +9 -8
  15. package/dist/ddApm.js +11 -0
  16. package/dist/elasticApm.js +14 -0
  17. package/dist/integrations/base/sql.js +10 -3
  18. package/dist/package.json +11 -7
  19. package/dist/sdk/app/backups/exports.js +8 -2
  20. package/dist/sdk/app/datasources/datasources.js +3 -0
  21. package/dist/tsconfig.build.tsbuildinfo +1 -1
  22. package/dist/utilities/retry.js +30 -0
  23. package/jest-testcontainers-config.js +8 -0
  24. package/jest.config.ts +28 -11
  25. package/package.json +12 -8
  26. package/scripts/load/create-many-apps.js +24 -0
  27. package/scripts/load/create-many-rows.js +30 -0
  28. package/scripts/load/utils.js +66 -0
  29. package/specs/openapi.json +6 -6
  30. package/specs/openapi.yaml +3 -3
  31. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  32. package/src/api/controllers/query/index.ts +2 -0
  33. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  34. package/src/api/controllers/row/external.ts +13 -1
  35. package/src/api/controllers/row/staticFormula.ts +7 -1
  36. package/src/api/controllers/table/external.ts +3 -2
  37. package/src/api/index.ts +3 -22
  38. package/src/api/routes/public/applications.ts +0 -1
  39. package/src/api/routes/public/tests/compare.spec.js +1 -1
  40. package/src/api/routes/public/tests/users.spec.js +1 -1
  41. package/src/api/routes/public/tests/utils.ts +25 -8
  42. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  43. package/src/api/routes/tests/analytics.spec.js +4 -1
  44. package/src/api/routes/tests/apikeys.spec.js +1 -1
  45. package/src/api/routes/tests/application.spec.ts +20 -6
  46. package/src/api/routes/tests/auth.spec.js +2 -2
  47. package/src/api/routes/tests/automation.spec.js +6 -2
  48. package/src/api/routes/tests/backup.spec.ts +4 -14
  49. package/src/api/routes/tests/{cloud.spec.ts → cloud.seq.spec.ts} +11 -15
  50. package/src/api/routes/tests/component.spec.js +1 -1
  51. package/src/api/routes/tests/datasource.spec.ts +20 -3
  52. package/src/api/routes/tests/dev.spec.js +1 -1
  53. package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
  54. package/src/api/routes/tests/integration.spec.js +1 -1
  55. package/src/api/routes/tests/layout.spec.js +1 -1
  56. package/src/api/routes/tests/metadata.spec.js +1 -1
  57. package/src/api/routes/tests/misc.spec.js +1 -1
  58. package/src/api/routes/tests/permissions.spec.js +4 -1
  59. package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
  60. package/src/api/routes/tests/role.spec.js +6 -1
  61. package/src/api/routes/tests/routing.spec.js +1 -1
  62. package/src/api/routes/tests/row.spec.js +11 -3
  63. package/src/api/routes/tests/screen.spec.js +1 -1
  64. package/src/api/routes/tests/static.spec.js +2 -1
  65. package/src/api/routes/tests/table.spec.js +1 -1
  66. package/src/api/routes/tests/templates.spec.js +1 -1
  67. package/src/api/routes/tests/user.spec.js +12 -12
  68. package/src/api/routes/tests/utilities/TestFunctions.ts +25 -2
  69. package/src/api/routes/tests/utilities/index.ts +5 -3
  70. package/src/api/routes/tests/view.spec.js +4 -1
  71. package/src/api/routes/tests/webhook.spec.js +11 -2
  72. package/src/app.ts +10 -1
  73. package/src/automations/tests/automation.spec.js +4 -4
  74. package/src/automations/tests/bash.spec.js +1 -1
  75. package/src/automations/tests/discord.spec.js +1 -1
  76. package/src/automations/tests/executeQuery.spec.js +2 -3
  77. package/src/automations/tests/executeScript.spec.js +1 -1
  78. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  79. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  80. package/src/automations/tests/serverLog.spec.js +1 -1
  81. package/src/automations/tests/updateRow.spec.js +1 -1
  82. package/src/automations/tests/zapier.spec.js +1 -1
  83. package/src/constants/index.ts +1 -23
  84. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  85. package/src/db/linkedRows/LinkController.ts +2 -1
  86. package/src/db/tests/linkController.spec.js +4 -1
  87. package/src/db/tests/linkTests.spec.js +1 -1
  88. package/src/ddApm.ts +7 -0
  89. package/src/elasticApm.ts +10 -0
  90. package/src/integration-test/postgres.spec.ts +762 -0
  91. package/src/integrations/base/sql.ts +15 -5
  92. package/src/integrations/oracle.ts +1 -1
  93. package/src/integrations/tests/couchdb.spec.ts +0 -2
  94. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  95. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  96. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  97. package/src/migrations/tests/index.spec.ts +13 -20
  98. package/src/sdk/app/backups/exports.ts +8 -2
  99. package/src/sdk/app/datasources/datasources.ts +3 -0
  100. package/src/tests/jestEnv.ts +8 -11
  101. package/src/tests/jestSetup.ts +9 -7
  102. package/src/tests/logging.ts +34 -0
  103. package/src/tests/utilities/TestConfiguration.ts +166 -92
  104. package/src/tests/utilities/structures.ts +16 -2
  105. package/src/utilities/retry.ts +18 -0
  106. package/tsconfig.build.json +1 -0
  107. package/coverage/clover.xml +0 -11771
  108. package/coverage/coverage-final.json +0 -284
  109. package/coverage/lcov-report/base.css +0 -224
  110. package/coverage/lcov-report/block-navigation.js +0 -87
  111. package/coverage/lcov-report/favicon.png +0 -0
  112. package/coverage/lcov-report/index.html +0 -1031
  113. package/coverage/lcov-report/prettify.css +0 -1
  114. package/coverage/lcov-report/prettify.js +0 -2
  115. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  116. package/coverage/lcov-report/sorter.js +0 -196
  117. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
  118. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
  119. package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
  120. package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
  121. package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
  122. package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
  123. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
  124. package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
  125. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
  126. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
  127. package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
  128. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
  129. package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
  130. package/coverage/lcov-report/src/api/controllers/index.html +0 -431
  131. package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
  132. package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
  133. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
  134. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
  135. package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
  136. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
  137. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
  138. package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
  139. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
  140. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
  141. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
  142. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
  143. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
  144. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
  145. package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
  146. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
  147. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
  148. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
  149. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
  150. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
  151. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
  152. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
  153. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
  154. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
  155. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
  156. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
  157. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
  158. package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
  159. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
  160. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
  161. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
  162. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
  163. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
  164. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
  165. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
  166. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
  167. package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
  168. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
  169. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
  170. package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
  171. package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
  172. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
  173. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
  174. package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
  175. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
  176. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
  177. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
  178. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -577
  179. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
  180. package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
  181. package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
  182. package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
  183. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
  184. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
  185. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
  186. package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
  187. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
  188. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
  189. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
  190. package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
  191. package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
  192. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
  193. package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
  194. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
  195. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
  196. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
  197. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
  198. package/coverage/lcov-report/src/api/index.html +0 -116
  199. package/coverage/lcov-report/src/api/index.ts.html +0 -352
  200. package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
  201. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
  202. package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
  203. package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
  204. package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
  205. package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
  206. package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
  207. package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
  208. package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
  209. package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
  210. package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
  211. package/coverage/lcov-report/src/api/routes/index.html +0 -551
  212. package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
  213. package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
  214. package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
  215. package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
  216. package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
  217. package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
  218. package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
  219. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
  220. package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
  221. package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
  222. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
  223. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
  224. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
  225. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
  226. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
  227. package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
  228. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
  229. package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
  230. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
  231. package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
  232. package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
  233. package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
  234. package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
  235. package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
  236. package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
  237. package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
  238. package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
  239. package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
  240. package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
  241. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
  242. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
  243. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
  244. package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
  245. package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
  246. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
  247. package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
  248. package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
  249. package/coverage/lcov-report/src/app.ts.html +0 -424
  250. package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
  251. package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
  252. package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
  253. package/coverage/lcov-report/src/automations/index.html +0 -191
  254. package/coverage/lcov-report/src/automations/index.ts.html +0 -163
  255. package/coverage/lcov-report/src/automations/logging/index.html +0 -116
  256. package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
  257. package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
  258. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
  259. package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
  260. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
  261. package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -397
  262. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
  263. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
  264. package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
  265. package/coverage/lcov-report/src/automations/steps/index.html +0 -371
  266. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -409
  267. package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
  268. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
  269. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
  270. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
  271. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
  272. package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -340
  273. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
  274. package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
  275. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -403
  276. package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
  277. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
  278. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
  279. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
  280. package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
  281. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
  282. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
  283. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
  284. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
  285. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
  286. package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
  287. package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
  288. package/coverage/lcov-report/src/constants/index.html +0 -146
  289. package/coverage/lcov-report/src/constants/index.ts.html +0 -697
  290. package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
  291. package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
  292. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
  293. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
  294. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
  295. package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
  296. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
  297. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
  298. package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
  299. package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
  300. package/coverage/lcov-report/src/db/index.html +0 -176
  301. package/coverage/lcov-report/src/db/index.ts.html +0 -133
  302. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
  303. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
  304. package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
  305. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
  306. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
  307. package/coverage/lcov-report/src/db/newid.ts.html +0 -100
  308. package/coverage/lcov-report/src/db/utils.ts.html +0 -913
  309. package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
  310. package/coverage/lcov-report/src/definitions/index.html +0 -116
  311. package/coverage/lcov-report/src/environment.ts.html +0 -472
  312. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
  313. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
  314. package/coverage/lcov-report/src/events/index.html +0 -161
  315. package/coverage/lcov-report/src/events/index.ts.html +0 -100
  316. package/coverage/lcov-report/src/events/utils.ts.html +0 -319
  317. package/coverage/lcov-report/src/index.html +0 -191
  318. package/coverage/lcov-report/src/index.ts.html +0 -133
  319. package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
  320. package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
  321. package/coverage/lcov-report/src/integrations/base/index.html +0 -161
  322. package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
  323. package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
  324. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
  325. package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
  326. package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
  327. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
  328. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
  329. package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
  330. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
  331. package/coverage/lcov-report/src/integrations/index.html +0 -371
  332. package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
  333. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
  334. package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
  335. package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
  336. package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
  337. package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
  338. package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
  339. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
  340. package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
  341. package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
  342. package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
  343. package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
  344. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
  345. package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
  346. package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
  347. package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
  348. package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
  349. package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
  350. package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
  351. package/coverage/lcov-report/src/middleware/index.html +0 -236
  352. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
  353. package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
  354. package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
  355. package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
  356. package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
  357. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
  358. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
  359. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
  360. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
  361. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
  362. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
  363. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
  364. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
  365. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
  366. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
  367. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
  368. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
  369. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
  370. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
  371. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
  372. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
  373. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
  374. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
  375. package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
  376. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
  377. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
  378. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
  379. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
  380. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
  381. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
  382. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
  383. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
  384. package/coverage/lcov-report/src/migrations/index.html +0 -116
  385. package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
  386. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
  387. package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
  388. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
  389. package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
  390. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
  391. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
  392. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
  393. package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
  394. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
  395. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
  396. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
  397. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
  398. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
  399. package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
  400. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
  401. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
  402. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
  403. package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
  404. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
  405. package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
  406. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
  407. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
  408. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
  409. package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
  410. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
  411. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
  412. package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
  413. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
  414. package/coverage/lcov-report/src/sdk/index.html +0 -116
  415. package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
  416. package/coverage/lcov-report/src/sdk/users/index.html +0 -131
  417. package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
  418. package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
  419. package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
  420. package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
  421. package/coverage/lcov-report/src/startup.ts.html +0 -484
  422. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
  423. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
  424. package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
  425. package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
  426. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
  427. package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
  428. package/coverage/lcov-report/src/threads/index.html +0 -161
  429. package/coverage/lcov-report/src/threads/index.ts.html +0 -418
  430. package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
  431. package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
  432. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
  433. package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
  434. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  435. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
  436. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
  437. package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
  438. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
  439. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
  440. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
  441. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  442. package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
  443. package/coverage/lcov-report/src/utilities/index.html +0 -251
  444. package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
  445. package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
  446. package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
  447. package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
  448. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
  449. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
  450. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
  451. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
  452. package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
  453. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
  454. package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
  455. package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
  456. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
  457. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
  458. package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
  459. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
  460. package/coverage/lcov-report/src/watch.ts.html +0 -196
  461. package/coverage/lcov-report/src/websocket.ts.html +0 -163
  462. package/coverage/lcov.info +0 -21770
  463. package/dist/api/routes/public/tests/utils.js +0 -33
@@ -1,3 +1,8 @@
1
+ const tk = require( "timekeeper")
2
+ const timestamp = new Date("2023-01-26T11:48:57.597Z").toISOString()
3
+ tk.freeze(timestamp)
4
+
5
+
1
6
  const { outputProcessing } = require("../../../utilities/rowProcessor")
2
7
  const setup = require("./utilities")
3
8
  const { basicRow } = setup.structures
@@ -20,8 +25,11 @@ describe("/rows", () => {
20
25
 
21
26
  afterAll(setup.afterAll)
22
27
 
23
- beforeEach(async () => {
28
+ beforeAll(async () => {
24
29
  await config.init()
30
+ })
31
+
32
+ beforeEach(async()=>{
25
33
  table = await config.createTable()
26
34
  row = basicRow(table._id)
27
35
  })
@@ -111,8 +119,8 @@ describe("/rows", () => {
111
119
  _id: existing._id,
112
120
  _rev: existing._rev,
113
121
  type: "row",
114
- createdAt: "2020-01-01T00:00:00.000Z",
115
- updatedAt: "2020-01-01T00:00:00.000Z",
122
+ createdAt: timestamp,
123
+ updatedAt: timestamp,
116
124
  })
117
125
  await assertQueryUsage(queryUsage + 1)
118
126
  })
@@ -10,7 +10,7 @@ describe("/screens", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  await config.init()
15
15
  screen = await config.createScreen()
16
16
  })
@@ -8,7 +8,8 @@ describe("/static", () => {
8
8
 
9
9
  afterAll(setup.afterAll)
10
10
 
11
- beforeEach(async () => {
11
+ beforeAll(async () => {
12
+ config.modeSelf()
12
13
  app = await config.init()
13
14
  })
14
15
 
@@ -10,7 +10,7 @@ describe("/tables", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  const app = await config.init()
15
15
  appId = app.appId
16
16
  })
@@ -6,7 +6,7 @@ describe("/templates", () => {
6
6
 
7
7
  afterAll(setup.afterAll)
8
8
 
9
- beforeEach(async () => {
9
+ beforeAll(async () => {
10
10
  await config.init()
11
11
  })
12
12
 
@@ -1,8 +1,10 @@
1
- const { roles } = require("@budibase/backend-core")
1
+ const { roles, utils } = require("@budibase/backend-core")
2
2
  const { checkPermissionsEndpoint } = require("./utilities/TestFunctions")
3
3
  const setup = require("./utilities")
4
4
  const { BUILTIN_ROLE_IDS } = roles
5
5
 
6
+ jest.setTimeout(30000)
7
+
6
8
  jest.mock("../../../utilities/workerRequests", () => ({
7
9
  getGlobalUsers: jest.fn(() => {
8
10
  return {}
@@ -19,14 +21,15 @@ describe("/users", () => {
19
21
 
20
22
  afterAll(setup.afterAll)
21
23
 
24
+ // For some reason this cannot be a beforeAll or the test "should be able to update the user" fail
22
25
  beforeEach(async () => {
23
26
  await config.init()
24
27
  })
25
28
 
26
29
  describe("fetch", () => {
27
30
  it("returns a list of users from an instance db", async () => {
28
- await config.createUser("uuidx")
29
- await config.createUser("uuidy")
31
+ await config.createUser({ id: "uuidx" })
32
+ await config.createUser({ id: "uuidy" })
30
33
  const res = await request
31
34
  .get(`/api/users/metadata`)
32
35
  .set(config.defaultHeaders())
@@ -53,7 +56,7 @@ describe("/users", () => {
53
56
 
54
57
  describe("update", () => {
55
58
  it("should be able to update the user", async () => {
56
- const user = await config.createUser()
59
+ const user = await config.createUser({ id: `us_update${Math.random()}` })
57
60
  user.roleId = BUILTIN_ROLE_IDS.BASIC
58
61
  const res = await request
59
62
  .put(`/api/users/metadata`)
@@ -177,14 +180,11 @@ describe("/users", () => {
177
180
  const app1 = await config.createApp('App 1')
178
181
  const app2 = await config.createApp('App 2')
179
182
 
180
- let user = await config.createUser(
181
- undefined,
182
- undefined,
183
- undefined,
184
- undefined,
185
- false,
186
- true,
187
- { [app1.appId]: 'ADMIN' })
183
+ let user = await config.createUser({
184
+ builder: false,
185
+ admin: true,
186
+ roles: { [app1.appId]: 'ADMIN' }
187
+ })
188
188
  let res = await request
189
189
  .post(`/api/users/metadata/sync/${user._id}`)
190
190
  .set(config.defaultHeaders())
@@ -4,6 +4,8 @@ import { AppStatus } from "../../../../db/utils"
4
4
  import { roles, tenancy, context } from "@budibase/backend-core"
5
5
  import { TENANT_ID } from "../../../../tests/utilities/structures"
6
6
  import env from "../../../../environment"
7
+ import { db } from "@budibase/backend-core"
8
+ import Nano from "@budibase/nano"
7
9
 
8
10
  class Request {
9
11
  appId: any
@@ -30,7 +32,10 @@ export const getAllTableRows = async (config: any) => {
30
32
  return req.body
31
33
  }
32
34
 
33
- export const clearAllApps = async (tenantId = TENANT_ID) => {
35
+ export const clearAllApps = async (
36
+ tenantId = TENANT_ID,
37
+ exceptions: Array<string> = []
38
+ ) => {
34
39
  await tenancy.doInTenant(tenantId, async () => {
35
40
  const req: any = { query: { status: AppStatus.DEV }, user: { tenantId } }
36
41
  await appController.fetch(req)
@@ -38,7 +43,7 @@ export const clearAllApps = async (tenantId = TENANT_ID) => {
38
43
  if (!apps || apps.length <= 0) {
39
44
  return
40
45
  }
41
- for (let app of apps) {
46
+ for (let app of apps.filter((x: any) => !exceptions.includes(x.appId))) {
42
47
  const { appId } = app
43
48
  const req = new Request(null, { appId })
44
49
  await runRequest(appId, appController.destroy, req)
@@ -55,6 +60,24 @@ export const clearAllAutomations = async (config: any) => {
55
60
  }
56
61
  }
57
62
 
63
+ export const wipeDb = async () => {
64
+ const couchInfo = db.getCouchInfo()
65
+ const nano = Nano({
66
+ url: couchInfo.url,
67
+ requestDefaults: {
68
+ headers: {
69
+ Authorization: couchInfo.cookie,
70
+ },
71
+ },
72
+ parseUrl: false,
73
+ })
74
+ let dbs
75
+ do {
76
+ dbs = await nano.db.list()
77
+ await Promise.all(dbs.map(x => nano.db.destroy(x)))
78
+ } while (dbs.length)
79
+ }
80
+
58
81
  export const createRequest = (
59
82
  request: any,
60
83
  method: any,
@@ -1,5 +1,6 @@
1
1
  import TestConfig from "../../../../tests/utilities/TestConfiguration"
2
2
  import env from "../../../../environment"
3
+ import supertest from "supertest"
3
4
  export * as structures from "../../../../tests/utilities/structures"
4
5
 
5
6
  function user() {
@@ -44,7 +45,8 @@ export function delay(ms: number) {
44
45
  return new Promise(resolve => setTimeout(resolve, ms))
45
46
  }
46
47
 
47
- let request: any, config: any
48
+ let request: supertest.SuperTest<supertest.Test> | undefined | null,
49
+ config: TestConfig | null
48
50
 
49
51
  export function beforeAll() {
50
52
  config = new TestConfig()
@@ -65,14 +67,14 @@ export function getRequest() {
65
67
  if (!request) {
66
68
  beforeAll()
67
69
  }
68
- return request
70
+ return request!
69
71
  }
70
72
 
71
73
  export function getConfig() {
72
74
  if (!config) {
73
75
  beforeAll()
74
76
  }
75
- return config
77
+ return config!
76
78
  }
77
79
 
78
80
  export async function switchToSelfHosted(func: any) {
@@ -28,8 +28,11 @@ describe("/views", () => {
28
28
 
29
29
  afterAll(setup.afterAll)
30
30
 
31
- beforeEach(async () => {
31
+ beforeAll(async () => {
32
32
  await config.init()
33
+ })
34
+
35
+ beforeEach(async() => {
33
36
  table = await config.createTable(priceTable())
34
37
  })
35
38
 
@@ -9,7 +9,8 @@ describe("/webhooks", () => {
9
9
 
10
10
  afterAll(setup.afterAll)
11
11
 
12
- beforeEach(async () => {
12
+ const setupTest = async () => {
13
+ config.modeSelf()
13
14
  await config.init()
14
15
  const autoConfig = basicAutomation()
15
16
  autoConfig.definition.trigger = {
@@ -18,7 +19,9 @@ describe("/webhooks", () => {
18
19
  }
19
20
  await config.createAutomation(autoConfig)
20
21
  webhook = await config.createWebhook()
21
- })
22
+ }
23
+
24
+ beforeAll(setupTest)
22
25
 
23
26
  describe("create", () => {
24
27
  it("should create a webhook successfully", async () => {
@@ -44,6 +47,8 @@ describe("/webhooks", () => {
44
47
  })
45
48
 
46
49
  describe("fetch", () => {
50
+ beforeAll(setupTest)
51
+
47
52
  it("returns the correct routing for basic user", async () => {
48
53
  const res = await request
49
54
  .get(`/api/webhooks`)
@@ -64,6 +69,8 @@ describe("/webhooks", () => {
64
69
  })
65
70
 
66
71
  describe("delete", () => {
72
+ beforeAll(setupTest)
73
+
67
74
  it("should successfully delete", async () => {
68
75
  const res = await request
69
76
  .delete(`/api/webhooks/${webhook._id}/${webhook._rev}`)
@@ -84,6 +91,8 @@ describe("/webhooks", () => {
84
91
  })
85
92
 
86
93
  describe("build schema", () => {
94
+ beforeAll(setupTest)
95
+
87
96
  it("should allow building a schema", async () => {
88
97
  const res = await request
89
98
  .post(`/api/webhooks/schema/${config.getAppId()}/${webhook._id}`)
package/src/app.ts CHANGED
@@ -1,3 +1,11 @@
1
+ if (process.env.DD_APM_ENABLED) {
2
+ require("./ddApm")
3
+ }
4
+
5
+ if (process.env.ELASTIC_APM_ENABLED) {
6
+ require("./elasticApm")
7
+ }
8
+
1
9
  // need to load environment first
2
10
  import env from "./environment"
3
11
 
@@ -66,6 +74,7 @@ initialiseWebsockets(server)
66
74
 
67
75
  let shuttingDown = false,
68
76
  errCode = 0
77
+
69
78
  server.on("close", async () => {
70
79
  // already in process
71
80
  if (shuttingDown) {
@@ -75,7 +84,7 @@ server.on("close", async () => {
75
84
  console.log("Server Closed")
76
85
  await automations.shutdown()
77
86
  await redis.shutdown()
78
- await events.shutdown()
87
+ events.shutdown()
79
88
  await Thread.shutdown()
80
89
  api.shutdown()
81
90
  if (!env.isTest()) {
@@ -21,7 +21,7 @@ const setup = require("./utilities")
21
21
  describe("Run through some parts of the automations system", () => {
22
22
  let config = setup.getConfig()
23
23
 
24
- beforeEach(async () => {
24
+ beforeAll(async () => {
25
25
  await automation.init()
26
26
  await config.init()
27
27
  })
@@ -29,9 +29,9 @@ describe("Run through some parts of the automations system", () => {
29
29
  afterAll(setup.afterAll)
30
30
 
31
31
  it("should be able to init in builder", async () => {
32
- await triggers.externalTrigger(basicAutomation(), { a: 1, appId: "app_123" })
33
- await wait(100)
34
- expect(thread.execute).toHaveBeenCalled()
32
+ await triggers.externalTrigger(basicAutomation(), { a: 1, appId: config.appId })
33
+ await wait(100)
34
+ expect(thread.execute).toHaveBeenCalled()
35
35
  })
36
36
 
37
37
  it("should check coercion", async () => {
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the bash action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeEach(async () => {
6
+ beforeAll(async () => {
7
7
  await config.init()
8
8
  })
9
9
  afterAll(setup.afterAll)
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  username: "joe_bloggs",
@@ -1,10 +1,9 @@
1
1
  const setup = require("./utilities")
2
2
 
3
3
  describe("test the execute query action", () => {
4
- let datasource
5
4
  let config = setup.getConfig()
6
5
 
7
- beforeEach(async () => {
6
+ beforeAll(async () => {
8
7
  await config.init()
9
8
 
10
9
  await config.createDatasource()
@@ -41,7 +40,7 @@ describe("test the execute query action", () => {
41
40
  query: { queryId: "wrong_id" }
42
41
  }
43
42
  )
44
- expect(res.response).toEqual('{"status":404,"name":"not_found","message":"missing","reason":"missing"}')
43
+ expect(res.response).toEqual('Error: missing')
45
44
  expect(res.success).toEqual(false)
46
45
  })
47
46
 
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the execute script action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeEach(async () => {
6
+ beforeAll(async () => {
7
7
  await config.init()
8
8
  })
9
9
  afterAll(setup.afterAll)
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  requestMethod: "POST",
@@ -36,7 +36,7 @@ const setup = require("./utilities")
36
36
  describe("test the outgoing webhook action", () => {
37
37
  let inputs
38
38
  let config = setup.getConfig()
39
- beforeEach(async () => {
39
+ beforeAll(async () => {
40
40
  await config.init()
41
41
  })
42
42
 
@@ -3,7 +3,7 @@ const setup = require("./utilities")
3
3
  describe("test the server log action", () => {
4
4
  let config = setup.getConfig()
5
5
 
6
- beforeEach(async () => {
6
+ beforeAll(async () => {
7
7
  await config.init()
8
8
  inputs = {
9
9
  text: "log message",
@@ -4,7 +4,7 @@ describe("test the update row action", () => {
4
4
  let table, row, inputs
5
5
  let config = setup.getConfig()
6
6
 
7
- beforeEach(async () => {
7
+ beforeAll(async () => {
8
8
  await config.init()
9
9
  table = await config.createTable()
10
10
  row = await config.createRow()
@@ -7,7 +7,7 @@ describe("test the outgoing webhook action", () => {
7
7
  let inputs
8
8
  let config = setup.getConfig()
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  inputs = {
13
13
  value1: "test",
@@ -1,4 +1,5 @@
1
1
  import { objectStore, roles, constants } from "@budibase/backend-core"
2
+ export { FieldType as FieldTypes, RelationshipTypes } from "@budibase/types"
2
3
 
3
4
  export enum FilterTypes {
4
5
  STRING = "string",
@@ -22,23 +23,6 @@ export const NoEmptyFilterStrings = [
22
23
  FilterTypes.NOT_CONTAINS,
23
24
  ]
24
25
 
25
- export enum FieldTypes {
26
- STRING = "string",
27
- BARCODEQR = "barcodeqr",
28
- LONGFORM = "longform",
29
- OPTIONS = "options",
30
- NUMBER = "number",
31
- BOOLEAN = "boolean",
32
- ARRAY = "array",
33
- DATETIME = "datetime",
34
- ATTACHMENT = "attachment",
35
- LINK = "link",
36
- FORMULA = "formula",
37
- AUTO = "auto",
38
- JSON = "json",
39
- INTERNAL = "internal",
40
- }
41
-
42
26
  export const CanSwitchTypes = [
43
27
  [exports.FieldTypes.JSON, exports.FieldTypes.ARRAY],
44
28
  [
@@ -54,12 +38,6 @@ export const SwitchableTypes = CanSwitchTypes.reduce((prev, current) =>
54
38
  prev ? prev.concat(current) : current
55
39
  )
56
40
 
57
- export enum RelationshipTypes {
58
- ONE_TO_MANY = "one-to-many",
59
- MANY_TO_ONE = "many-to-one",
60
- MANY_TO_MANY = "many-to-many",
61
- }
62
-
63
41
  export enum FormulaTypes {
64
42
  STATIC = "static",
65
43
  DYNAMIC = "dynamic",
@@ -1,8 +1,4 @@
1
- import {
2
- FieldTypes,
3
- AutoFieldSubTypes,
4
- RelationshipTypes,
5
- } from "../../constants"
1
+ import { FieldTypes, AutoFieldSubTypes } from "../../constants"
6
2
  import { importToRows } from "../../api/controllers/table/utils"
7
3
  import { cloneDeep } from "lodash/fp"
8
4
  import LinkDocument from "../linkedRows/LinkDocument"
@@ -11,7 +7,7 @@ import { employeeImport } from "./employeeImport"
11
7
  import { jobsImport } from "./jobsImport"
12
8
  import { expensesImport } from "./expensesImport"
13
9
  import { db as dbCore } from "@budibase/backend-core"
14
- import { Table, Row } from "@budibase/types"
10
+ import { Table, Row, RelationshipTypes } from "@budibase/types"
15
11
 
16
12
  export const DEFAULT_JOBS_TABLE_ID = "ta_bb_jobs"
17
13
  export const DEFAULT_INVENTORY_TABLE_ID = "ta_bb_inventory"
@@ -190,7 +186,7 @@ export const DEFAULT_INVENTORY_TABLE_SCHEMA: Table = {
190
186
  },
191
187
  }
192
188
 
193
- export const DEFAULT_EMPLOYEE_TABLE_SCHEMA = {
189
+ export const DEFAULT_EMPLOYEE_TABLE_SCHEMA: Table = {
194
190
  _id: DEFAULT_EMPLOYEE_TABLE_ID,
195
191
  type: "internal",
196
192
  views: {},
@@ -287,7 +283,7 @@ export const DEFAULT_EMPLOYEE_TABLE_SCHEMA = {
287
283
  sortable: false,
288
284
  },
289
285
  "Badge Photo": {
290
- type: "attachment",
286
+ type: FieldTypes.ATTACHMENT,
291
287
  constraints: {
292
288
  type: FieldTypes.ARRAY,
293
289
  presence: false,
@@ -466,7 +462,7 @@ export const DEFAULT_JOBS_TABLE_SCHEMA: Table = {
466
462
  // sortable: true,
467
463
  },
468
464
  "Works End": {
469
- type: "datetime",
465
+ type: FieldTypes.DATETIME,
470
466
  constraints: {
471
467
  type: "string",
472
468
  length: {},
@@ -480,7 +476,7 @@ export const DEFAULT_JOBS_TABLE_SCHEMA: Table = {
480
476
  ignoreTimezones: true,
481
477
  },
482
478
  "Updated Price": {
483
- type: "number",
479
+ type: FieldTypes.NUMBER,
484
480
  constraints: {
485
481
  type: "number",
486
482
  presence: false,
@@ -1,13 +1,14 @@
1
1
  import { IncludeDocs, getLinkDocuments } from "./linkUtils"
2
2
  import { InternalTables, getUserMetadataParams } from "../utils"
3
3
  import Sentry from "@sentry/node"
4
- import { FieldTypes, RelationshipTypes } from "../../constants"
4
+ import { FieldTypes } from "../../constants"
5
5
  import { context } from "@budibase/backend-core"
6
6
  import LinkDocument from "./LinkDocument"
7
7
  import {
8
8
  Database,
9
9
  FieldSchema,
10
10
  LinkDocumentValue,
11
+ RelationshipTypes,
11
12
  Row,
12
13
  Table,
13
14
  } from "@budibase/types"
@@ -9,9 +9,12 @@ describe("test the link controller", () => {
9
9
  let config = new TestConfig(false)
10
10
  let table1, table2, appId
11
11
 
12
- beforeEach(async () => {
12
+ beforeAll(async () => {
13
13
  const app = await config.init()
14
14
  appId = app.appId
15
+ })
16
+
17
+ beforeEach(async () => {
15
18
  const { _id } = await config.createTable()
16
19
  table2 = await config.createLinkedTable(RelationshipTypes.MANY_TO_MANY, ["link", "link2"])
17
20
  // update table after creating link
@@ -9,7 +9,7 @@ describe("test link functionality", () => {
9
9
 
10
10
  describe("getLinkedTable", () => {
11
11
  let table
12
- beforeEach(async () => {
12
+ beforeAll(async () => {
13
13
  const app = await config.init()
14
14
  appId = app.appId
15
15
  table = await config.createTable()
package/src/ddApm.ts ADDED
@@ -0,0 +1,7 @@
1
+ import apm from "dd-trace"
2
+
3
+ // enable APM if configured
4
+ if (process.env.DD_APM_ENABLED) {
5
+ console.log("Starting dd-trace")
6
+ apm.init()
7
+ }
@@ -0,0 +1,10 @@
1
+ import apm from "elastic-apm-node"
2
+
3
+ // enable APM if configured
4
+ if (process.env.ELASTIC_APM_ENABLED) {
5
+ console.log("Starting elastic-apm-node")
6
+ apm.start({
7
+ serviceName: process.env.SERVICE,
8
+ environment: process.env.BUDIBASE_ENVIRONMENT,
9
+ })
10
+ }