@budibase/server 2.3.15 → 2.3.17-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 (458) 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.e88df740.js → index.e8838b62.js} +364 -364
  4. package/builder/index.html +2 -2
  5. package/dist/api/controllers/query/index.js +2 -0
  6. package/dist/api/controllers/row/ExternalRequest.js +4 -2
  7. package/dist/api/controllers/row/external.js +12 -1
  8. package/dist/api/controllers/table/external.js +8 -8
  9. package/dist/api/routes/public/tests/utils.js +29 -2
  10. package/dist/api/routes/tests/utilities/index.js +131 -0
  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 +9 -6
  19. package/dist/sdk/app/backups/exports.js +8 -2
  20. package/dist/sdk/app/datasources/datasources.js +3 -0
  21. package/dist/tests/utilities/TestConfiguration.js +626 -0
  22. package/dist/tests/utilities/controllers.js +40 -0
  23. package/dist/tests/utilities/structures.js +234 -0
  24. package/dist/tsconfig.build.tsbuildinfo +1 -1
  25. package/dist/utilities/retry.js +30 -0
  26. package/jest-testcontainers-config.js +8 -0
  27. package/jest.config.ts +28 -11
  28. package/package.json +10 -7
  29. package/scripts/load/create-many-apps.js +24 -0
  30. package/scripts/load/create-many-rows.js +30 -0
  31. package/scripts/load/utils.js +66 -0
  32. package/src/api/controllers/query/import/tests/index.spec.js +1 -1
  33. package/src/api/controllers/query/index.ts +2 -0
  34. package/src/api/controllers/row/ExternalRequest.ts +6 -2
  35. package/src/api/controllers/row/external.ts +13 -1
  36. package/src/api/controllers/table/external.ts +3 -2
  37. package/src/api/routes/public/applications.ts +0 -1
  38. package/src/api/routes/public/tests/compare.spec.js +1 -1
  39. package/src/api/routes/public/tests/users.spec.js +1 -1
  40. package/src/api/routes/public/tests/utils.ts +25 -8
  41. package/src/api/routes/tests/__snapshots__/datasource.spec.ts.snap +1 -1
  42. package/src/api/routes/tests/analytics.spec.js +4 -1
  43. package/src/api/routes/tests/apikeys.spec.js +1 -1
  44. package/src/api/routes/tests/application.spec.ts +20 -6
  45. package/src/api/routes/tests/auth.spec.js +2 -2
  46. package/src/api/routes/tests/automation.spec.js +6 -2
  47. package/src/api/routes/tests/backup.spec.ts +4 -13
  48. package/src/api/routes/tests/{cloud.spec.ts → cloud.seq.spec.ts} +11 -15
  49. package/src/api/routes/tests/component.spec.js +1 -1
  50. package/src/api/routes/tests/datasource.spec.ts +20 -3
  51. package/src/api/routes/tests/dev.spec.js +1 -1
  52. package/src/api/routes/tests/environmentVariables.spec.ts +144 -0
  53. package/src/api/routes/tests/integration.spec.js +1 -1
  54. package/src/api/routes/tests/layout.spec.js +1 -1
  55. package/src/api/routes/tests/metadata.spec.js +1 -1
  56. package/src/api/routes/tests/misc.spec.js +1 -1
  57. package/src/api/routes/tests/permissions.spec.js +4 -1
  58. package/src/api/routes/tests/{query.spec.js → query.seq.spec.js} +22 -1
  59. package/src/api/routes/tests/role.spec.js +6 -1
  60. package/src/api/routes/tests/routing.spec.js +1 -1
  61. package/src/api/routes/tests/row.spec.js +11 -3
  62. package/src/api/routes/tests/screen.spec.js +1 -1
  63. package/src/api/routes/tests/static.spec.js +2 -1
  64. package/src/api/routes/tests/table.spec.js +1 -1
  65. package/src/api/routes/tests/templates.spec.js +1 -1
  66. package/src/api/routes/tests/user.spec.js +12 -12
  67. package/src/api/routes/tests/utilities/TestFunctions.ts +25 -2
  68. package/src/api/routes/tests/utilities/index.ts +5 -3
  69. package/src/api/routes/tests/view.spec.js +4 -1
  70. package/src/api/routes/tests/webhook.spec.js +11 -2
  71. package/src/app.ts +10 -1
  72. package/src/automations/tests/automation.spec.js +4 -4
  73. package/src/automations/tests/bash.spec.js +1 -1
  74. package/src/automations/tests/discord.spec.js +1 -1
  75. package/src/automations/tests/executeQuery.spec.js +2 -3
  76. package/src/automations/tests/executeScript.spec.js +1 -1
  77. package/src/automations/tests/outgoingWebhook.spec.js +1 -1
  78. package/src/automations/tests/sendSmtpEmail.spec.js +1 -1
  79. package/src/automations/tests/serverLog.spec.js +1 -1
  80. package/src/automations/tests/updateRow.spec.js +1 -1
  81. package/src/automations/tests/zapier.spec.js +1 -1
  82. package/src/constants/index.ts +1 -23
  83. package/src/db/defaultData/datasource_bb_default.ts +6 -10
  84. package/src/db/linkedRows/LinkController.ts +2 -1
  85. package/src/db/tests/linkController.spec.js +4 -1
  86. package/src/db/tests/linkTests.spec.js +1 -1
  87. package/src/ddApm.ts +7 -0
  88. package/src/elasticApm.ts +10 -0
  89. package/src/integration-test/postgres.spec.ts +752 -0
  90. package/src/integrations/base/sql.ts +15 -5
  91. package/src/integrations/oracle.ts +1 -1
  92. package/src/migrations/functions/tests/appUrls.spec.js +1 -1
  93. package/src/migrations/functions/tests/syncQuotas.spec.js +1 -1
  94. package/src/migrations/functions/tests/userEmailViewCasing.spec.js +1 -1
  95. package/src/migrations/tests/index.spec.ts +13 -20
  96. package/src/sdk/app/backups/exports.ts +8 -2
  97. package/src/sdk/app/datasources/datasources.ts +3 -0
  98. package/src/tests/jestEnv.ts +2 -6
  99. package/src/tests/jestSetup.ts +8 -7
  100. package/src/tests/utilities/TestConfiguration.ts +126 -50
  101. package/src/tests/utilities/structures.ts +16 -2
  102. package/src/utilities/retry.ts +18 -0
  103. package/coverage/clover.xml +0 -11755
  104. package/coverage/coverage-final.json +0 -284
  105. package/coverage/lcov-report/base.css +0 -224
  106. package/coverage/lcov-report/block-navigation.js +0 -87
  107. package/coverage/lcov-report/favicon.png +0 -0
  108. package/coverage/lcov-report/index.html +0 -1031
  109. package/coverage/lcov-report/prettify.css +0 -1
  110. package/coverage/lcov-report/prettify.js +0 -2
  111. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  112. package/coverage/lcov-report/sorter.js +0 -196
  113. package/coverage/lcov-report/src/api/controllers/analytics.ts.html +0 -190
  114. package/coverage/lcov-report/src/api/controllers/apikeys.ts.html +0 -247
  115. package/coverage/lcov-report/src/api/controllers/application.ts.html +0 -1987
  116. package/coverage/lcov-report/src/api/controllers/auth.ts.html +0 -301
  117. package/coverage/lcov-report/src/api/controllers/automation.ts.html +0 -940
  118. package/coverage/lcov-report/src/api/controllers/backup.ts.html +0 -148
  119. package/coverage/lcov-report/src/api/controllers/cloud.ts.html +0 -442
  120. package/coverage/lcov-report/src/api/controllers/component.ts.html +0 -259
  121. package/coverage/lcov-report/src/api/controllers/datasource.ts.html +0 -1135
  122. package/coverage/lcov-report/src/api/controllers/deploy/Deployment.ts.html +0 -262
  123. package/coverage/lcov-report/src/api/controllers/deploy/index.html +0 -131
  124. package/coverage/lcov-report/src/api/controllers/deploy/index.ts.html +0 -694
  125. package/coverage/lcov-report/src/api/controllers/dev.ts.html +0 -472
  126. package/coverage/lcov-report/src/api/controllers/index.html +0 -431
  127. package/coverage/lcov-report/src/api/controllers/integration.ts.html +0 -124
  128. package/coverage/lcov-report/src/api/controllers/layout.ts.html +0 -226
  129. package/coverage/lcov-report/src/api/controllers/metadata.ts.html +0 -211
  130. package/coverage/lcov-report/src/api/controllers/migrations.ts.html +0 -127
  131. package/coverage/lcov-report/src/api/controllers/permission.ts.html +0 -619
  132. package/coverage/lcov-report/src/api/controllers/plugin/file.ts.html +0 -130
  133. package/coverage/lcov-report/src/api/controllers/plugin/github.ts.html +0 -310
  134. package/coverage/lcov-report/src/api/controllers/plugin/index.html +0 -206
  135. package/coverage/lcov-report/src/api/controllers/plugin/index.ts.html +0 -499
  136. package/coverage/lcov-report/src/api/controllers/plugin/npm.ts.html +0 -253
  137. package/coverage/lcov-report/src/api/controllers/plugin/uploaders.ts.html +0 -97
  138. package/coverage/lcov-report/src/api/controllers/plugin/url.ts.html +0 -121
  139. package/coverage/lcov-report/src/api/controllers/plugin/utils.ts.html +0 -136
  140. package/coverage/lcov-report/src/api/controllers/public/applications.ts.html +0 -385
  141. package/coverage/lcov-report/src/api/controllers/public/index.html +0 -191
  142. package/coverage/lcov-report/src/api/controllers/public/mapping/applications.ts.html +0 -181
  143. package/coverage/lcov-report/src/api/controllers/public/mapping/index.html +0 -191
  144. package/coverage/lcov-report/src/api/controllers/public/mapping/index.ts.html +0 -124
  145. package/coverage/lcov-report/src/api/controllers/public/mapping/queries.ts.html +0 -202
  146. package/coverage/lcov-report/src/api/controllers/public/mapping/rows.ts.html +0 -178
  147. package/coverage/lcov-report/src/api/controllers/public/mapping/tables.ts.html +0 -163
  148. package/coverage/lcov-report/src/api/controllers/public/mapping/users.ts.html +0 -181
  149. package/coverage/lcov-report/src/api/controllers/public/queries.ts.html +0 -145
  150. package/coverage/lcov-report/src/api/controllers/public/rows.ts.html +0 -328
  151. package/coverage/lcov-report/src/api/controllers/public/tables.ts.html +0 -253
  152. package/coverage/lcov-report/src/api/controllers/public/users.ts.html +0 -325
  153. package/coverage/lcov-report/src/api/controllers/public/utils.ts.html +0 -220
  154. package/coverage/lcov-report/src/api/controllers/query/import/index.html +0 -116
  155. package/coverage/lcov-report/src/api/controllers/query/import/index.ts.html +0 -373
  156. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.html +0 -131
  157. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/index.ts.html +0 -379
  158. package/coverage/lcov-report/src/api/controllers/query/import/sources/base/openapi.ts.html +0 -157
  159. package/coverage/lcov-report/src/api/controllers/query/import/sources/curl.ts.html +0 -403
  160. package/coverage/lcov-report/src/api/controllers/query/import/sources/index.html +0 -146
  161. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi2.ts.html +0 -586
  162. package/coverage/lcov-report/src/api/controllers/query/import/sources/openapi3.ts.html +0 -712
  163. package/coverage/lcov-report/src/api/controllers/query/index.html +0 -131
  164. package/coverage/lcov-report/src/api/controllers/query/index.ts.html +0 -1000
  165. package/coverage/lcov-report/src/api/controllers/query/validation.ts.html +0 -235
  166. package/coverage/lcov-report/src/api/controllers/role.ts.html +0 -397
  167. package/coverage/lcov-report/src/api/controllers/routing.ts.html +0 -370
  168. package/coverage/lcov-report/src/api/controllers/row/ExternalRequest.ts.html +0 -2305
  169. package/coverage/lcov-report/src/api/controllers/row/external.ts.html +0 -931
  170. package/coverage/lcov-report/src/api/controllers/row/index.html +0 -206
  171. package/coverage/lcov-report/src/api/controllers/row/index.ts.html +0 -541
  172. package/coverage/lcov-report/src/api/controllers/row/internal.ts.html +0 -1609
  173. package/coverage/lcov-report/src/api/controllers/row/internalSearch.ts.html +0 -1678
  174. package/coverage/lcov-report/src/api/controllers/row/staticFormula.ts.html +0 -577
  175. package/coverage/lcov-report/src/api/controllers/row/utils.ts.html +0 -556
  176. package/coverage/lcov-report/src/api/controllers/screen.ts.html +0 -463
  177. package/coverage/lcov-report/src/api/controllers/script.ts.html +0 -121
  178. package/coverage/lcov-report/src/api/controllers/static/index.html +0 -116
  179. package/coverage/lcov-report/src/api/controllers/static/index.ts.html +0 -679
  180. package/coverage/lcov-report/src/api/controllers/table/bulkFormula.ts.html +0 -649
  181. package/coverage/lcov-report/src/api/controllers/table/external.ts.html +0 -1153
  182. package/coverage/lcov-report/src/api/controllers/table/index.html +0 -176
  183. package/coverage/lcov-report/src/api/controllers/table/index.ts.html +0 -514
  184. package/coverage/lcov-report/src/api/controllers/table/internal.ts.html +0 -658
  185. package/coverage/lcov-report/src/api/controllers/table/utils.ts.html +0 -1273
  186. package/coverage/lcov-report/src/api/controllers/templates.ts.html +0 -214
  187. package/coverage/lcov-report/src/api/controllers/user.ts.html +0 -634
  188. package/coverage/lcov-report/src/api/controllers/view/exporters.ts.html +0 -214
  189. package/coverage/lcov-report/src/api/controllers/view/index.html +0 -161
  190. package/coverage/lcov-report/src/api/controllers/view/index.ts.html +0 -661
  191. package/coverage/lcov-report/src/api/controllers/view/utils.ts.html +0 -580
  192. package/coverage/lcov-report/src/api/controllers/view/viewBuilder.ts.html +0 -694
  193. package/coverage/lcov-report/src/api/controllers/webhook.ts.html +0 -385
  194. package/coverage/lcov-report/src/api/index.html +0 -116
  195. package/coverage/lcov-report/src/api/index.ts.html +0 -352
  196. package/coverage/lcov-report/src/api/routes/analytics.ts.html +0 -112
  197. package/coverage/lcov-report/src/api/routes/apikeys.ts.html +0 -121
  198. package/coverage/lcov-report/src/api/routes/application.ts.html +0 -256
  199. package/coverage/lcov-report/src/api/routes/auth.ts.html +0 -109
  200. package/coverage/lcov-report/src/api/routes/automation.ts.html +0 -346
  201. package/coverage/lcov-report/src/api/routes/backup.ts.html +0 -127
  202. package/coverage/lcov-report/src/api/routes/cloud.ts.html +0 -139
  203. package/coverage/lcov-report/src/api/routes/component.ts.html +0 -127
  204. package/coverage/lcov-report/src/api/routes/datasource.ts.html +0 -265
  205. package/coverage/lcov-report/src/api/routes/deploy.ts.html +0 -145
  206. package/coverage/lcov-report/src/api/routes/dev.ts.html +0 -199
  207. package/coverage/lcov-report/src/api/routes/index.html +0 -551
  208. package/coverage/lcov-report/src/api/routes/index.ts.html +0 -298
  209. package/coverage/lcov-report/src/api/routes/integration.ts.html +0 -133
  210. package/coverage/lcov-report/src/api/routes/layout.ts.html +0 -133
  211. package/coverage/lcov-report/src/api/routes/metadata.ts.html +0 -199
  212. package/coverage/lcov-report/src/api/routes/migrations.ts.html +0 -127
  213. package/coverage/lcov-report/src/api/routes/permission.ts.html +0 -208
  214. package/coverage/lcov-report/src/api/routes/plugin.ts.html +0 -151
  215. package/coverage/lcov-report/src/api/routes/public/applications.ts.html +0 -673
  216. package/coverage/lcov-report/src/api/routes/public/index.html +0 -191
  217. package/coverage/lcov-report/src/api/routes/public/index.ts.html +0 -493
  218. package/coverage/lcov-report/src/api/routes/public/middleware/index.html +0 -116
  219. package/coverage/lcov-report/src/api/routes/public/middleware/mapper.ts.html +0 -340
  220. package/coverage/lcov-report/src/api/routes/public/queries.ts.html +0 -313
  221. package/coverage/lcov-report/src/api/routes/public/rows.ts.html +0 -598
  222. package/coverage/lcov-report/src/api/routes/public/tables.ts.html +0 -586
  223. package/coverage/lcov-report/src/api/routes/public/tests/index.html +0 -116
  224. package/coverage/lcov-report/src/api/routes/public/tests/utils.ts.html +0 -169
  225. package/coverage/lcov-report/src/api/routes/public/users.ts.html +0 -511
  226. package/coverage/lcov-report/src/api/routes/public/utils/Endpoint.ts.html +0 -238
  227. package/coverage/lcov-report/src/api/routes/public/utils/index.html +0 -116
  228. package/coverage/lcov-report/src/api/routes/query.ts.html +0 -268
  229. package/coverage/lcov-report/src/api/routes/role.ts.html +0 -157
  230. package/coverage/lcov-report/src/api/routes/routing.ts.html +0 -127
  231. package/coverage/lcov-report/src/api/routes/row.ts.html +0 -883
  232. package/coverage/lcov-report/src/api/routes/screen.ts.html +0 -154
  233. package/coverage/lcov-report/src/api/routes/script.ts.html +0 -115
  234. package/coverage/lcov-report/src/api/routes/static.ts.html +0 -280
  235. package/coverage/lcov-report/src/api/routes/table.ts.html +0 -595
  236. package/coverage/lcov-report/src/api/routes/templates.ts.html +0 -133
  237. package/coverage/lcov-report/src/api/routes/tests/utilities/TestFunctions.ts.html +0 -550
  238. package/coverage/lcov-report/src/api/routes/tests/utilities/index.html +0 -131
  239. package/coverage/lcov-report/src/api/routes/tests/utilities/index.ts.html +0 -367
  240. package/coverage/lcov-report/src/api/routes/user.ts.html +0 -238
  241. package/coverage/lcov-report/src/api/routes/utils/index.html +0 -116
  242. package/coverage/lcov-report/src/api/routes/utils/validators.ts.html +0 -805
  243. package/coverage/lcov-report/src/api/routes/view.ts.html +0 -187
  244. package/coverage/lcov-report/src/api/routes/webhook.ts.html +0 -166
  245. package/coverage/lcov-report/src/app.ts.html +0 -424
  246. package/coverage/lcov-report/src/automations/actions.ts.html +0 -316
  247. package/coverage/lcov-report/src/automations/automationUtils.ts.html +0 -562
  248. package/coverage/lcov-report/src/automations/bullboard.ts.html +0 -199
  249. package/coverage/lcov-report/src/automations/index.html +0 -191
  250. package/coverage/lcov-report/src/automations/index.ts.html +0 -163
  251. package/coverage/lcov-report/src/automations/logging/index.html +0 -116
  252. package/coverage/lcov-report/src/automations/logging/index.ts.html +0 -199
  253. package/coverage/lcov-report/src/automations/steps/bash.ts.html +0 -319
  254. package/coverage/lcov-report/src/automations/steps/createRow.ts.html +0 -382
  255. package/coverage/lcov-report/src/automations/steps/delay.ts.html +0 -217
  256. package/coverage/lcov-report/src/automations/steps/deleteRow.ts.html +0 -349
  257. package/coverage/lcov-report/src/automations/steps/discord.ts.html +0 -349
  258. package/coverage/lcov-report/src/automations/steps/executeQuery.ts.html +0 -370
  259. package/coverage/lcov-report/src/automations/steps/executeScript.ts.html +0 -325
  260. package/coverage/lcov-report/src/automations/steps/filter.ts.html +0 -394
  261. package/coverage/lcov-report/src/automations/steps/index.html +0 -371
  262. package/coverage/lcov-report/src/automations/steps/integromat.ts.html +0 -361
  263. package/coverage/lcov-report/src/automations/steps/loop.ts.html +0 -241
  264. package/coverage/lcov-report/src/automations/steps/outgoingWebhook.ts.html +0 -499
  265. package/coverage/lcov-report/src/automations/steps/queryRows.ts.html +0 -664
  266. package/coverage/lcov-report/src/automations/steps/sendSmtpEmail.ts.html +0 -355
  267. package/coverage/lcov-report/src/automations/steps/serverLog.ts.html +0 -256
  268. package/coverage/lcov-report/src/automations/steps/slack.ts.html +0 -292
  269. package/coverage/lcov-report/src/automations/steps/updateRow.ts.html +0 -439
  270. package/coverage/lcov-report/src/automations/steps/utils.ts.html +0 -223
  271. package/coverage/lcov-report/src/automations/steps/zapier.ts.html +0 -355
  272. package/coverage/lcov-report/src/automations/tests/utilities/index.html +0 -116
  273. package/coverage/lcov-report/src/automations/tests/utilities/index.ts.html +0 -265
  274. package/coverage/lcov-report/src/automations/triggerInfo/app.ts.html +0 -196
  275. package/coverage/lcov-report/src/automations/triggerInfo/cron.ts.html +0 -193
  276. package/coverage/lcov-report/src/automations/triggerInfo/index.html +0 -206
  277. package/coverage/lcov-report/src/automations/triggerInfo/index.ts.html +0 -130
  278. package/coverage/lcov-report/src/automations/triggerInfo/rowDeleted.ts.html +0 -196
  279. package/coverage/lcov-report/src/automations/triggerInfo/rowSaved.ts.html +0 -220
  280. package/coverage/lcov-report/src/automations/triggerInfo/rowUpdated.ts.html +0 -220
  281. package/coverage/lcov-report/src/automations/triggerInfo/webhook.ts.html +0 -208
  282. package/coverage/lcov-report/src/automations/triggers.ts.html +0 -553
  283. package/coverage/lcov-report/src/automations/utils.ts.html +0 -886
  284. package/coverage/lcov-report/src/constants/index.html +0 -146
  285. package/coverage/lcov-report/src/constants/index.ts.html +0 -697
  286. package/coverage/lcov-report/src/constants/layouts.ts.html +0 -526
  287. package/coverage/lcov-report/src/constants/screens.ts.html +0 -229
  288. package/coverage/lcov-report/src/db/defaultData/datasource_bb_default.ts.html +0 -2059
  289. package/coverage/lcov-report/src/db/defaultData/employeeImport.ts.html +0 -541
  290. package/coverage/lcov-report/src/db/defaultData/expensesImport.ts.html +0 -427
  291. package/coverage/lcov-report/src/db/defaultData/index.html +0 -176
  292. package/coverage/lcov-report/src/db/defaultData/inventoryImport.ts.html +0 -403
  293. package/coverage/lcov-report/src/db/defaultData/jobsImport.ts.html +0 -559
  294. package/coverage/lcov-report/src/db/dynamoClient.ts.html +0 -526
  295. package/coverage/lcov-report/src/db/inMemoryView.ts.html +0 -250
  296. package/coverage/lcov-report/src/db/index.html +0 -176
  297. package/coverage/lcov-report/src/db/index.ts.html +0 -133
  298. package/coverage/lcov-report/src/db/linkedRows/LinkController.ts.html +0 -1417
  299. package/coverage/lcov-report/src/db/linkedRows/LinkDocument.ts.html +0 -265
  300. package/coverage/lcov-report/src/db/linkedRows/index.html +0 -161
  301. package/coverage/lcov-report/src/db/linkedRows/index.ts.html +0 -736
  302. package/coverage/lcov-report/src/db/linkedRows/linkUtils.ts.html +0 -460
  303. package/coverage/lcov-report/src/db/newid.ts.html +0 -100
  304. package/coverage/lcov-report/src/db/utils.ts.html +0 -913
  305. package/coverage/lcov-report/src/definitions/automations.ts.html +0 -184
  306. package/coverage/lcov-report/src/definitions/index.html +0 -116
  307. package/coverage/lcov-report/src/environment.ts.html +0 -472
  308. package/coverage/lcov-report/src/events/AutomationEmitter.ts.html +0 -259
  309. package/coverage/lcov-report/src/events/BudibaseEmitter.ts.html +0 -172
  310. package/coverage/lcov-report/src/events/index.html +0 -161
  311. package/coverage/lcov-report/src/events/index.ts.html +0 -100
  312. package/coverage/lcov-report/src/events/utils.ts.html +0 -319
  313. package/coverage/lcov-report/src/index.html +0 -191
  314. package/coverage/lcov-report/src/index.ts.html +0 -133
  315. package/coverage/lcov-report/src/integrations/airtable.ts.html +0 -529
  316. package/coverage/lcov-report/src/integrations/arangodb.ts.html +0 -415
  317. package/coverage/lcov-report/src/integrations/base/index.html +0 -161
  318. package/coverage/lcov-report/src/integrations/base/query.ts.html +0 -139
  319. package/coverage/lcov-report/src/integrations/base/sql.ts.html +0 -2017
  320. package/coverage/lcov-report/src/integrations/base/sqlTable.ts.html +0 -691
  321. package/coverage/lcov-report/src/integrations/base/utils.ts.html +0 -121
  322. package/coverage/lcov-report/src/integrations/couchdb.ts.html +0 -484
  323. package/coverage/lcov-report/src/integrations/dynamodb.ts.html +0 -745
  324. package/coverage/lcov-report/src/integrations/elasticsearch.ts.html +0 -646
  325. package/coverage/lcov-report/src/integrations/firebase.ts.html +0 -646
  326. package/coverage/lcov-report/src/integrations/googlesheets.ts.html +0 -1315
  327. package/coverage/lcov-report/src/integrations/index.html +0 -371
  328. package/coverage/lcov-report/src/integrations/index.ts.html +0 -460
  329. package/coverage/lcov-report/src/integrations/microsoftSqlServer.ts.html +0 -1012
  330. package/coverage/lcov-report/src/integrations/mongodb.ts.html +0 -1999
  331. package/coverage/lcov-report/src/integrations/mysql.ts.html +0 -979
  332. package/coverage/lcov-report/src/integrations/oracle.ts.html +0 -1387
  333. package/coverage/lcov-report/src/integrations/postgres.ts.html +0 -1087
  334. package/coverage/lcov-report/src/integrations/queries/index.html +0 -116
  335. package/coverage/lcov-report/src/integrations/queries/sql.ts.html +0 -328
  336. package/coverage/lcov-report/src/integrations/redis.ts.html +0 -550
  337. package/coverage/lcov-report/src/integrations/rest.ts.html +0 -1372
  338. package/coverage/lcov-report/src/integrations/s3.ts.html +0 -862
  339. package/coverage/lcov-report/src/integrations/snowflake.ts.html +0 -376
  340. package/coverage/lcov-report/src/integrations/tests/TestConfiguration.js.html +0 -85
  341. package/coverage/lcov-report/src/integrations/tests/index.html +0 -116
  342. package/coverage/lcov-report/src/integrations/utils.ts.html +0 -1036
  343. package/coverage/lcov-report/src/middleware/appInfo.ts.html +0 -145
  344. package/coverage/lcov-report/src/middleware/authorized.ts.html +0 -472
  345. package/coverage/lcov-report/src/middleware/builder.ts.html +0 -361
  346. package/coverage/lcov-report/src/middleware/currentapp.ts.html +0 -508
  347. package/coverage/lcov-report/src/middleware/index.html +0 -236
  348. package/coverage/lcov-report/src/middleware/joi-validator.ts.html +0 -205
  349. package/coverage/lcov-report/src/middleware/publicApi.ts.html +0 -148
  350. package/coverage/lcov-report/src/middleware/resourceId.ts.html +0 -283
  351. package/coverage/lcov-report/src/middleware/selfhost.ts.html +0 -121
  352. package/coverage/lcov-report/src/middleware/utils.ts.html +0 -112
  353. package/coverage/lcov-report/src/migrations/functions/appUrls.ts.html +0 -166
  354. package/coverage/lcov-report/src/migrations/functions/backfill/app/automations.ts.html +0 -163
  355. package/coverage/lcov-report/src/migrations/functions/backfill/app/datasources.ts.html +0 -151
  356. package/coverage/lcov-report/src/migrations/functions/backfill/app/index.html +0 -206
  357. package/coverage/lcov-report/src/migrations/functions/backfill/app/layouts.ts.html +0 -172
  358. package/coverage/lcov-report/src/migrations/functions/backfill/app/queries.ts.html +0 -226
  359. package/coverage/lcov-report/src/migrations/functions/backfill/app/roles.ts.html +0 -151
  360. package/coverage/lcov-report/src/migrations/functions/backfill/app/screens.ts.html +0 -151
  361. package/coverage/lcov-report/src/migrations/functions/backfill/app/tables.ts.html +0 -166
  362. package/coverage/lcov-report/src/migrations/functions/backfill/app.ts.html +0 -532
  363. package/coverage/lcov-report/src/migrations/functions/backfill/global/configs.ts.html +0 -286
  364. package/coverage/lcov-report/src/migrations/functions/backfill/global/index.html +0 -146
  365. package/coverage/lcov-report/src/migrations/functions/backfill/global/quotas.ts.html +0 -265
  366. package/coverage/lcov-report/src/migrations/functions/backfill/global/users.ts.html +0 -232
  367. package/coverage/lcov-report/src/migrations/functions/backfill/global.ts.html +0 -724
  368. package/coverage/lcov-report/src/migrations/functions/backfill/index.html +0 -161
  369. package/coverage/lcov-report/src/migrations/functions/backfill/index.ts.html +0 -106
  370. package/coverage/lcov-report/src/migrations/functions/backfill/installation.ts.html +0 -235
  371. package/coverage/lcov-report/src/migrations/functions/index.html +0 -161
  372. package/coverage/lcov-report/src/migrations/functions/syncQuotas.ts.html +0 -130
  373. package/coverage/lcov-report/src/migrations/functions/tableSettings.ts.html +0 -520
  374. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.html +0 -161
  375. package/coverage/lcov-report/src/migrations/functions/usageQuotas/index.ts.html +0 -94
  376. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncApps.ts.html +0 -127
  377. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncPlugins.ts.html +0 -115
  378. package/coverage/lcov-report/src/migrations/functions/usageQuotas/syncRows.ts.html +0 -169
  379. package/coverage/lcov-report/src/migrations/functions/userEmailViewCasing.ts.html +0 -124
  380. package/coverage/lcov-report/src/migrations/index.html +0 -116
  381. package/coverage/lcov-report/src/migrations/index.ts.html +0 -430
  382. package/coverage/lcov-report/src/migrations/tests/helpers.ts.html +0 -205
  383. package/coverage/lcov-report/src/migrations/tests/index.html +0 -131
  384. package/coverage/lcov-report/src/migrations/tests/structures.ts.html +0 -283
  385. package/coverage/lcov-report/src/sdk/app/applications/index.html +0 -146
  386. package/coverage/lcov-report/src/sdk/app/applications/index.ts.html +0 -106
  387. package/coverage/lcov-report/src/sdk/app/applications/sync.ts.html +0 -268
  388. package/coverage/lcov-report/src/sdk/app/applications/utils.ts.html +0 -136
  389. package/coverage/lcov-report/src/sdk/app/automations/index.html +0 -131
  390. package/coverage/lcov-report/src/sdk/app/automations/index.ts.html +0 -100
  391. package/coverage/lcov-report/src/sdk/app/automations/webhook.ts.html +0 -214
  392. package/coverage/lcov-report/src/sdk/app/backups/constants.ts.html +0 -91
  393. package/coverage/lcov-report/src/sdk/app/backups/exports.ts.html +0 -604
  394. package/coverage/lcov-report/src/sdk/app/backups/imports.ts.html +0 -640
  395. package/coverage/lcov-report/src/sdk/app/backups/index.html +0 -176
  396. package/coverage/lcov-report/src/sdk/app/backups/index.ts.html +0 -112
  397. package/coverage/lcov-report/src/sdk/app/backups/statistics.ts.html +0 -292
  398. package/coverage/lcov-report/src/sdk/app/datasources/datasources.ts.html +0 -562
  399. package/coverage/lcov-report/src/sdk/app/datasources/index.html +0 -131
  400. package/coverage/lcov-report/src/sdk/app/datasources/index.ts.html +0 -100
  401. package/coverage/lcov-report/src/sdk/app/queries/index.html +0 -131
  402. package/coverage/lcov-report/src/sdk/app/queries/index.ts.html +0 -100
  403. package/coverage/lcov-report/src/sdk/app/queries/queries.ts.html +0 -235
  404. package/coverage/lcov-report/src/sdk/app/rows/attachments.ts.html +0 -265
  405. package/coverage/lcov-report/src/sdk/app/rows/index.html +0 -146
  406. package/coverage/lcov-report/src/sdk/app/rows/index.ts.html +0 -106
  407. package/coverage/lcov-report/src/sdk/app/rows/rows.ts.html +0 -139
  408. package/coverage/lcov-report/src/sdk/app/tables/index.html +0 -116
  409. package/coverage/lcov-report/src/sdk/app/tables/index.ts.html +0 -274
  410. package/coverage/lcov-report/src/sdk/index.html +0 -116
  411. package/coverage/lcov-report/src/sdk/index.ts.html +0 -151
  412. package/coverage/lcov-report/src/sdk/users/index.html +0 -131
  413. package/coverage/lcov-report/src/sdk/users/index.ts.html +0 -100
  414. package/coverage/lcov-report/src/sdk/users/utils.ts.html +0 -277
  415. package/coverage/lcov-report/src/sdk/utils/index.html +0 -116
  416. package/coverage/lcov-report/src/sdk/utils/index.ts.html +0 -133
  417. package/coverage/lcov-report/src/startup.ts.html +0 -484
  418. package/coverage/lcov-report/src/tests/utilities/TestConfiguration.ts.html +0 -2032
  419. package/coverage/lcov-report/src/tests/utilities/controllers.ts.html +0 -127
  420. package/coverage/lcov-report/src/tests/utilities/index.html +0 -161
  421. package/coverage/lcov-report/src/tests/utilities/index.ts.html +0 -118
  422. package/coverage/lcov-report/src/tests/utilities/structures.ts.html +0 -856
  423. package/coverage/lcov-report/src/threads/automation.ts.html +0 -1555
  424. package/coverage/lcov-report/src/threads/index.html +0 -161
  425. package/coverage/lcov-report/src/threads/index.ts.html +0 -418
  426. package/coverage/lcov-report/src/threads/query.ts.html +0 -1000
  427. package/coverage/lcov-report/src/threads/utils.ts.html +0 -373
  428. package/coverage/lcov-report/src/utilities/budibaseDir.ts.html +0 -94
  429. package/coverage/lcov-report/src/utilities/centralPath.ts.html +0 -151
  430. package/coverage/lcov-report/src/utilities/fileSystem/app.ts.html +0 -343
  431. package/coverage/lcov-report/src/utilities/fileSystem/clientLibrary.ts.html +0 -547
  432. package/coverage/lcov-report/src/utilities/fileSystem/filesystem.ts.html +0 -601
  433. package/coverage/lcov-report/src/utilities/fileSystem/index.html +0 -206
  434. package/coverage/lcov-report/src/utilities/fileSystem/index.ts.html +0 -100
  435. package/coverage/lcov-report/src/utilities/fileSystem/plugin.ts.html +0 -277
  436. package/coverage/lcov-report/src/utilities/fileSystem/processor.ts.html +0 -142
  437. package/coverage/lcov-report/src/utilities/fileSystem/template.ts.html +0 -193
  438. package/coverage/lcov-report/src/utilities/global.ts.html +0 -499
  439. package/coverage/lcov-report/src/utilities/index.html +0 -251
  440. package/coverage/lcov-report/src/utilities/index.ts.html +0 -487
  441. package/coverage/lcov-report/src/utilities/redis.ts.html +0 -343
  442. package/coverage/lcov-report/src/utilities/routing/index.html +0 -116
  443. package/coverage/lcov-report/src/utilities/routing/index.ts.html +0 -181
  444. package/coverage/lcov-report/src/utilities/rowProcessor/index.html +0 -146
  445. package/coverage/lcov-report/src/utilities/rowProcessor/index.ts.html +0 -922
  446. package/coverage/lcov-report/src/utilities/rowProcessor/map.ts.html +0 -373
  447. package/coverage/lcov-report/src/utilities/rowProcessor/utils.ts.html +0 -373
  448. package/coverage/lcov-report/src/utilities/schema.ts.html +0 -508
  449. package/coverage/lcov-report/src/utilities/scriptRunner.ts.html +0 -169
  450. package/coverage/lcov-report/src/utilities/security.ts.html +0 -280
  451. package/coverage/lcov-report/src/utilities/usageQuota/index.html +0 -131
  452. package/coverage/lcov-report/src/utilities/usageQuota/rows.ts.html +0 -325
  453. package/coverage/lcov-report/src/utilities/usageQuota/usageQuoteReset.ts.html +0 -139
  454. package/coverage/lcov-report/src/utilities/users.ts.html +0 -232
  455. package/coverage/lcov-report/src/utilities/workerRequests.ts.html +0 -646
  456. package/coverage/lcov-report/src/watch.ts.html +0 -196
  457. package/coverage/lcov-report/src/websocket.ts.html +0 -163
  458. package/coverage/lcov.info +0 -21750
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.retry = void 0;
13
+ function retry(fn, maxTry = 5, retryCount = 1) {
14
+ return __awaiter(this, void 0, void 0, function* () {
15
+ const currRetry = typeof retryCount === "number" ? retryCount : 1;
16
+ try {
17
+ const result = yield fn();
18
+ return result;
19
+ }
20
+ catch (e) {
21
+ console.log(`Retry ${currRetry} failed.`);
22
+ if (currRetry > maxTry) {
23
+ console.log(`All ${maxTry} retry attempts exhausted`);
24
+ throw e;
25
+ }
26
+ return retry(fn, maxTry, currRetry + 1);
27
+ }
28
+ });
29
+ }
30
+ exports.retry = retry;
@@ -0,0 +1,8 @@
1
+ const { join } = require("path")
2
+ require("dotenv").config({
3
+ path: join(__dirname, "..", "..", "hosting", ".env"),
4
+ })
5
+
6
+ const jestTestcontainersConfigGenerator = require("../../jestTestcontainersConfigGenerator")
7
+
8
+ module.exports = jestTestcontainersConfigGenerator()
package/jest.config.ts CHANGED
@@ -1,16 +1,13 @@
1
1
  import { Config } from "@jest/types"
