@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,95 +0,0 @@
1
- import { join } from 'node:path'
2
-
3
- import { createServer } from '~/src/server/index.js'
4
- import { getFormMetadata } from '~/src/server/plugins/engine/services/formsService.js'
5
- import * as fixtures from '~/test/fixtures/index.js'
6
- import { renderResponse } from '~/test/helpers/component-helpers.js'
7
- import { getCookie, getCookieHeader } from '~/test/utils/get-cookie.js'
8
-
9
- const basePath = '/minimal'
10
-
11
- jest.mock('~/src/server/plugins/engine/services/formsService.js')
12
- jest.mock('~/src/server/plugins/engine/services/formSubmissionService.js')
13
-
14
- describe('Page: /summary', () => {
15
- /** @type {Server} */
16
- let server
17
-
18
- /** @type {string} */
19
- let csrfToken
20
-
21
- /** @type {ReturnType<typeof getCookieHeader>} */
22
- let headers
23
-
24
- beforeAll(async () => {
25
- server = await createServer({
26
- formFileName: 'minimal.js',
27
- formFilePath: join(import.meta.dirname, 'definitions'),
28
- enforceCsrf: true
29
- })
30
-
31
- await server.initialize()
32
-
33
- // Navigate to start
34
- const response = await server.inject({
35
- url: `${basePath}/start`,
36
- headers
37
- })
38
-
39
- // Extract the session cookie
40
- csrfToken = getCookie(response, 'crumb')
41
- headers = getCookieHeader(response, ['session', 'crumb'])
42
-
43
- // Submit answers
44
- await server.inject({
45
- url: `${basePath}/start`,
46
- method: 'POST',
47
- headers,
48
- payload: {
49
- crumb: csrfToken,
50
- field: 'value'
51
- }
52
- })
53
- })
54
-
55
- beforeEach(() => {
56
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
57
- })
58
-
59
- it('should render the page with email notification warning', async () => {
60
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
61
-
62
- const { container } = await renderResponse(server, {
63
- url: `${basePath}/summary`,
64
- headers
65
- })
66
-
67
- const $warning = container.getByRole('link', {
68
- name: 'enter the email address (opens in new tab)'
69
- })
70
-
71
- expect($warning).toBeInTheDocument()
72
- })
73
-
74
- it('should render the page with no email notification warning', async () => {
75
- jest.mocked(getFormMetadata).mockResolvedValue({
76
- ...fixtures.form.metadata,
77
- notificationEmail: 'defra@gov.uk'
78
- })
79
-
80
- const { container } = await renderResponse(server, {
81
- url: `${basePath}/summary`,
82
- headers
83
- })
84
-
85
- const $warning = container.queryByRole('link', {
86
- name: 'enter the email address (opens in new tab)'
87
- })
88
-
89
- expect($warning).not.toBeInTheDocument()
90
- })
91
- })
92
-
93
- /**
94
- * @import { Server } from '@hapi/hapi'
95
- */
@@ -1,288 +0,0 @@
1
- import { join } from 'node:path'
2
-
3
- import { within } from '@testing-library/dom'
4
- import { StatusCodes } from 'http-status-codes'
5
-
6
- import { createServer } from '~/src/server/index.js'
7
- import { getFormMetadata } from '~/src/server/plugins/engine/services/formsService.js'
8
- import * as fixtures from '~/test/fixtures/index.js'
9
- import { renderResponse } from '~/test/helpers/component-helpers.js'
10
- import { getCookie, getCookieHeader } from '~/test/utils/get-cookie.js'
11
-
12
- const basePath = '/templates'
13
-
14
- jest.mock('~/src/server/plugins/engine/services/formsService.js')
15
-
16
- describe('Form template journey', () => {
17
- /** @type {Server} */
18
- let server
19
-
20
- /** @type {string} */
21
- let csrfToken
22
-
23
- /** @type {ReturnType<typeof getCookieHeader>} */
24
- let headers
25
-
26
- // Create server before each test
27
- beforeAll(async () => {
28
- server = await createServer({
29
- formFileName: 'templates.js',
30
- formFilePath: join(import.meta.dirname, 'definitions'),
31
- enforceCsrf: true
32
- })
33
-
34
- await server.initialize()
35
-
36
- // Navigate to start
37
- const response = await server.inject({
38
- url: `${basePath}/start`
39
- })
40
-
41
- // Extract the session cookie
42
- csrfToken = getCookie(response, 'crumb')
43
- headers = getCookieHeader(response, ['session', 'crumb'])
44
- })
45
-
46
- beforeEach(() => {
47
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
48
- })
49
-
50
- afterAll(async () => {
51
- await server.stop()
52
- })
53
-
54
- test('GET /start', async () => {
55
- const { container, response } = await renderResponse(server, {
56
- url: `${basePath}/start`,
57
- headers
58
- })
59
-
60
- expect(response.statusCode).toBe(StatusCodes.OK)
61
-
62
- const $heading = container.getByRole('heading', {
63
- name: 'Start page',
64
- level: 1
65
- })
66
-
67
- expect($heading).toBeInTheDocument()
68
- })
69
-
70
- test('GET /full-name', async () => {
71
- const { container, response } = await renderResponse(server, {
72
- url: `${basePath}/full-name`,
73
- headers
74
- })
75
-
76
- expect(response.statusCode).toBe(StatusCodes.OK)
77
-
78
- const $heading = container.getByRole('heading', {
79
- name: "What's your name?",
80
- level: 1
81
- })
82
-
83
- expect($heading).toBeInTheDocument()
84
- })
85
-
86
- test('POST /full-name', async () => {
87
- const { response } = await renderResponse(server, {
88
- url: `${basePath}/full-name`,
89
- method: 'POST',
90
- headers,
91
- payload: { WmHfSb: 'Enrique Chase', crumb: csrfToken }
92
- })
93
-
94
- expect(response.statusCode).toBe(StatusCodes.SEE_OTHER)
95
- expect(response.headers.location).toBe(`${basePath}/are-you-in-england`)
96
- })
97
-
98
- test('GET /are-you-in-england', async () => {
99
- const { container, response } = await renderResponse(server, {
100
- url: `${basePath}/are-you-in-england`,
101
- headers
102
- })
103
-
104
- expect(response.statusCode).toBe(StatusCodes.OK)
105
-
106
- const $title = await container.findByText(
107
- 'Are you in England, Enrique Chase? - Templates - GOV.UK'
108
- )
109
-
110
- expect($title).toBeInTheDocument()
111
-
112
- const $heading = container.getByRole('heading', {
113
- name: 'Are you in England, Enrique Chase?',
114
- level: 1
115
- })
116
-
117
- expect($heading).toBeInTheDocument()
118
- })
119
-
120
- test('POST /are-you-in-england with empty payload', async () => {
121
- const { response, container } = await renderResponse(server, {
122
- url: `${basePath}/are-you-in-england`,
123
- method: 'POST',
124
- headers,
125
- payload: { crumb: csrfToken }
126
- })
127
-
128
- expect(response.statusCode).toBe(StatusCodes.OK)
129
-
130
- const $errorSummary = container.getByRole('alert')
131
-
132
- const $heading = within($errorSummary).getByRole('heading', {
133
- name: 'There is a problem',
134
- level: 2
135
- })
136
-
137
- expect($heading).toBeInTheDocument()
138
-
139
- const $errorItems = within($errorSummary).getAllByRole('listitem')
140
- expect($errorItems[0]).toHaveTextContent(
141
- 'Select are you in England, Enrique Chase?'
142
- )
143
- })
144
-
145
- test('POST /are-you-in-england', async () => {
146
- const { response } = await renderResponse(server, {
147
- url: `${basePath}/are-you-in-england`,
148
- method: 'POST',
149
- headers,
150
- payload: { TKsWbP: 'true', crumb: csrfToken }
151
- })
152
-
153
- expect(response.statusCode).toBe(StatusCodes.SEE_OTHER)
154
- expect(response.headers.location).toBe(`${basePath}/what-is-your-business`)
155
- })
156
-
157
- test('GET /what-is-your-business', async () => {
158
- const { container, response } = await renderResponse(server, {
159
- url: `${basePath}/what-is-your-business`,
160
- headers
161
- })
162
-
163
- expect(response.statusCode).toBe(StatusCodes.OK)
164
-
165
- const $title = await container.findByText(
166
- 'What is your business, Enrique Chase? - Templates - GOV.UK'
167
- )
168
-
169
- expect($title).toBeInTheDocument()
170
-
171
- const $heading = container.getByRole('heading', {
172
- name: 'What is your business, Enrique Chase?',
173
- level: 1
174
- })
175
-
176
- expect($heading).toBeInTheDocument()
177
- })
178
-
179
- test('POST /what-is-your-business with empty payload', async () => {
180
- const { response, container } = await renderResponse(server, {
181
- url: `${basePath}/what-is-your-business`,
182
- method: 'POST',
183
- headers,
184
- payload: { crumb: csrfToken }
185
- })
186
-
187
- expect(response.statusCode).toBe(StatusCodes.OK)
188
-
189
- const $errorSummary = container.getByRole('alert')
190
-
191
- const $heading = within($errorSummary).getByRole('heading', {
192
- name: 'There is a problem',
193
- level: 2
194
- })
195
-
196
- expect($heading).toBeInTheDocument()
197
-
198
- const $errorItems = within($errorSummary).getAllByRole('listitem')
199
- expect($errorItems[0]).toHaveTextContent(
200
- 'Select what is your business, Enrique Chase?'
201
- )
202
- })
203
-
204
- test('POST /what-is-your-business', async () => {
205
- const { response } = await renderResponse(server, {
206
- url: `${basePath}/what-is-your-business`,
207
- method: 'POST',
208
- headers,
209
- payload: { sdFYHf: 'grower', crumb: csrfToken }
210
- })
211
-
212
- expect(response.statusCode).toBe(StatusCodes.SEE_OTHER)
213
- expect(response.headers.location).toBe(`${basePath}/information`)
214
- })
215
-
216
- test('GET /information', async () => {
217
- const { container, response } = await renderResponse(server, {
218
- url: `${basePath}/information`,
219
- headers
220
- })
221
-
222
- expect(response.statusCode).toBe(StatusCodes.OK)
223
-
224
- const $title = await container.findByText(
225
- 'Information: In England? true? - Templates - GOV.UK'
226
- )
227
-
228
- expect($title).toBeInTheDocument()
229
-
230
- const $heading = container.getByRole('heading', {
231
- name: 'Information: In England? true?',
232
- level: 1
233
- })
234
-
235
- expect($heading).toBeInTheDocument()
236
-
237
- const $output1 = container.getByTestId('output-1')
238
- expect($output1).toBeInTheDocument()
239
- expect($output1.textContent).toBe('Are you in England, Enrique Chase?')
240
-
241
- const $output2 = container.getByTestId('output-2')
242
- expect($output2).toBeInTheDocument()
243
- expect($output2.textContent).toBe(
244
- 'A grower or producer of agricultural or horticultural produce'
245
- )
246
-
247
- const $output3 = container.getByTestId('output-3')
248
- expect($output3).toBeInTheDocument()
249
- expect($output3.textContent).toBe('Yes')
250
-
251
- const $output4 = container.getByTestId('output-4')
252
- expect($output4).toBeInTheDocument()
253
- expect($output4.textContent).toBe('/templates/are-you-in-england')
254
- })
255
-
256
- test('POST /information', async () => {
257
- const { response } = await renderResponse(server, {
258
- url: `${basePath}/information`,
259
- method: 'POST',
260
- headers,
261
- payload: { crumb: csrfToken }
262
- })
263
-
264
- expect(response.statusCode).toBe(StatusCodes.SEE_OTHER)
265
- expect(response.headers.location).toBe(`${basePath}/summary`)
266
- })
267
-
268
- test('GET /summary', async () => {
269
- const { container, response } = await renderResponse(server, {
270
- url: `${basePath}/summary`,
271
- headers
272
- })
273
-
274
- expect(response.statusCode).toBe(StatusCodes.OK)
275
-
276
- const $titles = container.queryAllByRole('term')
277
- expect($titles).toHaveLength(3)
278
- expect($titles[0]).toHaveTextContent("What's your full name?")
279
- expect($titles[1]).toHaveTextContent('Are you in England, Enrique Chase?')
280
- expect($titles[2]).toHaveTextContent(
281
- 'What is your business, Enrique Chase?'
282
- )
283
- })
284
- })
285
-
286
- /**
287
- * @import { Server } from '@hapi/hapi'
288
- */
@@ -1,204 +0,0 @@
1
- import { join } from 'node:path'
2
-
3
- import { createServer } from '~/src/server/index.js'
4
- import { getFormMetadata } from '~/src/server/plugins/engine/services/formsService.js'
5
- import * as fixtures from '~/test/fixtures/index.js'
6
- import { renderResponse } from '~/test/helpers/component-helpers.js'
7
- import { getCookie, getCookieHeader } from '~/test/utils/get-cookie.js'
8
-
9
- const basePath = '/titles'
10
-
11
- jest.mock('~/src/server/plugins/engine/services/formsService.js')
12
-
13
- describe('Title and section title', () => {
14
- /** @type {Server} */
15
- let server
16
-
17
- /** @type {string} */
18
- let csrfToken
19
-
20
- /** @type {ReturnType<typeof getCookieHeader>} */
21
- let headers
22
-
23
- beforeAll(async () => {
24
- server = await createServer({
25
- formFileName: 'titles.json',
26
- formFilePath: join(import.meta.dirname, 'definitions'),
27
- enforceCsrf: true
28
- })
29
-
30
- await server.initialize()
31
-
32
- // Navigate to start
33
- const response = await server.inject({
34
- url: `${basePath}/start`,
35
- headers
36
- })
37
-
38
- // Extract the session cookie
39
- csrfToken = getCookie(response, 'crumb')
40
- headers = getCookieHeader(response, ['session', 'crumb'])
41
-
42
- // Submit answers for all pages
43
- for (const { path, payload } of [
44
- {
45
- path: '/applicant-one',
46
- payload: {
47
- crumb: csrfToken,
48
- firstName1: 'Firstname',
49
- middleName1: '',
50
- lastName1: 'Lastname'
51
- }
52
- },
53
- {
54
- path: '/applicant-one-address',
55
- payload: {
56
- crumb: csrfToken,
57
- address1__addressLine1: 'Richard Fairclough House',
58
- address1__addressLine2: 'Knutsford Road',
59
- address1__town: 'Warrington',
60
- address1__postcode: 'WA4 1HT'
61
- }
62
- },
63
- {
64
- path: '/applicant-two',
65
- payload: {
66
- crumb: csrfToken,
67
- firstName2: 'Firstname',
68
- middleName2: '',
69
- lastName2: 'Lastname'
70
- }
71
- },
72
- {
73
- path: '/applicant-two-address-optional',
74
- payload: {
75
- crumb: csrfToken,
76
- address2__addressLine1: '',
77
- address2__addressLine2: '',
78
- address2__town: '',
79
- address2__postcode: ''
80
- }
81
- }
82
- ]) {
83
- await server.inject({
84
- url: `${basePath}${path}`,
85
- method: 'POST',
86
- headers,
87
- payload
88
- })
89
- }
90
- })
91
-
92
- afterAll(async () => {
93
- await server.stop()
94
- })
95
-
96
- it('does not render the section title if it is the same as the title', async () => {
97
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
98
-
99
- const { container } = await renderResponse(server, {
100
- url: `${basePath}/applicant-one`
101
- })
102
-
103
- const $section = document.getElementById('section-title')
104
- const $heading = container.getByRole('heading', {
105
- name: 'Applicant 1',
106
- level: 1
107
- })
108
-
109
- expect($section).toBeNull()
110
- expect($heading).toBeInTheDocument()
111
- expect($heading).toHaveClass('govuk-heading-l')
112
- })
113
-
114
- it('render warning when notification email is not set', async () => {
115
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
116
-
117
- const { container } = await renderResponse(server, {
118
- url: `${basePath}/applicant-one`
119
- })
120
-
121
- const $warning = container.queryByRole('link', {
122
- name: 'enter the email address (opens in new tab)'
123
- })
124
-
125
- expect($warning).toBeInTheDocument()
126
- })
127
-
128
- it('does not render the warning when notification email is set', async () => {
129
- jest.mocked(getFormMetadata).mockResolvedValue({
130
- ...fixtures.form.metadata,
131
- notificationEmail: 'defra@gov.uk'
132
- })
133
-
134
- const { container } = await renderResponse(server, {
135
- url: `${basePath}/applicant-one`
136
- })
137
-
138
- const $warning = container.queryByRole('link', {
139
- name: 'enter the email address (opens in new tab)'
140
- })
141
-
142
- expect($warning).not.toBeInTheDocument()
143
- })
144
-
145
- it('does render the section title if it is not the same as the title', async () => {
146
- const { container } = await renderResponse(server, {
147
- url: `${basePath}/applicant-one-address`,
148
- headers
149
- })
150
-
151
- const $section = container.getByRole('heading', {
152
- name: 'Applicant 1',
153
- level: 2
154
- })
155
-
156
- const $heading = container.getByRole('heading', {
157
- name: 'Address',
158
- level: 1
159
- })
160
-
161
- expect($section).toBeInTheDocument()
162
- expect($section).toHaveAttribute('id', 'section-title')
163
-
164
- expect($heading).toBeInTheDocument()
165
- expect($heading).toHaveClass('govuk-fieldset__heading')
166
- })
167
-
168
- it('does not render the section title if hideTitle is set to true', async () => {
169
- const { container } = await renderResponse(server, {
170
- url: `${basePath}/applicant-two`,
171
- headers
172
- })
173
-
174
- const $section = document.getElementById('section-title')
175
- const $heading = container.getByRole('heading', {
176
- name: 'Applicant 2 details',
177
- level: 1
178
- })
179
-
180
- expect($section).toBeNull()
181
- expect($heading).toBeInTheDocument()
182
- expect($heading).toHaveClass('govuk-heading-l')
183
- })
184
-
185
- it('render title with optional when there is single component in page and is selected as optional', async () => {
186
- const { container } = await renderResponse(server, {
187
- url: `${basePath}/applicant-two-address-optional`,
188
- headers
189
- })
190
-
191
- const $heading = container.getByRole('heading', {
192
- name: 'Address (optional)',
193
- level: 1
194
- })
195
-
196
- expect($heading).toBeInTheDocument()
197
- expect($heading).toHaveClass('govuk-fieldset__heading')
198
- })
199
- })
200
-
201
- /**
202
- * @import { Server } from '@hapi/hapi'
203
- * @import { OutgoingHttpHeaders } from 'node:http'
204
- */
@@ -1,74 +0,0 @@
1
- import { within } from '@testing-library/dom'
2
-
3
- import { render } from '~/src/server/plugins/nunjucks/index.js'
4
-
5
- /**
6
- * Get component form data
7
- * @param {FormValue} [value]
8
- * @param {string} [name]
9
- * @returns {FormPayload}
10
- */
11
- export function getFormData(value, name = 'myComponent') {
12
- return typeof value !== 'undefined' ? { [name]: value } : {}
13
- }
14
-
15
- /**
16
- * Get component session state
17
- * @param {FormValue | null} [value]
18
- * @param {string} [name]
19
- * @returns {FormState}
20
- */
21
- export function getFormState(value, name = 'myComponent') {
22
- return { [name]: value ?? null }
23
- }
24
-
25
- /**
26
- * Render Nunjucks macro into DOM
27
- * @param {Parameters<typeof render.macro>} args
28
- */
29
- export function renderMacro(...args) {
30
- return renderDOM(render.macro(...args))
31
- }
32
-
33
- /**
34
- * Render Nunjucks view into DOM
35
- * @param {Parameters<typeof render.view>} args
36
- */
37
- export function renderView(...args) {
38
- return renderDOM(render.view(...args))
39
- }
40
-
41
- /**
42
- * Render HTTP response
43
- * @param {Server} server
44
- * @param {ServerInjectOptions} options
45
- */
46
- export async function renderResponse(server, options) {
47
- const response = /** @type {ServerInjectResponse<string>} */ (
48
- await server.inject(options)
49
- )
50
-
51
- const result = renderDOM(response.result)
52
- return { ...result, response }
53
- }
54
-
55
- /**
56
- * Render DOM
57
- * @param {string} [html]
58
- */
59
- export function renderDOM(html = '') {
60
- const { window } = globalThis.$jsdom
61
-
62
- // Update the document body
63
- window.document.body.innerHTML = html
64
-
65
- const document = window.document
66
- const container = within(document.body)
67
-
68
- return { container, document }
69
- }
70
-
71
- /**
72
- * @import { Server, ServerInjectOptions, ServerInjectResponse } from '@hapi/hapi'
73
- * @import { FormPayload, FormState, FormValue } from '~/src/server/plugins/engine/types.js'
74
- */
@@ -1,42 +0,0 @@
1
- import { parse } from 'cookie'
2
-
3
- /**
4
- * @param {ServerInjectResponse<string | object>} response
5
- * @param {string} name
6
- */
7
- export function getCookie(response, name) {
8
- const headers = [response.headers['set-cookie']].flat()
9
- const header = headers.find((header) => header?.includes(`${name}=`)) ?? ''
10
-
11
- const value = parse(header, {
12
- decode: (str) => str // we only need the raw value to pass along to the next request
13
- })[name]
14
-
15
- if (!value) {
16
- throw new Error(`Cookie ${name} not found`)
17
- }
18
-
19
- return value
20
- }
21
-
22
- /**
23
- * @param {ServerInjectResponse<string | object>} response
24
- * @param {string | string[]} names
25
- * @returns {Pick<OutgoingHttpHeaders, 'cookie'>}
26
- */
27
- export function getCookieHeader(response, names) {
28
- const cookies = /** @satisfies {string[]} */ ([])
29
-
30
- for (const name of [names].flat()) {
31
- cookies.push([name, getCookie(response, name)].join('='))
32
- }
33
-
34
- return {
35
- cookie: cookies.join('; ')
36
- }
37
- }
38
-
39
- /**
40
- * @import { ServerInjectResponse } from '@hapi/hapi'
41
- * @import { OutgoingHttpHeaders } from 'node:http'
42
- */