@defra/forms-engine-plugin 0.0.2 → 0.0.4

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 (330) hide show
  1. package/.public/assets/fonts/bold-affa96571d-v2.woff +0 -0
  2. package/.public/assets/fonts/bold-b542beb274-v2.woff2 +0 -0
  3. package/.public/assets/fonts/light-94a07e06a1-v2.woff2 +0 -0
  4. package/.public/assets/fonts/light-f591b13f7d-v2.woff +0 -0
  5. package/.public/assets/images/favicon.ico +0 -0
  6. package/.public/assets/images/favicon.svg +1 -0
  7. package/.public/assets/images/govuk-crest.svg +1 -0
  8. package/.public/assets/images/govuk-icon-180.png +0 -0
  9. package/.public/assets/images/govuk-icon-192.png +0 -0
  10. package/.public/assets/images/govuk-icon-512.png +0 -0
  11. package/.public/assets/images/govuk-icon-mask.svg +1 -0
  12. package/.public/assets/images/govuk-opengraph-image.png +0 -0
  13. package/.public/assets/manifest.json +39 -0
  14. package/.public/assets-manifest.json +24 -0
  15. package/.public/javascripts/application.0fd8c18.min.js +3 -0
  16. package/.public/javascripts/application.0fd8c18.min.js.LICENSE.txt +58 -0
  17. package/.public/javascripts/application.0fd8c18.min.js.map +1 -0
  18. package/.public/javascripts/file-upload.b2f18f5.min.js +2 -0
  19. package/.public/javascripts/file-upload.b2f18f5.min.js.map +1 -0
  20. package/.public/javascripts/vendor/accessible-autocomplete.275d332.min.js +2 -0
  21. package/.public/javascripts/vendor/accessible-autocomplete.275d332.min.js.map +1 -0
  22. package/.public/stylesheets/application.e340021.min.css +14 -0
  23. package/.public/stylesheets/application.e340021.min.css.map +1 -0
  24. package/.server/server/plugins/nunjucks/environment.js +3 -3
  25. package/.server/server/plugins/nunjucks/environment.js.map +1 -1
  26. package/package.json +6 -2
  27. package/.browserslistrc +0 -16
  28. package/.editorconfig +0 -9
  29. package/.eslintrc.cjs +0 -266
  30. package/.github/dependabot.yml +0 -85
  31. package/.github/workflows/check-pull-request.yml +0 -209
  32. package/.github/workflows/pr-notifier.yml +0 -98
  33. package/.github/workflows/publish.yml +0 -111
  34. package/.husky/pre-commit +0 -1
  35. package/.lintstagedrc.js +0 -4
  36. package/.nvmrc +0 -1
  37. package/.prettierignore +0 -8
  38. package/.prettierrc.cjs +0 -26
  39. package/Dockerfile +0 -61
  40. package/Procfile +0 -1
  41. package/babel.config.cjs +0 -55
  42. package/compose/aws.env +0 -4
  43. package/compose/start-localstack.sh +0 -26
  44. package/docker-compose.yaml +0 -86
  45. package/globals.d.ts +0 -1
  46. package/jest.config.cjs +0 -54
  47. package/jest.environment.js +0 -4
  48. package/jest.setup.cjs +0 -14
  49. package/postcss.config.js +0 -26
  50. package/sonar-project.properties +0 -17
  51. package/src/client/javascripts/application.js +0 -87
  52. package/src/client/javascripts/file-upload.js +0 -386
  53. package/src/client/stylesheets/_code.scss +0 -33
  54. package/src/client/stylesheets/_govuk-frontend.scss +0 -4
  55. package/src/client/stylesheets/_prose.scss +0 -56
  56. package/src/client/stylesheets/_service-banner.scss +0 -24
  57. package/src/client/stylesheets/_summary-list.scss +0 -28
  58. package/src/client/stylesheets/_tag-env.scss +0 -24
  59. package/src/client/stylesheets/application.scss +0 -14
  60. package/src/common/cookies.js +0 -58
  61. package/src/common/cookies.test.js +0 -23
  62. package/src/common/types.js +0 -5
  63. package/src/config/index.ts +0 -271
  64. package/src/index.ts +0 -31
  65. package/src/server/common/helpers/logging/logger-options.test.ts +0 -50
  66. package/src/server/common/helpers/logging/logger-options.ts +0 -46
  67. package/src/server/common/helpers/logging/logger.ts +0 -7
  68. package/src/server/common/helpers/logging/request-logger.ts +0 -9
  69. package/src/server/common/helpers/logging/request-tracing.js +0 -10
  70. package/src/server/common/helpers/redis-client.js +0 -70
  71. package/src/server/constants.js +0 -1
  72. package/src/server/forms/README.md +0 -10
  73. package/src/server/forms/components.json +0 -1015
  74. package/src/server/forms/report-a-terrorist.json +0 -270
  75. package/src/server/forms/runner-components-test.json +0 -365
  76. package/src/server/forms/test.json +0 -581
  77. package/src/server/index.test.ts +0 -582
  78. package/src/server/index.ts +0 -140
  79. package/src/server/plugins/blankie.test.ts +0 -73
  80. package/src/server/plugins/blankie.ts +0 -48
  81. package/src/server/plugins/crumb.ts +0 -20
  82. package/src/server/plugins/engine/README.md +0 -87
  83. package/src/server/plugins/engine/components/AutocompleteField.test.ts +0 -294
  84. package/src/server/plugins/engine/components/AutocompleteField.ts +0 -49
  85. package/src/server/plugins/engine/components/CheckboxesField.test.ts +0 -379
  86. package/src/server/plugins/engine/components/CheckboxesField.ts +0 -106
  87. package/src/server/plugins/engine/components/ComponentBase.ts +0 -97
  88. package/src/server/plugins/engine/components/ComponentCollection.ts +0 -278
  89. package/src/server/plugins/engine/components/DatePartsField.test.ts +0 -822
  90. package/src/server/plugins/engine/components/DatePartsField.ts +0 -264
  91. package/src/server/plugins/engine/components/Details.test.ts +0 -49
  92. package/src/server/plugins/engine/components/Details.ts +0 -30
  93. package/src/server/plugins/engine/components/EmailAddressField.test.ts +0 -395
  94. package/src/server/plugins/engine/components/EmailAddressField.ts +0 -55
  95. package/src/server/plugins/engine/components/FileUploadField.test.ts +0 -778
  96. package/src/server/plugins/engine/components/FileUploadField.ts +0 -262
  97. package/src/server/plugins/engine/components/FormComponent.ts +0 -249
  98. package/src/server/plugins/engine/components/Html.test.ts +0 -48
  99. package/src/server/plugins/engine/components/Html.ts +0 -29
  100. package/src/server/plugins/engine/components/InsetText.test.ts +0 -48
  101. package/src/server/plugins/engine/components/InsetText.ts +0 -27
  102. package/src/server/plugins/engine/components/List.test.ts +0 -76
  103. package/src/server/plugins/engine/components/List.ts +0 -72
  104. package/src/server/plugins/engine/components/ListFormComponent.ts +0 -140
  105. package/src/server/plugins/engine/components/MonthYearField.test.ts +0 -567
  106. package/src/server/plugins/engine/components/MonthYearField.ts +0 -222
  107. package/src/server/plugins/engine/components/MultilineTextField.test.ts +0 -558
  108. package/src/server/plugins/engine/components/MultilineTextField.ts +0 -138
  109. package/src/server/plugins/engine/components/NumberField.test.ts +0 -701
  110. package/src/server/plugins/engine/components/NumberField.ts +0 -163
  111. package/src/server/plugins/engine/components/RadiosField.test.ts +0 -288
  112. package/src/server/plugins/engine/components/RadiosField.ts +0 -24
  113. package/src/server/plugins/engine/components/SelectField.test.ts +0 -288
  114. package/src/server/plugins/engine/components/SelectField.ts +0 -47
  115. package/src/server/plugins/engine/components/SelectionControlField.ts +0 -43
  116. package/src/server/plugins/engine/components/TelephoneNumberField.test.ts +0 -356
  117. package/src/server/plugins/engine/components/TelephoneNumberField.ts +0 -67
  118. package/src/server/plugins/engine/components/TextField.test.ts +0 -489
  119. package/src/server/plugins/engine/components/TextField.ts +0 -96
  120. package/src/server/plugins/engine/components/UkAddressField.test.ts +0 -623
  121. package/src/server/plugins/engine/components/UkAddressField.ts +0 -172
  122. package/src/server/plugins/engine/components/YesNoField.test.ts +0 -248
  123. package/src/server/plugins/engine/components/YesNoField.ts +0 -31
  124. package/src/server/plugins/engine/components/constants.ts +0 -1
  125. package/src/server/plugins/engine/components/helpers.ts +0 -330
  126. package/src/server/plugins/engine/components/index.ts +0 -24
  127. package/src/server/plugins/engine/components/types.ts +0 -117
  128. package/src/server/plugins/engine/configureEnginePlugin.ts +0 -47
  129. package/src/server/plugins/engine/helpers.test.ts +0 -791
  130. package/src/server/plugins/engine/helpers.ts +0 -379
  131. package/src/server/plugins/engine/index.ts +0 -7
  132. package/src/server/plugins/engine/models/FormModel.test.ts +0 -42
  133. package/src/server/plugins/engine/models/FormModel.ts +0 -443
  134. package/src/server/plugins/engine/models/RepeatingSummaryViewModel.ts +0 -0
  135. package/src/server/plugins/engine/models/Section.ts +0 -0
  136. package/src/server/plugins/engine/models/SummaryViewModel.test.ts +0 -209
  137. package/src/server/plugins/engine/models/SummaryViewModel.ts +0 -220
  138. package/src/server/plugins/engine/models/index.ts +0 -2
  139. package/src/server/plugins/engine/models/types.ts +0 -114
  140. package/src/server/plugins/engine/outputFormatters/human/v1.test.ts +0 -143
  141. package/src/server/plugins/engine/outputFormatters/human/v1.ts +0 -73
  142. package/src/server/plugins/engine/outputFormatters/index.test.ts +0 -17
  143. package/src/server/plugins/engine/outputFormatters/index.ts +0 -44
  144. package/src/server/plugins/engine/outputFormatters/machine/v1.test.ts +0 -229
  145. package/src/server/plugins/engine/outputFormatters/machine/v1.ts +0 -140
  146. package/src/server/plugins/engine/outputFormatters/machine/v2.test.ts +0 -229
  147. package/src/server/plugins/engine/outputFormatters/machine/v2.ts +0 -153
  148. package/src/server/plugins/engine/pageControllers/FileUploadPageController.test.ts +0 -1108
  149. package/src/server/plugins/engine/pageControllers/FileUploadPageController.ts +0 -446
  150. package/src/server/plugins/engine/pageControllers/PageController.test.ts +0 -205
  151. package/src/server/plugins/engine/pageControllers/PageController.ts +0 -176
  152. package/src/server/plugins/engine/pageControllers/QuestionPageController.test.ts +0 -1264
  153. package/src/server/plugins/engine/pageControllers/QuestionPageController.ts +0 -561
  154. package/src/server/plugins/engine/pageControllers/README.md +0 -28
  155. package/src/server/plugins/engine/pageControllers/RepeatPageController.test.ts +0 -264
  156. package/src/server/plugins/engine/pageControllers/RepeatPageController.ts +0 -458
  157. package/src/server/plugins/engine/pageControllers/StartPageController.ts +0 -18
  158. package/src/server/plugins/engine/pageControllers/StatusPageController.ts +0 -50
  159. package/src/server/plugins/engine/pageControllers/SummaryPageController.ts +0 -261
  160. package/src/server/plugins/engine/pageControllers/TerminalController.test.ts +0 -28
  161. package/src/server/plugins/engine/pageControllers/TerminalPageController.ts +0 -19
  162. package/src/server/plugins/engine/pageControllers/helpers.test.ts +0 -198
  163. package/src/server/plugins/engine/pageControllers/helpers.ts +0 -101
  164. package/src/server/plugins/engine/pageControllers/index.ts +0 -10
  165. package/src/server/plugins/engine/pageControllers/validationOptions.ts +0 -89
  166. package/src/server/plugins/engine/plugin.ts +0 -673
  167. package/src/server/plugins/engine/services/formSubmissionService.js +0 -46
  168. package/src/server/plugins/engine/services/formsService.js +0 -46
  169. package/src/server/plugins/engine/services/formsService.test.js +0 -90
  170. package/src/server/plugins/engine/services/index.js +0 -3
  171. package/src/server/plugins/engine/services/notifyService.test.ts +0 -132
  172. package/src/server/plugins/engine/services/notifyService.ts +0 -64
  173. package/src/server/plugins/engine/services/uploadService.js +0 -60
  174. package/src/server/plugins/engine/types.ts +0 -315
  175. package/src/server/plugins/engine/views/components/autocompletefield.html +0 -5
  176. package/src/server/plugins/engine/views/components/checkboxesfield.html +0 -5
  177. package/src/server/plugins/engine/views/components/datepartsfield.html +0 -5
  178. package/src/server/plugins/engine/views/components/details.html +0 -6
  179. package/src/server/plugins/engine/views/components/emailaddressfield.html +0 -5
  180. package/src/server/plugins/engine/views/components/fileuploadfield-key.html +0 -8
  181. package/src/server/plugins/engine/views/components/fileuploadfield-value.html +0 -3
  182. package/src/server/plugins/engine/views/components/fileuploadfield.html +0 -24
  183. package/src/server/plugins/engine/views/components/html.html +0 -3
  184. package/src/server/plugins/engine/views/components/insettext.html +0 -7
  185. package/src/server/plugins/engine/views/components/list.html +0 -36
  186. package/src/server/plugins/engine/views/components/monthyearfield.html +0 -5
  187. package/src/server/plugins/engine/views/components/multilinetextfield.html +0 -10
  188. package/src/server/plugins/engine/views/components/numberfield.html +0 -5
  189. package/src/server/plugins/engine/views/components/radiosfield.html +0 -5
  190. package/src/server/plugins/engine/views/components/selectfield.html +0 -5
  191. package/src/server/plugins/engine/views/components/telephonenumberfield.html +0 -5
  192. package/src/server/plugins/engine/views/components/textfield.html +0 -5
  193. package/src/server/plugins/engine/views/components/ukaddressfield.html +0 -25
  194. package/src/server/plugins/engine/views/components/yesnofield.html +0 -5
  195. package/src/server/plugins/engine/views/file-upload.html +0 -45
  196. package/src/server/plugins/engine/views/index.html +0 -39
  197. package/src/server/plugins/engine/views/item-delete.html +0 -56
  198. package/src/server/plugins/engine/views/partials/components.html +0 -6
  199. package/src/server/plugins/engine/views/partials/conditional-components.html +0 -3
  200. package/src/server/plugins/engine/views/partials/debug.html +0 -44
  201. package/src/server/plugins/engine/views/partials/form.html +0 -15
  202. package/src/server/plugins/engine/views/partials/heading.html +0 -16
  203. package/src/server/plugins/engine/views/partials/preview-banner.html +0 -32
  204. package/src/server/plugins/engine/views/partials/preview-banner.test.js +0 -122
  205. package/src/server/plugins/engine/views/partials/warn-missing-notification-email.html +0 -10
  206. package/src/server/plugins/engine/views/repeat-list-summary.html +0 -53
  207. package/src/server/plugins/errorPages.ts +0 -58
  208. package/src/server/plugins/nunjucks/context.js +0 -88
  209. package/src/server/plugins/nunjucks/context.test.js +0 -142
  210. package/src/server/plugins/nunjucks/enviroment.test.js +0 -201
  211. package/src/server/plugins/nunjucks/environment.js +0 -116
  212. package/src/server/plugins/nunjucks/filters/answer.js +0 -27
  213. package/src/server/plugins/nunjucks/filters/answer.test.js +0 -89
  214. package/src/server/plugins/nunjucks/filters/evaluate.js +0 -21
  215. package/src/server/plugins/nunjucks/filters/field.js +0 -28
  216. package/src/server/plugins/nunjucks/filters/field.test.js +0 -75
  217. package/src/server/plugins/nunjucks/filters/highlight.js +0 -11
  218. package/src/server/plugins/nunjucks/filters/href.js +0 -30
  219. package/src/server/plugins/nunjucks/filters/href.test.js +0 -80
  220. package/src/server/plugins/nunjucks/filters/index.js +0 -8
  221. package/src/server/plugins/nunjucks/filters/inspect.js +0 -15
  222. package/src/server/plugins/nunjucks/filters/page.js +0 -24
  223. package/src/server/plugins/nunjucks/filters/page.test.js +0 -65
  224. package/src/server/plugins/nunjucks/index.js +0 -3
  225. package/src/server/plugins/nunjucks/plugin.js +0 -40
  226. package/src/server/plugins/nunjucks/render.js +0 -42
  227. package/src/server/plugins/nunjucks/types.js +0 -40
  228. package/src/server/plugins/pulse.ts +0 -11
  229. package/src/server/plugins/router.ts +0 -201
  230. package/src/server/plugins/session.ts +0 -28
  231. package/src/server/routes/health.js +0 -13
  232. package/src/server/routes/health.test.js +0 -35
  233. package/src/server/routes/index.test.ts +0 -125
  234. package/src/server/routes/index.ts +0 -2
  235. package/src/server/routes/public.ts +0 -47
  236. package/src/server/routes/types.ts +0 -48
  237. package/src/server/schemas/index.ts +0 -34
  238. package/src/server/secure-context.js +0 -43
  239. package/src/server/services/cacheService.test.ts +0 -276
  240. package/src/server/services/cacheService.ts +0 -131
  241. package/src/server/services/httpService.test.js +0 -491
  242. package/src/server/services/httpService.ts +0 -50
  243. package/src/server/services/index.ts +0 -1
  244. package/src/server/types.ts +0 -54
  245. package/src/server/utils/notify.test.ts +0 -37
  246. package/src/server/utils/notify.ts +0 -50
  247. package/src/server/utils/secure-context/get-trust-store-certs.js +0 -11
  248. package/src/server/utils/secure-context/get-trust-store-certs.test.js +0 -19
  249. package/src/server/utils/utils.js +0 -24
  250. package/src/server/utils/utils.test.js +0 -54
  251. package/src/server/views/404.html +0 -16
  252. package/src/server/views/500.html +0 -19
  253. package/src/server/views/components/debug/macro.njk +0 -3
  254. package/src/server/views/components/debug/template.njk +0 -13
  255. package/src/server/views/components/service-banner/macro.njk +0 -3
  256. package/src/server/views/components/service-banner/template.njk +0 -20
  257. package/src/server/views/components/service-banner/template.test.js +0 -43
  258. package/src/server/views/components/tag-env/macro.njk +0 -3
  259. package/src/server/views/components/tag-env/template.njk +0 -30
  260. package/src/server/views/components/tag-env/template.test.js +0 -66
  261. package/src/server/views/confirmation.html +0 -19
  262. package/src/server/views/help/accessibility-statement.html +0 -58
  263. package/src/server/views/help/cookie-preferences.html +0 -57
  264. package/src/server/views/help/cookies.html +0 -71
  265. package/src/server/views/help/get-support.html +0 -37
  266. package/src/server/views/help/privacy-notice.html +0 -68
  267. package/src/server/views/help/terms-and-conditions.html +0 -83
  268. package/src/server/views/layout.html +0 -199
  269. package/src/server/views/summary.html +0 -50
  270. package/src/typings/hapi/index.d.ts +0 -95
  271. package/src/typings/hapi-tracing/index.d.ts +0 -6
  272. package/src/typings/index.d.ts +0 -3
  273. package/src/typings/joi/index.d.ts +0 -22
  274. package/stylelint.config.js +0 -10
  275. package/test/client/javascripts/file-upload.test.js +0 -1197
  276. package/test/condition/checkboxes.test.js +0 -112
  277. package/test/condition/radios.test.js +0 -112
  278. package/test/condition/text.test.js +0 -103
  279. package/test/fixtures/assets-manifest.json +0 -4
  280. package/test/fixtures/form.js +0 -86
  281. package/test/fixtures/index.js +0 -2
  282. package/test/fixtures/list.js +0 -92
  283. package/test/form/cookies.test.js +0 -338
  284. package/test/form/csrf.test.js +0 -87
  285. package/test/form/definitions/basic.js +0 -101
  286. package/test/form/definitions/blank.js +0 -10
  287. package/test/form/definitions/checkboxes.json +0 -88
  288. package/test/form/definitions/components.json +0 -452
  289. package/test/form/definitions/conditional-reveal.js +0 -140
  290. package/test/form/definitions/conditions-basic.js +0 -187
  291. package/test/form/definitions/conditions-complex.js +0 -338
  292. package/test/form/definitions/conditions-dates.js +0 -78
  293. package/test/form/definitions/conditions-escaping.js +0 -143
  294. package/test/form/definitions/demo-cph-number.js +0 -3099
  295. package/test/form/definitions/feedback.json +0 -45
  296. package/test/form/definitions/fields-optional.js +0 -402
  297. package/test/form/definitions/fields-required.js +0 -402
  298. package/test/form/definitions/file-upload-basic.js +0 -44
  299. package/test/form/definitions/file-upload.js +0 -66
  300. package/test/form/definitions/minimal.js +0 -39
  301. package/test/form/definitions/phase-alpha.json +0 -33
  302. package/test/form/definitions/phase-default.json +0 -26
  303. package/test/form/definitions/radios.json +0 -88
  304. package/test/form/definitions/repeat-mixed.js +0 -54
  305. package/test/form/definitions/repeat.js +0 -70
  306. package/test/form/definitions/status.json +0 -126
  307. package/test/form/definitions/templates.js +0 -183
  308. package/test/form/definitions/test.json +0 -581
  309. package/test/form/definitions/text.json +0 -75
  310. package/test/form/definitions/titles.json +0 -170
  311. package/test/form/definitions.test.js +0 -47
  312. package/test/form/exit-page.test.js +0 -210
  313. package/test/form/feedback.test.js +0 -68
  314. package/test/form/fields-optional.test.js +0 -237
  315. package/test/form/fields-required.test.js +0 -294
  316. package/test/form/file-upload.test.js +0 -313
  317. package/test/form/govuk-notify.test.js +0 -449
  318. package/test/form/journey-basic.test.js +0 -444
  319. package/test/form/persist-files.test.js +0 -227
  320. package/test/form/phase-banner.test.js +0 -71
  321. package/test/form/repeat.test.js +0 -628
  322. package/test/form/summary-submission-email.test.js +0 -95
  323. package/test/form/template.test.js +0 -288
  324. package/test/form/titles.test.js +0 -204
  325. package/test/helpers/component-helpers.js +0 -74
  326. package/test/utils/get-cookie.js +0 -42
  327. package/test/utils/get-form-definitions.js +0 -18
  328. package/tmp.pdf +0 -1
  329. package/tsconfig.json +0 -28
  330. package/webpack.config.js +0 -208