2
+
2
3
  import * as fs from "fs"
4
+ const preset = require("ts-jest/jest-preset")
3
5
 
4
- const config: Config.InitialOptions = {
5
- testEnvironment: "node",
6
+ const baseConfig: Config.InitialProjectOptions = {
7
+ ...preset,
8
+ preset: "@trendyol/jest-testcontainers",
6
9
  setupFiles: ["./src/tests/jestEnv.ts"],
7
10
  setupFilesAfterEnv: ["./src/tests/jestSetup.ts"],
8
- collectCoverageFrom: [
9
- "src/**/*.{js,ts}",
10
- // The use of coverage with couchdb view functions breaks tests
11
- "!src/db/views/staticViews.*",
12
- ],
13
- coverageReporters: ["lcov", "json", "clover"],
14
11
  transform: {
15
12
  "^.+\\.ts?$": "@swc/jest",
16
13
  },
@@ -18,19 +15,39 @@ const config: Config.InitialOptions = {
18
15
 
19
16
  if (!process.env.CI) {
20
17
  // use sources when not in CI
21
- config.moduleNameMapper = {
18
+ baseConfig.moduleNameMapper = {
22
19
  "@budibase/backend-core/(.*)": "<rootDir>/../backend-core/$1",
23
20
  "@budibase/backend-core": "<rootDir>/../backend-core/src",
24
21
  "@budibase/types": "<rootDir>/../types/src",
25
- "^axios.*$": "<rootDir>/node_modules/axios/lib/axios.js",
26
22
  }
27
23
  // add pro sources if they exist
28
24
  if (fs.existsSync("../../../budibase-pro")) {
29
- config.moduleNameMapper["@budibase/pro"] =
25
+ baseConfig.moduleNameMapper["@budibase/pro"] =
30
26
  "<rootDir>/../../../budibase-pro/packages/pro/src"
31
27
  }
32
28
  } else {
33
29
  console.log("Running tests with compiled dependency sources")
34
30
  }
35
31
 
32
+ const config: Config.InitialOptions = {
33
+ projects: [
34
+ {
35
+ ...baseConfig,
36
+ displayName: "sequential test",
37
+ testMatch: ["<rootDir>/**/*.seq.spec.[jt]s"],
38
+ runner: "jest-serial-runner",
39
+ },
40
+ {
41
+ ...baseConfig,
42
+ testMatch: ["<rootDir>/**/!(*.seq).spec.[jt]s"],
43
+ },
44
+ ],
45
+ collectCoverageFrom: [
46
+ "src/**/*.{js,ts}",
47
+ // The use of coverage with couchdb view functions breaks tests
48
+ "!src/db/views/staticViews.*",
49
+ ],
50
+ coverageReporters: ["lcov", "json", "clover"],
51
+ }
52
+
36
53
  export default config
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@budibase/server",
3
3
  "email": "hi@budibase.com",
4
- "version": "2.3.15",
4
+ "version": "2.3.17-alpha.0",
5
5
  "description": "Budibase Web Server",
6
6
  "main": "src/index.ts",
7
7
  "repository": {
@@ -43,11 +43,11 @@
43
43
  "license": "GPL-3.0",
44
44
  "dependencies": {
45
45
  "@apidevtools/swagger-parser": "10.0.3",
46
- "@budibase/backend-core": "^2.3.15",
47
- "@budibase/client": "^2.3.15",
48
- "@budibase/pro": "2.3.14",
49
- "@budibase/string-templates": "^2.3.15",
50
- "@budibase/types": "^2.3.15",
46
+ "@budibase/backend-core": "2.3.17-alpha.0",
47
+ "@budibase/client": "2.3.17-alpha.0",
48
+ "@budibase/pro": "2.3.16",
49
+ "@budibase/string-templates": "2.3.17-alpha.0",
50
+ "@budibase/types": "2.3.17-alpha.0",
51
51
  "@bull-board/api": "3.7.0",
52
52
  "@bull-board/koa": "3.9.4",
53
53
  "@elastic/elasticsearch": "7.10.0",
@@ -64,6 +64,7 @@
64
64
  "chokidar": "3.5.3",
65
65
  "csvtojson": "2.0.10",
66
66
  "curlconverter": "3.21.0",
67
+ "dd-trace": "3.13.2",
67
68
  "dotenv": "8.2.0",
68
69
  "download": "8.0.0",
69
70
  "elastic-apm-node": "3.38.0",
@@ -125,6 +126,7 @@
125
126
  "@jest/test-sequencer": "24.9.0",
126
127
  "@swc/core": "^1.3.25",
127
128
  "@swc/jest": "^0.2.24",
129
+ "@trendyol/jest-testcontainers": "^2.1.1",
128
130
  "@types/apidoc": "0.50.0",
129
131
  "@types/bson": "4.2.0",
130
132
  "@types/global-agent": "2.1.1",
@@ -151,6 +153,7 @@
151
153
  "is-wsl": "2.2.0",
152
154
  "jest": "28.1.1",
153
155
  "jest-openapi": "0.14.2",
156
+ "jest-serial-runner": "^1.2.1",
154
157
  "nodemon": "2.0.15",
155
158
  "openapi-types": "9.3.1",
156
159
  "openapi-typescript": "5.2.0",
@@ -169,5 +172,5 @@
169
172
  "optionalDependencies": {
170
173
  "oracledb": "5.3.0"
171
174
  },
172
- "gitHead": "3566477d01738aac5fe036794fa7d9042c89ecba"
175
+ "gitHead": "92d4358c4013f4941c374f9b82069206790b9ef4"
173
176
  }
@@ -0,0 +1,24 @@
1
+ #!/bin/node
2
+ const { createApp } = require("./utils")
3
+
4
+ const APP_COUNT = 100
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ for (let i = 0; i < APP_COUNT; i++) {
13
+ const app = await createApp(process.argv[2])
14
+ console.log(`App created: ${app._id}`)
15
+ }
16
+ }
17
+
18
+ run()
19
+ .then(() => {
20
+ console.log(`Finished creating ${APP_COUNT} apps.`)
21
+ })
22
+ .catch(err => {
23
+ console.error(err)
24
+ })
@@ -0,0 +1,30 @@
1
+ #!/bin/node
2
+ const { createApp, getTable, createRow } = require("./utils")
3
+
4
+ const ROW_COUNT = 1000
5
+
6
+ if (!process.argv[2]) {
7
+ console.error("Please specify an API key as script argument.")
8
+ process.exit(-1)
9
+ }
10
+
11
+ async function run() {
12
+ const apiKey = process.argv[2]
13
+ const app = await createApp(apiKey)
14
+ console.log(`App created: ${app._id}`)
15
+ const table = await getTable(apiKey, app._id)
16
+ console.log(`Table found: ${table.name}`)
17
+ const promises = []
18
+ for (let i = 0; i < ROW_COUNT; i++) {
19
+ promises.push(await createRow(apiKey, app._id, table))
20
+ }
21
+ await Promise.all(promises)
22
+ }
23
+
24
+ run()
25
+ .then(() => {
26
+ console.log(`Finished creating ${ROW_COUNT} rows.`)
27
+ })
28
+ .catch(err => {
29
+ console.error(err)
30
+ })
@@ -0,0 +1,66 @@
1
+ const fetch = require("node-fetch")
2
+ const uuid = require("uuid/v4")
3
+
4
+ const URL_APP = "http://localhost:10000/api/public/v1/applications"
5
+ const URL_TABLE = "http://localhost:10000/api/public/v1/tables/search"
6
+
7
+ async function request(apiKey, url, method, body, appId = undefined) {
8
+ const headers = {
9
+ "x-budibase-api-key": apiKey,
10
+ "Content-Type": "application/json",
11
+ }
12
+ if (appId) {
13
+ headers["x-budibase-app-id"] = appId
14
+ }
15
+ const res = await fetch(url, {
16
+ method,
17
+ headers,
18
+ body: JSON.stringify(body),
19
+ })
20
+ if (res.status !== 200) {
21
+ throw new Error(await res.text())
22
+ }
23
+ return res
24
+ }
25
+
26
+ exports.createApp = async apiKey => {
27
+ const name = uuid().replace(/-/g, "")
28
+ const body = {
29
+ name,
30
+ url: `/${name}`,
31
+ useTemplate: "true",
32
+ templateKey: "app/school-admin-panel",
33
+ templateName: "School Admin Panel",
34
+ }
35
+ const res = await request(apiKey, URL_APP, "POST", body)
36
+ const json = await res.json()
37
+ return json.data
38
+ }
39
+
40
+ exports.getTable = async (apiKey, appId) => {
41
+ const res = await request(apiKey, URL_TABLE, "POST", {}, appId)
42
+ const json = await res.json()
43
+ return json.data[0]
44
+ }
45
+
46
+ exports.createRow = async (apiKey, appId, table) => {
47
+ const body = {}
48
+ for (let [key, schema] of Object.entries(table.schema)) {
49
+ let fake
50
+ switch (schema.type) {
51
+ default:
52
+ case "string":
53
+ fake = schema.constraints.inclusion
54
+ ? schema.constraints.inclusion[0]
55
+ : "a"
56
+ break
57
+ case "number":
58
+ fake = 1
59
+ break
60
+ }
61
+ body[key] = fake
62
+ }
63
+ const url = `http://localhost:10000/api/public/v1/tables/${table._id}/rows`
64
+ const res = await request(apiKey, url, "POST", body, appId)
65
+ return (await res.json()).data
66
+ }
@@ -41,7 +41,7 @@ const datasets = {
41
41
  describe("Rest Importer", () => {
42
42
  const config = new TestConfig(false)
43
43
 
44
- beforeEach(async () => {
44
+ beforeAll(async () => {
45
45
  await config.init()
46
46
  })
47
47
 
@@ -186,6 +186,8 @@ export async function preview(ctx: any) {
186
186
  schemaFields[key] = fieldType
187
187
  }
188
188
  }
189
+ // remove configuration before sending event
190
+ delete datasource.config
189
191
  await events.query.previewed(datasource, query)
190
192
  ctx.body = {
191
193
  rows,
@@ -10,6 +10,7 @@ import {
10
10
  FieldSchema,
11
11
  Row,
12
12
  Table,
13
+ RelationshipTypes,
13
14
  } from "@budibase/types"
14
15
  import {
15
16
  breakRowIdField,
@@ -18,7 +19,7 @@ import {
18
19
  convertRowId,
19
20
  } from "../../../integrations/utils"
20
21
  import { getDatasourceAndQuery } from "./utils"
21
- import { FieldTypes, RelationshipTypes } from "../../../constants"
22
+ import { FieldTypes } from "../../../constants"
22
23
  import { breakExternalTableId, isSQL } from "../../../integrations/utils"
23
24
  import { processObjectSync } from "@budibase/string-templates"
24
25
  import { cloneDeep } from "lodash/fp"
@@ -44,6 +45,7 @@ export interface RunConfig {
44
45
  row?: Row
45
46
  rows?: Row[]
46
47
  tables?: Record<string, Table>
48
+ includeSqlRelationships?: IncludeRelationship
47
49
  }
48
50
 
49
51
  function buildFilters(
@@ -706,7 +708,9 @@ export class ExternalRequest {
706
708
  },
707
709
  resource: {
708
710
  // have to specify the fields to avoid column overlap (for SQL)
709
- fields: isSql ? this.buildFields(table) : [],
711
+ fields: isSql
712
+ ? this.buildFields(table, config.includeSqlRelationships)
713
+ : [],
710
714
  },
711
715
  filters,
712
716
  sort,
@@ -18,6 +18,7 @@ import {
18
18
  PaginationJson,
19
19
  Table,
20
20
  Datasource,
21
+ IncludeRelationship,
21
22
  } from "@budibase/types"
22
23
  import sdk from "../../../sdk"
23
24
 
@@ -57,6 +58,7 @@ export async function patch(ctx: BBContext) {
57
58
  return handleRequest(Operation.UPDATE, tableId, {
58
59
  id: breakRowIdField(id),
59
60
  row: inputs,
61
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
60
62
  })
61
63
  }
62
64
 
@@ -65,6 +67,7 @@ export async function save(ctx: BBContext) {
65
67
  const tableId = ctx.params.tableId
66
68
  return handleRequest(Operation.CREATE, tableId, {
67
69
  row: inputs,
70
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
68
71
  })
69
72
  }
70
73
 
@@ -78,7 +81,9 @@ export async function fetchView(ctx: BBContext) {
78
81
 
79
82
  export async function fetch(ctx: BBContext) {
80
83
  const tableId = ctx.params.tableId
81
- return handleRequest(Operation.READ, tableId)
84
+ return handleRequest(Operation.READ, tableId, {
85
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
86
+ })
82
87
  }
83
88
 
84
89
  export async function find(ctx: BBContext) {
@@ -86,6 +91,7 @@ export async function find(ctx: BBContext) {
86
91
  const tableId = ctx.params.tableId
87
92
  const response = (await handleRequest(Operation.READ, tableId, {
88
93
  id: breakRowIdField(id),
94
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
89
95
  })) as Row[]
90
96
  return response ? response[0] : response
91
97
  }
@@ -95,6 +101,7 @@ export async function destroy(ctx: BBContext) {
95
101
  const id = ctx.request.body._id
96
102
  const { row } = (await handleRequest(Operation.DELETE, tableId, {
97
103
  id: breakRowIdField(id),
104
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
98
105
  })) as { row: Row }
99
106
  return { response: { ok: true }, row }
100
107
  }
@@ -107,6 +114,7 @@ export async function bulkDestroy(ctx: BBContext) {
107
114
  promises.push(
108
115
  handleRequest(Operation.DELETE, tableId, {
109
116
  id: breakRowIdField(row._id),
117
+ includeSqlRelationships: IncludeRelationship.EXCLUDE,
110
118
  })
111
119
  )
112
120
  }
@@ -149,6 +157,7 @@ export async function search(ctx: BBContext) {
149
157
  filters: query,
150
158
  sort,
151
159
  paginate: paginateObj as PaginationJson,
160
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
152
161
  })) as Row[]
153
162
  let hasNextPage = false
154
163
  if (paginate && rows.length === limit) {
@@ -159,6 +168,7 @@ export async function search(ctx: BBContext) {
159
168
  limit: 1,
160
169
  page: bookmark * limit + 1,
161
170
  },
171
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
162
172
  })) as Row[]
163
173
  hasNextPage = nextRows.length > 0
164
174
  }
@@ -249,6 +259,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
249
259
  const response = (await handleRequest(Operation.READ, tableId, {
250
260
  id,
251
261
  datasource,
262
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
252
263
  })) as Row[]
253
264
  const table: Table = tables[tableName]
254
265
  const row = response[0]
@@ -276,6 +287,7 @@ export async function fetchEnrichedRow(ctx: BBContext) {
276
287
  [primaryLink]: linkedIds,
277
288
  },
278
289
  },
290
+ includeSqlRelationships: IncludeRelationship.INCLUDE,
279
291
  })
280
292
  }
281
293
  return row
@@ -8,7 +8,7 @@ import {
8
8
  foreignKeyStructure,
9
9
  hasTypeChanged,
10
10
  } from "./utils"
11
- import { FieldTypes, RelationshipTypes } from "../../../constants"
11
+ import { FieldTypes } from "../../../constants"
12
12
  import { makeExternalQuery } from "../../../integrations/base/query"
13
13
  import { handleRequest } from "../row/external"
14
14
  import { events, context } from "@budibase/backend-core"
@@ -22,6 +22,7 @@ import {
22
22
  FieldSchema,
23
23
  BBContext,
24
24
  TableRequest,
25
+ RelationshipTypes,
25
26
  } from "@budibase/types"
26
27
  import sdk from "../../../sdk"
27
28
  const { cloneDeep } = require("lodash/fp")
@@ -146,7 +147,7 @@ function generateLinkSchema(
146
147
  column: FieldSchema,
147
148
  table: Table,
148
149
  relatedTable: Table,
149
- type: string
150
+ type: RelationshipTypes
150
151
  ) {
151
152
  if (!table.primary || !relatedTable.primary) {
152
153
  throw new Error("Unable to generate link schema, no primary keys")
@@ -1,7 +1,6 @@
1
1
  import controller from "../../controllers/public/applications"
2
2
  import Endpoint from "./utils/Endpoint"
3
3
  const { nameValidator, applicationValidator } = require("../utils/validators")
4
- import { db } from "@budibase/backend-core"
5
4
 
6
5
  const read = [],
7
6
  write = []
@@ -13,7 +13,7 @@ beforeAll(async () => {
13
13
  app = await config.init()
14
14
  table = await config.updateTable()
15
15
  apiKey = await config.generateApiKey()
16
- makeRequest = generateMakeRequest(apiKey, setup)
16
+ makeRequest = generateMakeRequest(apiKey)
17
17
  })
18
18
 
19
19
  afterAll(setup.afterAll)
@@ -10,7 +10,7 @@ beforeAll(async () => {
10
10
  await config.init()
11
11
  globalUser = await config.globalUser()
12
12
  apiKey = await config.generateApiKey(globalUser._id)
13
- makeRequest = generateMakeRequest(apiKey, setup)
13
+ makeRequest = generateMakeRequest(apiKey)
14
14
  workerRequests.readGlobalUser.mockReturnValue(globalUser)
15
15
  })
16
16
 
@@ -1,13 +1,27 @@
1
+ import * as setup from "../../tests/utilities"
1
2
  import { checkSlashesInUrl } from "../../../../utilities"
3
+ import supertest from "supertest"
2
4
 
3
- export function generateMakeRequest(apiKey: string, setup: any) {
4
- const request = setup.getRequest()
5
- const config = setup.getConfig()
5
+ export type HttpMethod = "post" | "get" | "put" | "delete" | "patch"
6
+
7
+ export type MakeRequestResponse = (
8
+ method: HttpMethod,
9
+ endpoint: string,
10
+ body?: any,
11
+ intAppId?: string
12
+ ) => Promise<supertest.Response>
13
+
14
+ export function generateMakeRequest(
15
+ apiKey: string,
16
+ isInternal = false
17
+ ): MakeRequestResponse {
18
+ const request = setup.getRequest()!
19
+ const config = setup.getConfig()!
6
20
  return async (
7
- method: string,
21
+ method: HttpMethod,
8
22
  endpoint: string,
9
23
  body?: any,
10
- intAppId: string = config.getAppId()
24
+ intAppId: string | null = config.getAppId()
11
25
  ) => {
12
26
  const extraHeaders: any = {
13
27
  "x-budibase-api-key": apiKey,
@@ -15,9 +29,12 @@ export function generateMakeRequest(apiKey: string, setup: any) {
15
29
  if (intAppId) {
16
30
  extraHeaders["x-budibase-app-id"] = intAppId
17
31
  }
18
- const req = request[method](
19
- checkSlashesInUrl(`/api/public/v1/${endpoint}`)
20
- ).set(config.defaultHeaders(extraHeaders))
32
+
33
+ const url = isInternal
34
+ ? endpoint
35
+ : checkSlashesInUrl(`/api/public/v1/${endpoint}`)
36
+
37
+ const req = request[method](url).set(config.defaultHeaders(extraHeaders))
21
38
  if (body) {
22
39
  req.send(body)
23
40
  }
@@ -7,7 +7,7 @@ Array [
7
7
  "entities": Array [
8
8
  Object {
9
9
  "_id": "ta_users",
10
- "_rev": "1-6f4013e796887f1771bf7837598d87e7",
10
+ "_rev": "1-2375e1bc58aeec664dc1b1f04ad43e44",
11
11
  "createdAt": "2020-01-01T00:00:00.000Z",
12
12
  "name": "Users",
13
13
  "primaryDisplay": "email",
@@ -10,8 +10,11 @@ describe("/static", () => {
10
10
 
11
11
  afterAll(setup.afterAll)
12
12
 
13
- beforeEach(async () => {
13
+ beforeAll(async () => {
14
14
  app = await config.init()
15
+ })
16
+
17
+ beforeEach(()=>{
15
18
  jest.clearAllMocks()
16
19
  })
17
20
 
@@ -7,7 +7,7 @@ describe("/api/keys", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -14,18 +14,22 @@ jest.mock("../../../utilities/redis", () => ({
14
14
  import { clearAllApps, checkBuilderEndpoint } from "./utilities/TestFunctions"
15
15
  import * as setup from "./utilities"
16
16
  import { AppStatus } from "../../../db/utils"
17
- import { events } from "@budibase/backend-core"
17
+ import { events, utils } from "@budibase/backend-core"
18
18
  import env from "../../../environment"
19
19
 
20
+ jest.setTimeout(15000)
21
+
20
22
  describe("/applications", () => {
21
23
  let request = setup.getRequest()
22
24
  let config = setup.getConfig()
23
25
 
24
26
  afterAll(setup.afterAll)
25
27
 
26
- beforeEach(async () => {
27
- await clearAllApps()
28
+ beforeAll(async () => {
28
29
  await config.init()
30
+ })
31
+
32
+ beforeEach(async () => {
29
33
  jest.clearAllMocks()
30
34
  })
31
35
 
@@ -33,7 +37,7 @@ describe("/applications", () => {
33
37
  it("creates empty app", async () => {
34
38
  const res = await request
35
39
  .post("/api/applications")
36
- .field("name", "My App")
40
+ .field("name", utils.newid())
37
41
  .set(config.defaultHeaders())
38
42
  .expect("Content-Type", /json/)
39
43
  .expect(200)
@@ -44,7 +48,7 @@ describe("/applications", () => {
44
48
  it("creates app from template", async () => {
45
49
  const res = await request
46
50
  .post("/api/applications")
47
- .field("name", "My App")
51
+ .field("name", utils.newid())
48
52
  .field("useTemplate", "true")
49
53
  .field("templateKey", "test")
50
54
  .field("templateString", "{}") // override the file download
@@ -59,7 +63,7 @@ describe("/applications", () => {
59
63
  it("creates app from file", async () => {
60
64
  const res = await request
61
65
  .post("/api/applications")
62
- .field("name", "My App")
66
+ .field("name", utils.newid())
63
67
  .field("useTemplate", "true")
64
68
  .set(config.defaultHeaders())
65
69
  .attach("templateFile", "src/api/routes/tests/data/export.txt")
@@ -106,6 +110,11 @@ describe("/applications", () => {
106
110
  })
107
111
 
108
112
  describe("fetch", () => {
113
+ beforeEach(async () => {
114
+ // Clean all apps but the onde from config
115
+ await clearAllApps(config.getTenantId(), [config.getAppId()!])
116
+ })
117
+
109
118
  it("lists all applications", async () => {
110
119
  await config.createApp("app1")
111
120
  await config.createApp("app2")
@@ -266,6 +275,11 @@ describe("/applications", () => {
266
275
  })
267
276
 
268
277
  describe("unpublish", () => {
278
+ beforeEach(async () => {
279
+ // We want to republish as the unpublish will delete the prod app
280
+ await config.publish()
281
+ })
282
+
269
283
  it("should unpublish app with dev app ID", async () => {
270
284
  const appId = config.getAppId()
271
285
  await request
@@ -7,7 +7,7 @@ describe("/authenticate", () => {
7
7
 
8
8
  afterAll(setup.afterAll)
9
9
 
10
- beforeEach(async () => {
10
+ beforeAll(async () => {
11
11
  await config.init()
12
12
  })
13
13
 
@@ -18,7 +18,7 @@ describe("/authenticate", () => {
18
18
  .set(config.defaultHeaders())
19
19
  .expect("Content-Type", /json/)
20
20
  .expect(200)
21
- expect(res.body._id).toEqual(generateUserMetadataID("us_uuid1"))
21
+ expect(res.body._id).toEqual(generateUserMetadataID(config.user._id))
22
22
  })
23
23
  })
24
24
  })