@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,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
- */