@@ -1,582 +0,0 @@
1
- import { type Server } from '@hapi/hapi'
2
- import { StatusCodes } from 'http-status-codes'
3
-
4
- import { createServer } from '~/src/server/index.js'
5
- import {
6
- getFormDefinition,
7
- getFormMetadata
8
- } from '~/src/server/plugins/engine/services/formsService.js'
9
- import { getUploadStatus } from '~/src/server/plugins/engine/services/uploadService.js'
10
- import {
11
- FileStatus,
12
- UploadStatus,
13
- type UploadStatusResponse
14
- } from '~/src/server/plugins/engine/types.js'
15
- import { FormStatus } from '~/src/server/routes/types.js'
16
- import * as fixtures from '~/test/fixtures/index.js'
17
-
18
- jest.mock('~/src/server/plugins/engine/services/formsService.js')
19
- jest.mock('~/src/server/plugins/engine/services/uploadService.js')
20
-
21
- describe('Model cache', () => {
22
- let server: Server
23
-
24
- const getCacheSize = () => {
25
- return server.app.models.size
26
- }
27
-
28
- const getCacheItem = (key: string) => {
29
- return server.app.models.get(key)
30
- }
31
-
32
- beforeAll(async () => {
33
- server = await createServer()
34
- await server.initialize()
35
- })
36
-
37
- beforeEach(() => {
38
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
39
- server.app.models.clear()
40
- })
41
-
42
- afterAll(async () => {
43
- await server.stop()
44
- })
45
-
46
- describe('Success responses', () => {
47
- test('Dispatch page with the correct state returns 302', async () => {
48
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
49
- ...fixtures.form.metadata,
50
- live: fixtures.form.state
51
- })
52
-
53
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
54
-
55
- const options = {
56
- method: 'GET',
57
- url: '/slug'
58
- }
59
-
60
- const res = await server.inject(options)
61
-
62
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
63
- expect(res.headers.location).toBe('/slug/page-one')
64
- expect(getCacheSize()).toBe(1)
65
- })
66
-
67
- test('Dispatch preview page with the correct live state returns 302', async () => {
68
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
69
- ...fixtures.form.metadata,
70
- live: fixtures.form.state
71
- })
72
-
73
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
74
-
75
- const options = {
76
- method: 'GET',
77
- url: '/preview/live/slug'
78
- }
79
-
80
- const res = await server.inject(options)
81
-
82
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
83
- expect(res.headers.location).toBe('/preview/live/slug/page-one')
84
- expect(getCacheSize()).toBe(1)
85
- })
86
-
87
- test('Dispatch preview page with the correct draft state returns 302', async () => {
88
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
89
- ...fixtures.form.metadata,
90
- draft: fixtures.form.state
91
- })
92
-
93
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
94
-
95
- const options = {
96
- method: 'GET',
97
- url: '/preview/draft/slug'
98
- }
99
-
100
- const res = await server.inject(options)
101
-
102
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
103
- expect(res.headers.location).toBe('/preview/draft/slug/page-one')
104
- expect(getCacheSize()).toBe(1)
105
- })
106
-
107
- test('Get page with the correct live state returns 200', async () => {
108
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
109
- ...fixtures.form.metadata,
110
- live: fixtures.form.state
111
- })
112
-
113
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
114
-
115
- const options = {
116
- method: 'GET',
117
- url: '/slug/page-one'
118
- }
119
-
120
- const res = await server.inject(options)
121
-
122
- expect(res.statusCode).toBe(StatusCodes.OK)
123
- expect(getCacheSize()).toBe(1)
124
- })
125
-
126
- test('Get preview page with the correct live state returns 200', async () => {
127
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
128
- ...fixtures.form.metadata,
129
- live: fixtures.form.state
130
- })
131
-
132
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
133
-
134
- const options = {
135
- method: 'GET',
136
- url: '/preview/live/slug/page-one'
137
- }
138
-
139
- const res = await server.inject(options)
140
-
141
- expect(res.statusCode).toBe(StatusCodes.OK)
142
- expect(getCacheSize()).toBe(1)
143
- })
144
-
145
- test('Get preview page with the correct draft state returns 200', async () => {
146
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
147
- ...fixtures.form.metadata,
148
- draft: fixtures.form.state
149
- })
150
-
151
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
152
-
153
- const options = {
154
- method: 'GET',
155
- url: '/preview/draft/slug/page-one'
156
- }
157
-
158
- const res = await server.inject(options)
159
-
160
- expect(res.statusCode).toBe(StatusCodes.OK)
161
- expect(getCacheSize()).toBe(1)
162
- })
163
-
164
- test('Get page with the correct state returns 200', async () => {
165
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
166
- ...fixtures.form.metadata,
167
- live: fixtures.form.state
168
- })
169
-
170
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
171
-
172
- const options = {
173
- method: 'GET',
174
- url: '/slug/page-one'
175
- }
176
-
177
- const res = await server.inject(options)
178
-
179
- expect(res.statusCode).toBe(StatusCodes.OK)
180
- expect(getCacheSize()).toBe(1)
181
- })
182
-
183
- test('Get page with the correct state populates the cache correctly', async () => {
184
- jest.mocked(getFormMetadata).mockResolvedValue({
185
- ...fixtures.form.metadata,
186
- draft: fixtures.form.state,
187
- live: fixtures.form.state
188
- })
189
-
190
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
191
-
192
- // Populate live/live cache item
193
- const options1 = {
194
- method: 'GET',
195
- url: '/slug/page-one'
196
- }
197
-
198
- const res1 = await server.inject(options1)
199
-
200
- expect(res1.statusCode).toBe(StatusCodes.OK)
201
- expect(getCacheSize()).toBe(1)
202
-
203
- // Populate live/preview cache item
204
- const options2 = {
205
- method: 'GET',
206
- url: '/preview/live/slug/page-one'
207
- }
208
-
209
- const res2 = await server.inject(options2)
210
-
211
- expect(res2.statusCode).toBe(StatusCodes.OK)
212
- expect(getCacheSize()).toBe(2)
213
-
214
- // Populate draft/preview cache item
215
- const options3 = {
216
- method: 'GET',
217
- url: '/preview/draft/slug/page-one'
218
- }
219
-
220
- const res3 = await server.inject(options3)
221
-
222
- expect(res3.statusCode).toBe(StatusCodes.OK)
223
- expect(getCacheSize()).toBe(3)
224
-
225
- // Execute each request again and
226
- // assert the cache size is unchanged
227
- await server.inject(options1)
228
- await server.inject(options2)
229
- await server.inject(options3)
230
-
231
- expect(getCacheSize()).toBe(3)
232
-
233
- // Check models cache item is regenerated on an update to the state
234
- const now2 = new Date()
235
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
236
- ...fixtures.form.metadata,
237
- draft: fixtures.form.state,
238
- live: { ...fixtures.form.state, updatedAt: now2 }
239
- })
240
-
241
- await server.inject(options1)
242
-
243
- // Expect `getFormDefinition` to be called as the updatedAt has moved on
244
- expect(getFormDefinition).toHaveBeenLastCalledWith(
245
- fixtures.form.metadata.id,
246
- FormStatus.Live
247
- )
248
-
249
- // Assert the live/live cache item has the correct updatedAt timestamp
250
- expect(
251
- getCacheItem(`${fixtures.form.metadata.id}_live_false`)?.updatedAt
252
- ).toBe(now2)
253
-
254
- // Expect the cache size to remain unchanged
255
- expect(getCacheSize()).toBe(3)
256
-
257
- // Assert the number of times `getFormDefinition`
258
- // has only been called 4 times for the 7 requests
259
- expect(getFormDefinition).toHaveBeenCalledTimes(4)
260
- })
261
- })
262
-
263
- describe('Error responses', () => {
264
- test('Dispatch page without the correct state returns 404', async () => {
265
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
266
-
267
- const options = {
268
- method: 'GET',
269
- url: '/slug'
270
- }
271
-
272
- const res = await server.inject(options)
273
-
274
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
275
- expect(getCacheSize()).toBe(0)
276
- })
277
-
278
- test('Dispatch preview page without the correct draft state returns 404', async () => {
279
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
280
-
281
- const options = {
282
- method: 'GET',
283
- url: '/preview/draft/slug'
284
- }
285
-
286
- const res = await server.inject(options)
287
-
288
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
289
- expect(getCacheSize()).toBe(0)
290
- })
291
-
292
- test('Dispatch preview page without the correct live state returns 404', async () => {
293
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
294
-
295
- const options = {
296
- method: 'GET',
297
- url: '/preview/live/slug'
298
- }
299
-
300
- const res = await server.inject(options)
301
-
302
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
303
- expect(getCacheSize()).toBe(0)
304
- })
305
-
306
- test('Dispatch page with the correct live state but no definition returns 404', async () => {
307
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
308
- ...fixtures.form.metadata,
309
- live: fixtures.form.state
310
- })
311
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
312
-
313
- const options = {
314
- method: 'GET',
315
- url: '/slug'
316
- }
317
-
318
- const res = await server.inject(options)
319
-
320
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
321
- expect(getCacheSize()).toBe(0)
322
- })
323
-
324
- test('Dispatch preview page with the correct draft state but no definition returns 404', async () => {
325
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
326
- ...fixtures.form.metadata,
327
- live: fixtures.form.state
328
- })
329
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
330
-
331
- const options = {
332
- method: 'GET',
333
- url: '/preview/draft/slug'
334
- }
335
-
336
- const res = await server.inject(options)
337
-
338
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
339
- expect(getCacheSize()).toBe(0)
340
- })
341
-
342
- test('Dispatch preview page with the correct live state but no definition returns 404', async () => {
343
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
344
- ...fixtures.form.metadata,
345
- live: fixtures.form.state
346
- })
347
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
348
-
349
- const options = {
350
- method: 'GET',
351
- url: '/preview/live/slug'
352
- }
353
-
354
- const res = await server.inject(options)
355
-
356
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
357
- expect(getCacheSize()).toBe(0)
358
- })
359
-
360
- test('Get page without the correct state returns 404', async () => {
361
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
362
-
363
- const options = {
364
- method: 'GET',
365
- url: '/slug/page-one'
366
- }
367
-
368
- const res = await server.inject(options)
369
-
370
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
371
- expect(getCacheSize()).toBe(0)
372
- })
373
-
374
- test('Get preview page without the correct draft state returns 404', async () => {
375
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
376
-
377
- const options = {
378
- method: 'GET',
379
- url: '/preview/draft/slug/page-one'
380
- }
381
-
382
- const res = await server.inject(options)
383
-
384
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
385
- expect(getCacheSize()).toBe(0)
386
- })
387
-
388
- test('Get preview page without the correct live state returns 404', async () => {
389
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
390
-
391
- const options = {
392
- method: 'GET',
393
- url: '/preview/live/slug/page-one'
394
- }
395
-
396
- const res = await server.inject(options)
397
-
398
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
399
- expect(getCacheSize()).toBe(0)
400
- })
401
-
402
- test('Get page with the correct live state but no definition returns 404', async () => {
403
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
404
- ...fixtures.form.metadata,
405
- live: fixtures.form.state
406
- })
407
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
408
-
409
- const options = {
410
- method: 'GET',
411
- url: '/slug/page-one'
412
- }
413
-
414
- const res = await server.inject(options)
415
-
416
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
417
- expect(getCacheSize()).toBe(0)
418
- })
419
-
420
- test('Get preview page with the correct draft state but no definition returns 404', async () => {
421
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
422
- ...fixtures.form.metadata,
423
- live: fixtures.form.state
424
- })
425
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
426
-
427
- const options = {
428
- method: 'GET',
429
- url: '/preview/draft/slug/page-one'
430
- }
431
-
432
- const res = await server.inject(options)
433
-
434
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
435
- expect(getCacheSize()).toBe(0)
436
- })
437
-
438
- test('Get preview page with the correct live state but no definition returns 404', async () => {
439
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
440
- ...fixtures.form.metadata,
441
- live: fixtures.form.state
442
- })
443
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
444
-
445
- const options = {
446
- method: 'GET',
447
- url: '/preview/live/slug/page-one'
448
- }
449
-
450
- const res = await server.inject(options)
451
-
452
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
453
- expect(getCacheSize()).toBe(0)
454
- })
455
- })
456
-
457
- describe('Help pages', () => {
458
- test('Contextual help page returns 200', async () => {
459
- jest.mocked(getFormMetadata).mockResolvedValue({
460
- ...fixtures.form.metadata,
461
- draft: fixtures.form.state,
462
- live: fixtures.form.state
463
- })
464
-
465
- const options = {
466
- method: 'GET',
467
- url: '/help/get-support/slug'
468
- }
469
-
470
- const res = await server.inject(options)
471
-
472
- expect(res.statusCode).toBe(StatusCodes.OK)
473
- })
474
-
475
- test('Privacy notice page returns 200', async () => {
476
- jest.mocked(getFormMetadata).mockResolvedValue({
477
- ...fixtures.form.metadata,
478
- draft: fixtures.form.state,
479
- live: fixtures.form.state
480
- })
481
-
482
- const options = {
483
- method: 'GET',
484
- url: '/help/privacy/slug'
485
- }
486
-
487
- const res = await server.inject(options)
488
-
489
- expect(res.statusCode).toBe(StatusCodes.OK)
490
- })
491
- })
492
- })
493
-
494
- describe('Upload status route', () => {
495
- let server: Server
496
-
497
- beforeAll(async () => {
498
- server = await createServer()
499
- await server.initialize()
500
- })
501
-
502
- afterAll(async () => {
503
- await server.stop()
504
- })
505
-
506
- beforeEach(() => {
507
- jest.resetAllMocks()
508
- })
509
-
510
- test('GET /upload-status/{uploadId} returns upload status with 200 when successful', async () => {
511
- const mockStatus: UploadStatusResponse = {
512
- uploadStatus: UploadStatus.ready,
513
- metadata: {
514
- retrievalKey: 'some-key'
515
- },
516
- form: {
517
- file: {
518
- fileId: 'some-file-id',
519
- filename: 'some-file-name',
520
- contentLength: 1024,
521
- fileStatus: FileStatus.complete
522
- }
523
- },
524
- numberOfRejectedFiles: 0
525
- }
526
- jest.mocked(getUploadStatus).mockResolvedValueOnce(mockStatus)
527
-
528
- const options = {
529
- method: 'GET',
530
- url: '/upload-status/123e4567-e89b-12d3-a456-426614174000'
531
- }
532
-
533
- const res = await server.inject(options)
534
-
535
- expect(res.statusCode).toBe(StatusCodes.OK)
536
- expect(res.result).toEqual(mockStatus)
537
- expect(getUploadStatus).toHaveBeenCalledWith(
538
- '123e4567-e89b-12d3-a456-426614174000'
539
- )
540
- })
541
-
542
- test('GET /upload-status/{uploadId} returns 400 when status check fails', async () => {
543
- jest.mocked(getUploadStatus).mockResolvedValueOnce(undefined)
544
-
545
- const options = {
546
- method: 'GET',
547
- url: '/upload-status/123e4567-e89b-12d3-a456-426614174000'
548
- }
549
-
550
- const res = await server.inject(options)
551
-
552
- expect(res.statusCode).toBe(StatusCodes.BAD_REQUEST)
553
- expect(res.result).toEqual({ error: 'Status check failed' })
554
- })
555
-
556
- test('GET /upload-status/{uploadId} returns 500 when exception occurs', async () => {
557
- jest
558
- .mocked(getUploadStatus)
559
- .mockRejectedValueOnce(new Error('Service unavailable'))
560
-
561
- const options = {
562
- method: 'GET',
563
- url: '/upload-status/123e4567-e89b-12d3-a456-426614174000'
564
- }
565
-
566
- const res = await server.inject(options)
567
-
568
- expect(res.statusCode).toBe(StatusCodes.INTERNAL_SERVER_ERROR)
569
- expect(res.result).toEqual({ error: 'Status check error' })
570
- })
571
-
572
- test('GET /upload-status/{uploadId} returns 400 for invalid uploadId format', async () => {
573
- const options = {
574
- method: 'GET',
575
- url: '/upload-status/not-a-valid-guid'
576
- }
577
-
578
- const res = await server.inject(options)
579
-
580
- expect(res.statusCode).toBe(StatusCodes.BAD_REQUEST)
581
- })
582
- })