@defra/forms-engine-plugin 0.0.3 → 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 (328) 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/package.json +6 -2
  25. package/.browserslistrc +0 -16
  26. package/.editorconfig +0 -9
  27. package/.eslintrc.cjs +0 -266
  28. package/.github/dependabot.yml +0 -85
  29. package/.github/workflows/check-pull-request.yml +0 -209
  30. package/.github/workflows/pr-notifier.yml +0 -98
  31. package/.github/workflows/publish.yml +0 -111
  32. package/.husky/pre-commit +0 -1
  33. package/.lintstagedrc.js +0 -4
  34. package/.nvmrc +0 -1
  35. package/.prettierignore +0 -8
  36. package/.prettierrc.cjs +0 -26
  37. package/Dockerfile +0 -61
  38. package/Procfile +0 -1
  39. package/babel.config.cjs +0 -55
  40. package/compose/aws.env +0 -4
  41. package/compose/start-localstack.sh +0 -26
  42. package/docker-compose.yaml +0 -86
  43. package/globals.d.ts +0 -1
  44. package/jest.config.cjs +0 -54
  45. package/jest.environment.js +0 -4
  46. package/jest.setup.cjs +0 -14
  47. package/postcss.config.js +0 -26
  48. package/sonar-project.properties +0 -17
  49. package/src/client/javascripts/application.js +0 -87
  50. package/src/client/javascripts/file-upload.js +0 -386
  51. package/src/client/stylesheets/_code.scss +0 -33
  52. package/src/client/stylesheets/_govuk-frontend.scss +0 -4
  53. package/src/client/stylesheets/_prose.scss +0 -56
  54. package/src/client/stylesheets/_service-banner.scss +0 -24
  55. package/src/client/stylesheets/_summary-list.scss +0 -28
  56. package/src/client/stylesheets/_tag-env.scss +0 -24
  57. package/src/client/stylesheets/application.scss +0 -14
  58. package/src/common/cookies.js +0 -58
  59. package/src/common/cookies.test.js +0 -23
  60. package/src/common/types.js +0 -5
  61. package/src/config/index.ts +0 -271
  62. package/src/index.ts +0 -31
  63. package/src/server/common/helpers/logging/logger-options.test.ts +0 -50
  64. package/src/server/common/helpers/logging/logger-options.ts +0 -46
  65. package/src/server/common/helpers/logging/logger.ts +0 -7
  66. package/src/server/common/helpers/logging/request-logger.ts +0 -9
  67. package/src/server/common/helpers/logging/request-tracing.js +0 -10
  68. package/src/server/common/helpers/redis-client.js +0 -70
  69. package/src/server/constants.js +0 -1
  70. package/src/server/forms/README.md +0 -10
  71. package/src/server/forms/components.json +0 -1015
  72. package/src/server/forms/report-a-terrorist.json +0 -270
  73. package/src/server/forms/runner-components-test.json +0 -365
  74. package/src/server/forms/test.json +0 -581
  75. package/src/server/index.test.ts +0 -582
  76. package/src/server/index.ts +0 -140
  77. package/src/server/plugins/blankie.test.ts +0 -73
  78. package/src/server/plugins/blankie.ts +0 -48
  79. package/src/server/plugins/crumb.ts +0 -20
  80. package/src/server/plugins/engine/README.md +0 -87
  81. package/src/server/plugins/engine/components/AutocompleteField.test.ts +0 -294
  82. package/src/server/plugins/engine/components/AutocompleteField.ts +0 -49
  83. package/src/server/plugins/engine/components/CheckboxesField.test.ts +0 -379
  84. package/src/server/plugins/engine/components/CheckboxesField.ts +0 -106
  85. package/src/server/plugins/engine/components/ComponentBase.ts +0 -97
  86. package/src/server/plugins/engine/components/ComponentCollection.ts +0 -278
  87. package/src/server/plugins/engine/components/DatePartsField.test.ts +0 -822
  88. package/src/server/plugins/engine/components/DatePartsField.ts +0 -264
  89. package/src/server/plugins/engine/components/Details.test.ts +0 -49
  90. package/src/server/plugins/engine/components/Details.ts +0 -30
  91. package/src/server/plugins/engine/components/EmailAddressField.test.ts +0 -395
  92. package/src/server/plugins/engine/components/EmailAddressField.ts +0 -55
  93. package/src/server/plugins/engine/components/FileUploadField.test.ts +0 -778
  94. package/src/server/plugins/engine/components/FileUploadField.ts +0 -262
  95. package/src/server/plugins/engine/components/FormComponent.ts +0 -249
  96. package/src/server/plugins/engine/components/Html.test.ts +0 -48
  97. package/src/server/plugins/engine/components/Html.ts +0 -29
  98. package/src/server/plugins/engine/components/InsetText.test.ts +0 -48
  99. package/src/server/plugins/engine/components/InsetText.ts +0 -27
  100. package/src/server/plugins/engine/components/List.test.ts +0 -76
  101. package/src/server/plugins/engine/components/List.ts +0 -72
  102. package/src/server/plugins/engine/components/ListFormComponent.ts +0 -140
  103. package/src/server/plugins/engine/components/MonthYearField.test.ts +0 -567
  104. package/src/server/plugins/engine/components/MonthYearField.ts +0 -222
  105. package/src/server/plugins/engine/components/MultilineTextField.test.ts +0 -558
  106. package/src/server/plugins/engine/components/MultilineTextField.ts +0 -138
  107. package/src/server/plugins/engine/components/NumberField.test.ts +0 -701
  108. package/src/server/plugins/engine/components/NumberField.ts +0 -163
  109. package/src/server/plugins/engine/components/RadiosField.test.ts +0 -288
  110. package/src/server/plugins/engine/components/RadiosField.ts +0 -24
  111. package/src/server/plugins/engine/components/SelectField.test.ts +0 -288
  112. package/src/server/plugins/engine/components/SelectField.ts +0 -47
  113. package/src/server/plugins/engine/components/SelectionControlField.ts +0 -43
  114. package/src/server/plugins/engine/components/TelephoneNumberField.test.ts +0 -356
  115. package/src/server/plugins/engine/components/TelephoneNumberField.ts +0 -67
  116. package/src/server/plugins/engine/components/TextField.test.ts +0 -489
  117. package/src/server/plugins/engine/components/TextField.ts +0 -96
  118. package/src/server/plugins/engine/components/UkAddressField.test.ts +0 -623
  119. package/src/server/plugins/engine/components/UkAddressField.ts +0 -172
  120. package/src/server/plugins/engine/components/YesNoField.test.ts +0 -248
  121. package/src/server/plugins/engine/components/YesNoField.ts +0 -31
  122. package/src/server/plugins/engine/components/constants.ts +0 -1
  123. package/src/server/plugins/engine/components/helpers.ts +0 -330
  124. package/src/server/plugins/engine/components/index.ts +0 -24
  125. package/src/server/plugins/engine/components/types.ts +0 -117
  126. package/src/server/plugins/engine/configureEnginePlugin.ts +0 -47
  127. package/src/server/plugins/engine/helpers.test.ts +0 -791
  128. package/src/server/plugins/engine/helpers.ts +0 -379
  129. package/src/server/plugins/engine/index.ts +0 -7
  130. package/src/server/plugins/engine/models/FormModel.test.ts +0 -42
  131. package/src/server/plugins/engine/models/FormModel.ts +0 -443
  132. package/src/server/plugins/engine/models/RepeatingSummaryViewModel.ts +0 -0
  133. package/src/server/plugins/engine/models/Section.ts +0 -0
  134. package/src/server/plugins/engine/models/SummaryViewModel.test.ts +0 -209
  135. package/src/server/plugins/engine/models/SummaryViewModel.ts +0 -220
  136. package/src/server/plugins/engine/models/index.ts +0 -2
  137. package/src/server/plugins/engine/models/types.ts +0 -114
  138. package/src/server/plugins/engine/outputFormatters/human/v1.test.ts +0 -143
  139. package/src/server/plugins/engine/outputFormatters/human/v1.ts +0 -73
  140. package/src/server/plugins/engine/outputFormatters/index.test.ts +0 -17
  141. package/src/server/plugins/engine/outputFormatters/index.ts +0 -44
  142. package/src/server/plugins/engine/outputFormatters/machine/v1.test.ts +0 -229
  143. package/src/server/plugins/engine/outputFormatters/machine/v1.ts +0 -140
  144. package/src/server/plugins/engine/outputFormatters/machine/v2.test.ts +0 -229
  145. package/src/server/plugins/engine/outputFormatters/machine/v2.ts +0 -153
  146. package/src/server/plugins/engine/pageControllers/FileUploadPageController.test.ts +0 -1108
  147. package/src/server/plugins/engine/pageControllers/FileUploadPageController.ts +0 -446
  148. package/src/server/plugins/engine/pageControllers/PageController.test.ts +0 -205
  149. package/src/server/plugins/engine/pageControllers/PageController.ts +0 -176
  150. package/src/server/plugins/engine/pageControllers/QuestionPageController.test.ts +0 -1264
  151. package/src/server/plugins/engine/pageControllers/QuestionPageController.ts +0 -561
  152. package/src/server/plugins/engine/pageControllers/README.md +0 -28
  153. package/src/server/plugins/engine/pageControllers/RepeatPageController.test.ts +0 -264
  154. package/src/server/plugins/engine/pageControllers/RepeatPageController.ts +0 -458
  155. package/src/server/plugins/engine/pageControllers/StartPageController.ts +0 -18
  156. package/src/server/plugins/engine/pageControllers/StatusPageController.ts +0 -50
  157. package/src/server/plugins/engine/pageControllers/SummaryPageController.ts +0 -261
  158. package/src/server/plugins/engine/pageControllers/TerminalController.test.ts +0 -28
  159. package/src/server/plugins/engine/pageControllers/TerminalPageController.ts +0 -19
  160. package/src/server/plugins/engine/pageControllers/helpers.test.ts +0 -198
  161. package/src/server/plugins/engine/pageControllers/helpers.ts +0 -101
  162. package/src/server/plugins/engine/pageControllers/index.ts +0 -10
  163. package/src/server/plugins/engine/pageControllers/validationOptions.ts +0 -89
  164. package/src/server/plugins/engine/plugin.ts +0 -673
  165. package/src/server/plugins/engine/services/formSubmissionService.js +0 -46
  166. package/src/server/plugins/engine/services/formsService.js +0 -46
  167. package/src/server/plugins/engine/services/formsService.test.js +0 -90
  168. package/src/server/plugins/engine/services/index.js +0 -3
  169. package/src/server/plugins/engine/services/notifyService.test.ts +0 -132
  170. package/src/server/plugins/engine/services/notifyService.ts +0 -64
  171. package/src/server/plugins/engine/services/uploadService.js +0 -60
  172. package/src/server/plugins/engine/types.ts +0 -315
  173. package/src/server/plugins/engine/views/components/autocompletefield.html +0 -5
  174. package/src/server/plugins/engine/views/components/checkboxesfield.html +0 -5
  175. package/src/server/plugins/engine/views/components/datepartsfield.html +0 -5
  176. package/src/server/plugins/engine/views/components/details.html +0 -6
  177. package/src/server/plugins/engine/views/components/emailaddressfield.html +0 -5
  178. package/src/server/plugins/engine/views/components/fileuploadfield-key.html +0 -8
  179. package/src/server/plugins/engine/views/components/fileuploadfield-value.html +0 -3
  180. package/src/server/plugins/engine/views/components/fileuploadfield.html +0 -24
  181. package/src/server/plugins/engine/views/components/html.html +0 -3
  182. package/src/server/plugins/engine/views/components/insettext.html +0 -7
  183. package/src/server/plugins/engine/views/components/list.html +0 -36
  184. package/src/server/plugins/engine/views/components/monthyearfield.html +0 -5
  185. package/src/server/plugins/engine/views/components/multilinetextfield.html +0 -10
  186. package/src/server/plugins/engine/views/components/numberfield.html +0 -5
  187. package/src/server/plugins/engine/views/components/radiosfield.html +0 -5
  188. package/src/server/plugins/engine/views/components/selectfield.html +0 -5
  189. package/src/server/plugins/engine/views/components/telephonenumberfield.html +0 -5
  190. package/src/server/plugins/engine/views/components/textfield.html +0 -5
  191. package/src/server/plugins/engine/views/components/ukaddressfield.html +0 -25
  192. package/src/server/plugins/engine/views/components/yesnofield.html +0 -5
  193. package/src/server/plugins/engine/views/file-upload.html +0 -45
  194. package/src/server/plugins/engine/views/index.html +0 -39
  195. package/src/server/plugins/engine/views/item-delete.html +0 -56
  196. package/src/server/plugins/engine/views/partials/components.html +0 -6
  197. package/src/server/plugins/engine/views/partials/conditional-components.html +0 -3
  198. package/src/server/plugins/engine/views/partials/debug.html +0 -44
  199. package/src/server/plugins/engine/views/partials/form.html +0 -15
  200. package/src/server/plugins/engine/views/partials/heading.html +0 -16
  201. package/src/server/plugins/engine/views/partials/preview-banner.html +0 -32
  202. package/src/server/plugins/engine/views/partials/preview-banner.test.js +0 -122
  203. package/src/server/plugins/engine/views/partials/warn-missing-notification-email.html +0 -10
  204. package/src/server/plugins/engine/views/repeat-list-summary.html +0 -53
  205. package/src/server/plugins/errorPages.ts +0 -58
  206. package/src/server/plugins/nunjucks/context.js +0 -88
  207. package/src/server/plugins/nunjucks/context.test.js +0 -142
  208. package/src/server/plugins/nunjucks/enviroment.test.js +0 -201
  209. package/src/server/plugins/nunjucks/environment.js +0 -116
  210. package/src/server/plugins/nunjucks/filters/answer.js +0 -27
  211. package/src/server/plugins/nunjucks/filters/answer.test.js +0 -89
  212. package/src/server/plugins/nunjucks/filters/evaluate.js +0 -21
  213. package/src/server/plugins/nunjucks/filters/field.js +0 -28
  214. package/src/server/plugins/nunjucks/filters/field.test.js +0 -75
  215. package/src/server/plugins/nunjucks/filters/highlight.js +0 -11
  216. package/src/server/plugins/nunjucks/filters/href.js +0 -30
  217. package/src/server/plugins/nunjucks/filters/href.test.js +0 -80
  218. package/src/server/plugins/nunjucks/filters/index.js +0 -8
  219. package/src/server/plugins/nunjucks/filters/inspect.js +0 -15
  220. package/src/server/plugins/nunjucks/filters/page.js +0 -24
  221. package/src/server/plugins/nunjucks/filters/page.test.js +0 -65
  222. package/src/server/plugins/nunjucks/index.js +0 -3
  223. package/src/server/plugins/nunjucks/plugin.js +0 -40
  224. package/src/server/plugins/nunjucks/render.js +0 -42
  225. package/src/server/plugins/nunjucks/types.js +0 -40
  226. package/src/server/plugins/pulse.ts +0 -11
  227. package/src/server/plugins/router.ts +0 -201
  228. package/src/server/plugins/session.ts +0 -28
  229. package/src/server/routes/health.js +0 -13
  230. package/src/server/routes/health.test.js +0 -35
  231. package/src/server/routes/index.test.ts +0 -125
  232. package/src/server/routes/index.ts +0 -2
  233. package/src/server/routes/public.ts +0 -47
  234. package/src/server/routes/types.ts +0 -48
  235. package/src/server/schemas/index.ts +0 -34
  236. package/src/server/secure-context.js +0 -43
  237. package/src/server/services/cacheService.test.ts +0 -276
  238. package/src/server/services/cacheService.ts +0 -131
  239. package/src/server/services/httpService.test.js +0 -491
  240. package/src/server/services/httpService.ts +0 -50
  241. package/src/server/services/index.ts +0 -1
  242. package/src/server/types.ts +0 -54
  243. package/src/server/utils/notify.test.ts +0 -37
  244. package/src/server/utils/notify.ts +0 -50
  245. package/src/server/utils/secure-context/get-trust-store-certs.js +0 -11
  246. package/src/server/utils/secure-context/get-trust-store-certs.test.js +0 -19
  247. package/src/server/utils/utils.js +0 -24
  248. package/src/server/utils/utils.test.js +0 -54
  249. package/src/server/views/404.html +0 -16
  250. package/src/server/views/500.html +0 -19
  251. package/src/server/views/components/debug/macro.njk +0 -3
  252. package/src/server/views/components/debug/template.njk +0 -13
  253. package/src/server/views/components/service-banner/macro.njk +0 -3
  254. package/src/server/views/components/service-banner/template.njk +0 -20
  255. package/src/server/views/components/service-banner/template.test.js +0 -43
  256. package/src/server/views/components/tag-env/macro.njk +0 -3
  257. package/src/server/views/components/tag-env/template.njk +0 -30
  258. package/src/server/views/components/tag-env/template.test.js +0 -66
  259. package/src/server/views/confirmation.html +0 -19
  260. package/src/server/views/help/accessibility-statement.html +0 -58
  261. package/src/server/views/help/cookie-preferences.html +0 -57
  262. package/src/server/views/help/cookies.html +0 -71
  263. package/src/server/views/help/get-support.html +0 -37
  264. package/src/server/views/help/privacy-notice.html +0 -68
  265. package/src/server/views/help/terms-and-conditions.html +0 -83
  266. package/src/server/views/layout.html +0 -199
  267. package/src/server/views/summary.html +0 -50
  268. package/src/typings/hapi/index.d.ts +0 -95
  269. package/src/typings/hapi-tracing/index.d.ts +0 -6
  270. package/src/typings/index.d.ts +0 -3
  271. package/src/typings/joi/index.d.ts +0 -22
  272. package/stylelint.config.js +0 -10
  273. package/test/client/javascripts/file-upload.test.js +0 -1197
  274. package/test/condition/checkboxes.test.js +0 -112
  275. package/test/condition/radios.test.js +0 -112
  276. package/test/condition/text.test.js +0 -103
  277. package/test/fixtures/assets-manifest.json +0 -4
  278. package/test/fixtures/form.js +0 -86
  279. package/test/fixtures/index.js +0 -2
  280. package/test/fixtures/list.js +0 -92
  281. package/test/form/cookies.test.js +0 -338
  282. package/test/form/csrf.test.js +0 -87
  283. package/test/form/definitions/basic.js +0 -101
  284. package/test/form/definitions/blank.js +0 -10
  285. package/test/form/definitions/checkboxes.json +0 -88
  286. package/test/form/definitions/components.json +0 -452
  287. package/test/form/definitions/conditional-reveal.js +0 -140
  288. package/test/form/definitions/conditions-basic.js +0 -187
  289. package/test/form/definitions/conditions-complex.js +0 -338
  290. package/test/form/definitions/conditions-dates.js +0 -78
  291. package/test/form/definitions/conditions-escaping.js +0 -143
  292. package/test/form/definitions/demo-cph-number.js +0 -3099
  293. package/test/form/definitions/feedback.json +0 -45
  294. package/test/form/definitions/fields-optional.js +0 -402
  295. package/test/form/definitions/fields-required.js +0 -402
  296. package/test/form/definitions/file-upload-basic.js +0 -44
  297. package/test/form/definitions/file-upload.js +0 -66
  298. package/test/form/definitions/minimal.js +0 -39
  299. package/test/form/definitions/phase-alpha.json +0 -33
  300. package/test/form/definitions/phase-default.json +0 -26
  301. package/test/form/definitions/radios.json +0 -88
  302. package/test/form/definitions/repeat-mixed.js +0 -54
  303. package/test/form/definitions/repeat.js +0 -70
  304. package/test/form/definitions/status.json +0 -126
  305. package/test/form/definitions/templates.js +0 -183
  306. package/test/form/definitions/test.json +0 -581
  307. package/test/form/definitions/text.json +0 -75
  308. package/test/form/definitions/titles.json +0 -170
  309. package/test/form/definitions.test.js +0 -47
  310. package/test/form/exit-page.test.js +0 -210
  311. package/test/form/feedback.test.js +0 -68
  312. package/test/form/fields-optional.test.js +0 -237
  313. package/test/form/fields-required.test.js +0 -294
  314. package/test/form/file-upload.test.js +0 -313
  315. package/test/form/govuk-notify.test.js +0 -449
  316. package/test/form/journey-basic.test.js +0 -444
  317. package/test/form/persist-files.test.js +0 -227
  318. package/test/form/phase-banner.test.js +0 -71
  319. package/test/form/repeat.test.js +0 -628
  320. package/test/form/summary-submission-email.test.js +0 -95
  321. package/test/form/template.test.js +0 -288
  322. package/test/form/titles.test.js +0 -204
  323. package/test/helpers/component-helpers.js +0 -74
  324. package/test/utils/get-cookie.js +0 -42
  325. package/test/utils/get-form-definitions.js +0 -18
  326. package/tmp.pdf +0 -1
  327. package/tsconfig.json +0 -28
  328. 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
- })