@defra/forms-engine-plugin 4.7.2 → 4.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. package/.public/javascripts/shared.min.js +1 -1
  2. package/.public/javascripts/shared.min.js.map +1 -1
  3. package/.server/client/javascripts/geospatial-map.d.ts +6 -6
  4. package/.server/client/javascripts/geospatial-map.js +3 -3
  5. package/.server/client/javascripts/location-map.d.ts +1 -1
  6. package/.server/client/javascripts/location-map.js +1 -1
  7. package/.server/client/javascripts/map.d.ts +5 -1
  8. package/.server/client/javascripts/map.js +10 -2
  9. package/.server/client/javascripts/map.js.map +1 -1
  10. package/.server/client/javascripts/shared.d.ts +7 -7
  11. package/.server/server/index.d.ts +1 -1
  12. package/.server/server/plugins/crumb.d.ts +1 -1
  13. package/.server/server/plugins/engine/beta/form-context.d.ts +6 -6
  14. package/.server/server/plugins/engine/components/AutocompleteField.d.ts +4 -4
  15. package/.server/server/plugins/engine/components/CheckboxesField.d.ts +2 -2
  16. package/.server/server/plugins/engine/components/CheckboxesField.js +2 -2
  17. package/.server/server/plugins/engine/components/CheckboxesField.js.map +1 -1
  18. package/.server/server/plugins/engine/components/ComponentBase.d.ts +5 -5
  19. package/.server/server/plugins/engine/components/ComponentCollection.d.ts +8 -8
  20. package/.server/server/plugins/engine/components/DatePartsField.d.ts +11 -11
  21. package/.server/server/plugins/engine/components/DeclarationField.d.ts +3 -3
  22. package/.server/server/plugins/engine/components/Details.d.ts +1 -1
  23. package/.server/server/plugins/engine/components/EastingNorthingField.d.ts +22 -22
  24. package/.server/server/plugins/engine/components/EmailAddressField.d.ts +4 -4
  25. package/.server/server/plugins/engine/components/FileUploadField.d.ts +3 -3
  26. package/.server/server/plugins/engine/components/FormComponent.d.ts +10 -10
  27. package/.server/server/plugins/engine/components/GeospatialField.d.ts +6 -6
  28. package/.server/server/plugins/engine/components/HiddenField.d.ts +2 -2
  29. package/.server/server/plugins/engine/components/Html.d.ts +1 -1
  30. package/.server/server/plugins/engine/components/InsetText.d.ts +1 -1
  31. package/.server/server/plugins/engine/components/LatLongField.d.ts +22 -22
  32. package/.server/server/plugins/engine/components/List.d.ts +8 -8
  33. package/.server/server/plugins/engine/components/ListFormComponent.d.ts +10 -10
  34. package/.server/server/plugins/engine/components/LocationFieldBase.d.ts +6 -6
  35. package/.server/server/plugins/engine/components/LocationFieldHelpers.d.ts +14 -14
  36. package/.server/server/plugins/engine/components/Markdown.d.ts +1 -1
  37. package/.server/server/plugins/engine/components/MonthYearField.d.ts +11 -11
  38. package/.server/server/plugins/engine/components/MultilineTextField.d.ts +5 -5
  39. package/.server/server/plugins/engine/components/NationalGridFieldNumberField.d.ts +1 -1
  40. package/.server/server/plugins/engine/components/NumberField.d.ts +3 -3
  41. package/.server/server/plugins/engine/components/OsGridRefField.d.ts +1 -1
  42. package/.server/server/plugins/engine/components/PaymentField.d.ts +12 -12
  43. package/.server/server/plugins/engine/components/RadiosField.d.ts +1 -1
  44. package/.server/server/plugins/engine/components/SelectField.d.ts +4 -4
  45. package/.server/server/plugins/engine/components/SelectionControlField.d.ts +10 -10
  46. package/.server/server/plugins/engine/components/TelephoneNumberField.d.ts +4 -4
  47. package/.server/server/plugins/engine/components/TextField.d.ts +2 -2
  48. package/.server/server/plugins/engine/components/UkAddressField.d.ts +11 -11
  49. package/.server/server/plugins/engine/components/YesNoField.d.ts +2 -2
  50. package/.server/server/plugins/engine/components/helpers/__stubs__/geospatial.d.ts +1 -1
  51. package/.server/server/plugins/engine/components/helpers/components.d.ts +5 -5
  52. package/.server/server/plugins/engine/components/helpers/geospatial.d.ts +1 -1
  53. package/.server/server/plugins/engine/components/index.d.ts +27 -27
  54. package/.server/server/plugins/engine/components/types.d.ts +1 -1
  55. package/.server/server/plugins/engine/configureEnginePlugin.d.ts +4 -4
  56. package/.server/server/plugins/engine/date-helper.d.ts +1 -1
  57. package/.server/server/plugins/engine/helpers.d.ts +8 -8
  58. package/.server/server/plugins/engine/index.d.ts +5 -5
  59. package/.server/server/plugins/engine/models/FormModel.d.ts +6 -6
  60. package/.server/server/plugins/engine/models/SummaryViewModel.d.ts +6 -6
  61. package/.server/server/plugins/engine/models/index.d.ts +2 -2
  62. package/.server/server/plugins/engine/models/types.d.ts +4 -4
  63. package/.server/server/plugins/engine/options.d.ts +1 -1
  64. package/.server/server/plugins/engine/options.js +1 -1
  65. package/.server/server/plugins/engine/options.test.js +1 -1
  66. package/.server/server/plugins/engine/outputFormatters/adapter/v1.d.ts +4 -4
  67. package/.server/server/plugins/engine/outputFormatters/human/v1.d.ts +4 -4
  68. package/.server/server/plugins/engine/outputFormatters/index.d.ts +5 -5
  69. package/.server/server/plugins/engine/outputFormatters/machine/v1.d.ts +4 -4
  70. package/.server/server/plugins/engine/outputFormatters/machine/v2.d.ts +4 -4
  71. package/.server/server/plugins/engine/pageControllers/FileUploadPageController.d.ts +8 -8
  72. package/.server/server/plugins/engine/pageControllers/PageController.d.ts +6 -6
  73. package/.server/server/plugins/engine/pageControllers/QuestionPageController.d.ts +8 -8
  74. package/.server/server/plugins/engine/pageControllers/RepeatPageController.d.ts +5 -5
  75. package/.server/server/plugins/engine/pageControllers/StartPageController.d.ts +4 -4
  76. package/.server/server/plugins/engine/pageControllers/StatusPageController.d.ts +4 -4
  77. package/.server/server/plugins/engine/pageControllers/SummaryPageController.d.ts +5 -5
  78. package/.server/server/plugins/engine/pageControllers/TerminalPageController.d.ts +3 -3
  79. package/.server/server/plugins/engine/pageControllers/__stubs__/request.d.ts +2 -2
  80. package/.server/server/plugins/engine/pageControllers/errors.d.ts +1 -1
  81. package/.server/server/plugins/engine/pageControllers/helpers/pages.d.ts +2 -2
  82. package/.server/server/plugins/engine/pageControllers/helpers/state.d.ts +5 -5
  83. package/.server/server/plugins/engine/pageControllers/helpers/state.js +1 -1
  84. package/.server/server/plugins/engine/pageControllers/helpers/state.js.map +1 -1
  85. package/.server/server/plugins/engine/pageControllers/helpers/submission.d.ts +1 -1
  86. package/.server/server/plugins/engine/pageControllers/index.d.ts +7 -7
  87. package/.server/server/plugins/engine/plugin.d.ts +1 -1
  88. package/.server/server/plugins/engine/routes/file-upload.d.ts +1 -1
  89. package/.server/server/plugins/engine/routes/index.d.ts +3 -3
  90. package/.server/server/plugins/engine/routes/payment-helper.d.ts +3 -3
  91. package/.server/server/plugins/engine/routes/payment-helper.js +2 -2
  92. package/.server/server/plugins/engine/routes/payment.js +5 -5
  93. package/.server/server/plugins/engine/routes/payment.test.js +1 -1
  94. package/.server/server/plugins/engine/routes/questions.d.ts +2 -2
  95. package/.server/server/plugins/engine/routes/repeaters/item-delete.d.ts +2 -2
  96. package/.server/server/plugins/engine/routes/repeaters/summary.d.ts +2 -2
  97. package/.server/server/plugins/engine/services/index.d.ts +3 -3
  98. package/.server/server/plugins/engine/services/notifyService.d.ts +4 -4
  99. package/.server/server/plugins/engine/services/uploadService.d.ts +2 -2
  100. package/.server/server/plugins/engine/services/uploadService.js +1 -1
  101. package/.server/server/plugins/engine/types/index.d.ts +10 -10
  102. package/.server/server/plugins/engine/types/schema.d.ts +1 -1
  103. package/.server/server/plugins/engine/types.d.ts +25 -16
  104. package/.server/server/plugins/engine/types.js.map +1 -1
  105. package/.server/server/plugins/engine/validationHelpers.d.ts +2 -2
  106. package/.server/server/plugins/engine/vision.d.ts +1 -1
  107. package/.server/server/plugins/map/index.d.ts +1 -1
  108. package/.server/server/plugins/map/index.js +1 -1
  109. package/.server/server/plugins/map/routes/get-os-token.d.ts +11 -1
  110. package/.server/server/plugins/map/routes/get-os-token.js +12 -2
  111. package/.server/server/plugins/map/routes/get-os-token.js.map +1 -1
  112. package/.server/server/plugins/map/routes/index.d.ts +4 -4
  113. package/.server/server/plugins/map/routes/index.js +3 -2
  114. package/.server/server/plugins/map/routes/index.js.map +1 -1
  115. package/.server/server/plugins/map/routes/vts/esri-aerial.json +23 -0
  116. package/.server/server/plugins/map/service.d.ts +1 -1
  117. package/.server/server/plugins/map/service.js +5 -2
  118. package/.server/server/plugins/map/service.js.map +1 -1
  119. package/.server/server/plugins/map/test/__stubs__/find.d.ts +1 -1
  120. package/.server/server/plugins/map/test/__stubs__/find.js +1 -1
  121. package/.server/server/plugins/nunjucks/context.d.ts +2 -2
  122. package/.server/server/plugins/nunjucks/context.js +2 -2
  123. package/.server/server/plugins/nunjucks/context.test.js +1 -1
  124. package/.server/server/plugins/nunjucks/enviroment.test.js +1 -1
  125. package/.server/server/plugins/nunjucks/environment.d.ts +3 -3
  126. package/.server/server/plugins/nunjucks/environment.js +3 -3
  127. package/.server/server/plugins/nunjucks/filters/answer.d.ts +1 -1
  128. package/.server/server/plugins/nunjucks/filters/answer.js +2 -2
  129. package/.server/server/plugins/nunjucks/filters/answer.test.js +1 -1
  130. package/.server/server/plugins/nunjucks/filters/evaluate.d.ts +1 -1
  131. package/.server/server/plugins/nunjucks/filters/evaluate.js +1 -1
  132. package/.server/server/plugins/nunjucks/filters/field.d.ts +1 -1
  133. package/.server/server/plugins/nunjucks/filters/field.js +1 -1
  134. package/.server/server/plugins/nunjucks/filters/field.test.js +1 -1
  135. package/.server/server/plugins/nunjucks/filters/href.d.ts +1 -1
  136. package/.server/server/plugins/nunjucks/filters/href.js +1 -1
  137. package/.server/server/plugins/nunjucks/filters/href.test.js +1 -1
  138. package/.server/server/plugins/nunjucks/filters/index.d.ts +8 -8
  139. package/.server/server/plugins/nunjucks/filters/page.d.ts +1 -1
  140. package/.server/server/plugins/nunjucks/filters/page.js +1 -1
  141. package/.server/server/plugins/nunjucks/filters/page.test.js +1 -1
  142. package/.server/server/plugins/nunjucks/index.d.ts +3 -3
  143. package/.server/server/plugins/nunjucks/render.d.ts +2 -2
  144. package/.server/server/plugins/nunjucks/render.js +1 -1
  145. package/.server/server/plugins/nunjucks/types.d.ts +1 -1
  146. package/.server/server/plugins/nunjucks/types.js +1 -1
  147. package/.server/server/plugins/payment/helper.d.ts +2 -2
  148. package/.server/server/plugins/payment/helper.js +1 -1
  149. package/.server/server/plugins/payment/service.d.ts +3 -3
  150. package/.server/server/plugins/payment/service.js +1 -1
  151. package/.server/server/plugins/postcode-lookup/index.d.ts +1 -1
  152. package/.server/server/plugins/postcode-lookup/index.js +1 -1
  153. package/.server/server/plugins/postcode-lookup/models/index.d.ts +6 -6
  154. package/.server/server/plugins/postcode-lookup/models/index.js +1 -1
  155. package/.server/server/plugins/postcode-lookup/routes/index.d.ts +6 -6
  156. package/.server/server/plugins/postcode-lookup/routes/index.js +15 -15
  157. package/.server/server/plugins/postcode-lookup/routes/index.js.map +1 -1
  158. package/.server/server/plugins/postcode-lookup/service.d.ts +1 -1
  159. package/.server/server/plugins/postcode-lookup/service.js +5 -2
  160. package/.server/server/plugins/postcode-lookup/service.js.map +1 -1
  161. package/.server/server/plugins/postcode-lookup/types.js +1 -1
  162. package/.server/server/routes/index.d.ts +2 -2
  163. package/.server/server/routes/types.d.ts +1 -1
  164. package/.server/server/schemas/index.d.ts +2 -2
  165. package/.server/server/services/cacheService.d.ts +8 -8
  166. package/.server/server/services/cacheService.js +2 -5
  167. package/.server/server/services/cacheService.js.map +1 -1
  168. package/.server/server/services/httpService.test.js +1 -1
  169. package/.server/server/services/index.d.ts +1 -1
  170. package/.server/server/types.d.ts +7 -7
  171. package/.server/server/utils/file-form-service.d.ts +2 -2
  172. package/.server/server/utils/file-form-service.js +1 -1
  173. package/package.json +8 -4
  174. package/src/client/javascripts/application.js +1 -1
  175. package/src/client/javascripts/geospatial-map.js +4 -4
  176. package/src/client/javascripts/location-map.js +2 -2
  177. package/src/client/javascripts/map.js +13 -4
  178. package/src/client/javascripts/shared.js +7 -7
  179. package/src/index.ts +3 -3
  180. package/src/server/common/helpers/logging/logger-options.ts +1 -1
  181. package/src/server/common/helpers/logging/logger.ts +1 -1
  182. package/src/server/common/helpers/logging/request-logger.ts +1 -1
  183. package/src/server/common/helpers/logging/request-tracing.js +1 -1
  184. package/src/server/common/helpers/redis-client.js +2 -2
  185. package/src/server/index.ts +13 -13
  186. package/src/server/plugins/crumb.ts +2 -2
  187. package/src/server/plugins/engine/beta/form-context.ts +9 -9
  188. package/src/server/plugins/engine/components/AutocompleteField.ts +3 -3
  189. package/src/server/plugins/engine/components/CheckboxesField.ts +7 -8
  190. package/src/server/plugins/engine/components/ComponentBase.ts +5 -5
  191. package/src/server/plugins/engine/components/ComponentCollection.ts +9 -9
  192. package/src/server/plugins/engine/components/DatePartsField.ts +8 -8
  193. package/src/server/plugins/engine/components/DeclarationField.ts +3 -3
  194. package/src/server/plugins/engine/components/Details.ts +1 -1
  195. package/src/server/plugins/engine/components/EastingNorthingField.ts +9 -9
  196. package/src/server/plugins/engine/components/EmailAddressField.ts +3 -3
  197. package/src/server/plugins/engine/components/FileUploadField.ts +6 -6
  198. package/src/server/plugins/engine/components/FormComponent.ts +4 -4
  199. package/src/server/plugins/engine/components/GeospatialField.ts +5 -5
  200. package/src/server/plugins/engine/components/HiddenField.ts +4 -4
  201. package/src/server/plugins/engine/components/Html.ts +1 -1
  202. package/src/server/plugins/engine/components/InsetText.ts +1 -1
  203. package/src/server/plugins/engine/components/LatLongField.ts +9 -9
  204. package/src/server/plugins/engine/components/List.ts +2 -2
  205. package/src/server/plugins/engine/components/ListFormComponent.ts +4 -4
  206. package/src/server/plugins/engine/components/LocationFieldBase.ts +5 -5
  207. package/src/server/plugins/engine/components/LocationFieldHelpers.ts +5 -5
  208. package/src/server/plugins/engine/components/Markdown.ts +1 -1
  209. package/src/server/plugins/engine/components/MonthYearField.ts +8 -8
  210. package/src/server/plugins/engine/components/MultilineTextField.ts +4 -4
  211. package/src/server/plugins/engine/components/NationalGridFieldNumberField.ts +2 -2
  212. package/src/server/plugins/engine/components/NumberField.ts +3 -3
  213. package/src/server/plugins/engine/components/OsGridRefField.ts +2 -2
  214. package/src/server/plugins/engine/components/PaymentField.ts +8 -8
  215. package/src/server/plugins/engine/components/RadiosField.ts +1 -1
  216. package/src/server/plugins/engine/components/SelectField.ts +2 -2
  217. package/src/server/plugins/engine/components/SelectionControlField.ts +4 -4
  218. package/src/server/plugins/engine/components/TelephoneNumberField.ts +4 -4
  219. package/src/server/plugins/engine/components/TextField.ts +3 -3
  220. package/src/server/plugins/engine/components/UkAddressField.ts +7 -7
  221. package/src/server/plugins/engine/components/YesNoField.ts +5 -5
  222. package/src/server/plugins/engine/components/helpers/__stubs__/geospatial.ts +1 -1
  223. package/src/server/plugins/engine/components/helpers/components.ts +8 -8
  224. package/src/server/plugins/engine/components/helpers/geospatial.ts +1 -1
  225. package/src/server/plugins/engine/components/index.ts +27 -27
  226. package/src/server/plugins/engine/components/types.ts +1 -1
  227. package/src/server/plugins/engine/configureEnginePlugin.ts +10 -10
  228. package/src/server/plugins/engine/date-helper.ts +1 -1
  229. package/src/server/plugins/engine/helpers.ts +8 -8
  230. package/src/server/plugins/engine/index.ts +8 -8
  231. package/src/server/plugins/engine/models/FormModel.ts +15 -15
  232. package/src/server/plugins/engine/models/SummaryViewModel.ts +10 -10
  233. package/src/server/plugins/engine/models/index.ts +2 -2
  234. package/src/server/plugins/engine/models/types.ts +4 -4
  235. package/src/server/plugins/engine/options.js +3 -3
  236. package/src/server/plugins/engine/outputFormatters/adapter/v1.ts +6 -6
  237. package/src/server/plugins/engine/outputFormatters/human/v1.ts +9 -9
  238. package/src/server/plugins/engine/outputFormatters/index.ts +8 -8
  239. package/src/server/plugins/engine/outputFormatters/machine/v1.ts +7 -7
  240. package/src/server/plugins/engine/outputFormatters/machine/v2.ts +6 -6
  241. package/src/server/plugins/engine/pageControllers/FileUploadPageController.ts +9 -9
  242. package/src/server/plugins/engine/pageControllers/PageController.ts +7 -7
  243. package/src/server/plugins/engine/pageControllers/QuestionPageController.ts +13 -13
  244. package/src/server/plugins/engine/pageControllers/RepeatPageController.ts +6 -6
  245. package/src/server/plugins/engine/pageControllers/StartPageController.ts +3 -3
  246. package/src/server/plugins/engine/pageControllers/StatusPageController.ts +5 -5
  247. package/src/server/plugins/engine/pageControllers/SummaryPageController.ts +12 -12
  248. package/src/server/plugins/engine/pageControllers/TerminalPageController.ts +3 -3
  249. package/src/server/plugins/engine/pageControllers/__stubs__/request.ts +3 -3
  250. package/src/server/plugins/engine/pageControllers/__stubs__/server.ts +2 -2
  251. package/src/server/plugins/engine/pageControllers/errors.ts +1 -1
  252. package/src/server/plugins/engine/pageControllers/helpers/pages.ts +2 -2
  253. package/src/server/plugins/engine/pageControllers/helpers/state.ts +9 -9
  254. package/src/server/plugins/engine/pageControllers/helpers/submission.ts +5 -5
  255. package/src/server/plugins/engine/pageControllers/index.ts +7 -7
  256. package/src/server/plugins/engine/pageControllers/validationOptions.ts +1 -1
  257. package/src/server/plugins/engine/plugin.ts +14 -14
  258. package/src/server/plugins/engine/routes/file-upload.ts +2 -2
  259. package/src/server/plugins/engine/routes/index.ts +10 -10
  260. package/src/server/plugins/engine/routes/payment-helper.js +4 -4
  261. package/src/server/plugins/engine/routes/payment.js +9 -9
  262. package/src/server/plugins/engine/routes/questions.ts +10 -10
  263. package/src/server/plugins/engine/routes/repeaters/item-delete.ts +6 -6
  264. package/src/server/plugins/engine/routes/repeaters/summary.ts +5 -5
  265. package/src/server/plugins/engine/services/formSubmissionService.js +2 -2
  266. package/src/server/plugins/engine/services/index.js +3 -3
  267. package/src/server/plugins/engine/services/localFormsService.js +2 -2
  268. package/src/server/plugins/engine/services/notifyService.ts +9 -9
  269. package/src/server/plugins/engine/services/uploadService.js +3 -3
  270. package/src/server/plugins/engine/types/index.ts +10 -10
  271. package/src/server/plugins/engine/types/schema.ts +2 -2
  272. package/src/server/plugins/engine/types.ts +22 -17
  273. package/src/server/plugins/engine/validationHelpers.ts +3 -3
  274. package/src/server/plugins/engine/vision.ts +3 -3
  275. package/src/server/plugins/map/index.js +2 -2
  276. package/src/server/plugins/map/routes/get-os-token.js +15 -3
  277. package/src/server/plugins/map/routes/index.js +7 -5
  278. package/src/server/plugins/map/routes/vts/esri-aerial.json +23 -0
  279. package/src/server/plugins/map/service.js +7 -4
  280. package/src/server/plugins/map/test/__stubs__/find.js +1 -1
  281. package/src/server/plugins/nunjucks/context.js +5 -5
  282. package/src/server/plugins/nunjucks/environment.js +6 -6
  283. package/src/server/plugins/nunjucks/filters/answer.js +3 -3
  284. package/src/server/plugins/nunjucks/filters/evaluate.js +2 -2
  285. package/src/server/plugins/nunjucks/filters/field.js +1 -1
  286. package/src/server/plugins/nunjucks/filters/href.js +2 -2
  287. package/src/server/plugins/nunjucks/filters/index.js +8 -8
  288. package/src/server/plugins/nunjucks/filters/page.js +1 -1
  289. package/src/server/plugins/nunjucks/index.js +3 -3
  290. package/src/server/plugins/nunjucks/plugin.js +3 -3
  291. package/src/server/plugins/nunjucks/render.js +2 -2
  292. package/src/server/plugins/nunjucks/types.js +1 -1
  293. package/src/server/plugins/payment/helper.js +2 -2
  294. package/src/server/plugins/payment/service.js +4 -4
  295. package/src/server/plugins/postcode-lookup/index.js +2 -2
  296. package/src/server/plugins/postcode-lookup/models/index.js +3 -3
  297. package/src/server/plugins/postcode-lookup/routes/index.js +24 -14
  298. package/src/server/plugins/postcode-lookup/service.js +7 -4
  299. package/src/server/plugins/postcode-lookup/types.js +1 -1
  300. package/src/server/plugins/session.ts +1 -1
  301. package/src/server/routes/index.ts +2 -2
  302. package/src/server/routes/public.ts +1 -1
  303. package/src/server/routes/types.ts +1 -1
  304. package/src/server/schemas/index.ts +2 -2
  305. package/src/server/secure-context.js +1 -1
  306. package/src/server/services/cacheService.ts +13 -18
  307. package/src/server/services/httpService.ts +1 -1
  308. package/src/server/services/index.ts +1 -1
  309. package/src/server/types.ts +7 -7
  310. package/src/server/utils/notify.ts +2 -2
  311. package/src/server/utils/utils.js +1 -1
  312. package/src/typings/hapi/index.d.ts +4 -4
  313. package/src/typings/joi/index.d.ts +1 -1
  314. package/src/server/common/helpers/logging/logger-options.test.ts +0 -50
  315. package/src/server/index.test.ts +0 -644
  316. package/src/server/plugins/engine/beta/form-context.test.ts +0 -373
  317. package/src/server/plugins/engine/components/AutocompleteField.test.ts +0 -362
  318. package/src/server/plugins/engine/components/CheckboxesField.test.ts +0 -486
  319. package/src/server/plugins/engine/components/DatePartsField.test.ts +0 -927
  320. package/src/server/plugins/engine/components/DeclarationField.test.ts +0 -560
  321. package/src/server/plugins/engine/components/Details.test.ts +0 -49
  322. package/src/server/plugins/engine/components/EastingNorthingField.test.ts +0 -727
  323. package/src/server/plugins/engine/components/EmailAddressField.test.ts +0 -445
  324. package/src/server/plugins/engine/components/FileUploadField.test.ts +0 -1079
  325. package/src/server/plugins/engine/components/GeospatialField.test.ts +0 -380
  326. package/src/server/plugins/engine/components/HiddenField.test.ts +0 -188
  327. package/src/server/plugins/engine/components/Html.test.ts +0 -48
  328. package/src/server/plugins/engine/components/InsetText.test.ts +0 -48
  329. package/src/server/plugins/engine/components/LatLongField.test.ts +0 -898
  330. package/src/server/plugins/engine/components/List.test.ts +0 -79
  331. package/src/server/plugins/engine/components/LocationFieldBase.test.ts +0 -253
  332. package/src/server/plugins/engine/components/LocationFieldHelpers.test.ts +0 -743
  333. package/src/server/plugins/engine/components/Markdown.test.ts +0 -48
  334. package/src/server/plugins/engine/components/MonthYearField.test.ts +0 -617
  335. package/src/server/plugins/engine/components/MultilineTextField.test.ts +0 -647
  336. package/src/server/plugins/engine/components/NationalGridFieldNumberField.test.ts +0 -449
  337. package/src/server/plugins/engine/components/NumberField.test.ts +0 -723
  338. package/src/server/plugins/engine/components/OsGridRefField.test.ts +0 -460
  339. package/src/server/plugins/engine/components/PaymentField.test.ts +0 -745
  340. package/src/server/plugins/engine/components/RadiosField.test.ts +0 -297
  341. package/src/server/plugins/engine/components/SelectField.test.ts +0 -289
  342. package/src/server/plugins/engine/components/TelephoneNumberField.test.ts +0 -384
  343. package/src/server/plugins/engine/components/TextField.test.ts +0 -521
  344. package/src/server/plugins/engine/components/UkAddressField.test.ts +0 -806
  345. package/src/server/plugins/engine/components/YesNoField.test.ts +0 -256
  346. package/src/server/plugins/engine/components/helpers/components.test.ts +0 -399
  347. package/src/server/plugins/engine/components/helpers/geospatial.test.js +0 -55
  348. package/src/server/plugins/engine/components/helpers/helpers.test.ts +0 -219
  349. package/src/server/plugins/engine/date-helper.test.ts +0 -47
  350. package/src/server/plugins/engine/helpers.test.ts +0 -868
  351. package/src/server/plugins/engine/models/FormModel.test.ts +0 -725
  352. package/src/server/plugins/engine/models/SummaryViewModel.test.ts +0 -472
  353. package/src/server/plugins/engine/options.test.js +0 -63
  354. package/src/server/plugins/engine/outputFormatters/adapter/v1.location.test.ts +0 -356
  355. package/src/server/plugins/engine/outputFormatters/adapter/v1.test.ts +0 -871
  356. package/src/server/plugins/engine/outputFormatters/human/v1.payment.test.ts +0 -147
  357. package/src/server/plugins/engine/outputFormatters/human/v1.test.ts +0 -145
  358. package/src/server/plugins/engine/outputFormatters/index.test.ts +0 -17
  359. package/src/server/plugins/engine/outputFormatters/machine/v1.test.ts +0 -268
  360. package/src/server/plugins/engine/outputFormatters/machine/v2.location.test.ts +0 -341
  361. package/src/server/plugins/engine/outputFormatters/machine/v2.payment.test.ts +0 -115
  362. package/src/server/plugins/engine/outputFormatters/machine/v2.test.ts +0 -311
  363. package/src/server/plugins/engine/pageControllers/FileUploadPageController.test.ts +0 -1372
  364. package/src/server/plugins/engine/pageControllers/PageController.test.ts +0 -246
  365. package/src/server/plugins/engine/pageControllers/QuestionPageController.test.ts +0 -1686
  366. package/src/server/plugins/engine/pageControllers/RepeatPageController.test.ts +0 -279
  367. package/src/server/plugins/engine/pageControllers/StartPageController.test.ts +0 -32
  368. package/src/server/plugins/engine/pageControllers/StatusPageController.test.ts +0 -32
  369. package/src/server/plugins/engine/pageControllers/SummaryPageController.test.ts +0 -89
  370. package/src/server/plugins/engine/pageControllers/TerminalController.test.ts +0 -37
  371. package/src/server/plugins/engine/pageControllers/errors.test.ts +0 -78
  372. package/src/server/plugins/engine/pageControllers/helpers/helpers.test.ts +0 -182
  373. package/src/server/plugins/engine/pageControllers/helpers/state.test.ts +0 -359
  374. package/src/server/plugins/engine/pageControllers/helpers/submission.test.ts +0 -373
  375. package/src/server/plugins/engine/referenceNumbers.test.ts +0 -74
  376. package/src/server/plugins/engine/routes/index.test.ts +0 -332
  377. package/src/server/plugins/engine/routes/payment-helper.test.js +0 -136
  378. package/src/server/plugins/engine/routes/payment.test.js +0 -180
  379. package/src/server/plugins/engine/routes/questions.test.ts +0 -502
  380. package/src/server/plugins/engine/routes/repeaters/item-delete.test.ts +0 -83
  381. package/src/server/plugins/engine/routes/repeaters/summary.test.ts +0 -75
  382. package/src/server/plugins/engine/services/formsService.test.js +0 -26
  383. package/src/server/plugins/engine/services/notifyService.test.ts +0 -310
  384. package/src/server/plugins/engine/types/schema.test.ts +0 -234
  385. package/src/server/plugins/engine/views/components/service-banner/template.test.js +0 -43
  386. package/src/server/plugins/engine/views/components/tag-env/template.test.js +0 -28
  387. package/src/server/plugins/engine/views/partials/preview-banner.test.js +0 -122
  388. package/src/server/plugins/map/routes/get-os-token.test.js +0 -55
  389. package/src/server/plugins/map/service.test.js +0 -144
  390. package/src/server/plugins/nunjucks/context.test.js +0 -109
  391. package/src/server/plugins/nunjucks/enviroment.test.js +0 -207
  392. package/src/server/plugins/nunjucks/filters/answer.test.js +0 -92
  393. package/src/server/plugins/nunjucks/filters/field.test.js +0 -75
  394. package/src/server/plugins/nunjucks/filters/href.test.js +0 -80
  395. package/src/server/plugins/nunjucks/filters/merge.test.js +0 -15
  396. package/src/server/plugins/nunjucks/filters/page.test.js +0 -65
  397. package/src/server/plugins/payment/helper.test.js +0 -29
  398. package/src/server/plugins/payment/service.test.js +0 -218
  399. package/src/server/plugins/postcode-lookup/service.test.js +0 -177
  400. package/src/server/postcode-lookup.test.ts +0 -64
  401. package/src/server/routes/dummy-api.test.ts +0 -97
  402. package/src/server/services/cacheService.test.ts +0 -308
  403. package/src/server/services/httpService.test.js +0 -491
  404. package/src/server/utils/file-form-service.test.js +0 -127
  405. package/src/server/utils/notify.test.ts +0 -37
  406. package/src/server/utils/secure-context/get-trust-store-certs.test.js +0 -19
  407. package/src/server/utils/utils.test.js +0 -69
@@ -1,644 +0,0 @@
1
- import { type Server } from '@hapi/hapi'
2
- import { StatusCodes } from 'http-status-codes'
3
- import { type Environment } from 'nunjucks'
4
-
5
- import { FORM_PREFIX } from '~/src/server/constants.js'
6
- import { createServer } from '~/src/server/index.js'
7
- import { prepareNunjucksEnvironment } from '~/src/server/plugins/engine/index.js'
8
- import {
9
- getFormDefinition,
10
- getFormMetadata
11
- } from '~/src/server/plugins/engine/services/formsService.js'
12
- import * as defaultServices from '~/src/server/plugins/engine/services/index.js'
13
- import { getUploadStatus } from '~/src/server/plugins/engine/services/uploadService.js'
14
- import {
15
- FileStatus,
16
- UploadStatus,
17
- type PluginOptions,
18
- type UploadStatusResponse
19
- } from '~/src/server/plugins/engine/types.js'
20
- import { FormStatus } from '~/src/server/routes/types.js'
21
- import * as fixtures from '~/test/fixtures/index.js'
22
-
23
- jest.mock('~/src/server/plugins/engine/services/formsService.js')
24
- jest.mock('~/src/server/plugins/engine/services/uploadService.js')
25
-
26
- describe('Model cache', () => {
27
- let server: Server
28
-
29
- const getCacheSize = () => {
30
- return server.app.models.size
31
- }
32
-
33
- const getCacheItem = (key: string) => {
34
- return server.app.models.get(key)
35
- }
36
-
37
- beforeAll(async () => {
38
- server = await createServer({
39
- services: defaultServices
40
- })
41
- await server.initialize()
42
- })
43
-
44
- beforeEach(() => {
45
- jest.mocked(getFormMetadata).mockResolvedValue(fixtures.form.metadata)
46
- server.app.models.clear()
47
- })
48
-
49
- afterAll(async () => {
50
- await server.stop()
51
- })
52
-
53
- describe('Success responses', () => {
54
- test('Dispatch page with the correct state returns 302', async () => {
55
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
56
- ...fixtures.form.metadata,
57
- live: fixtures.form.state
58
- })
59
-
60
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
61
-
62
- const options = {
63
- method: 'GET',
64
- url: `${FORM_PREFIX}/slug`
65
- }
66
-
67
- const res = await server.inject(options)
68
-
69
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
70
- expect(res.headers.location).toBe(`${FORM_PREFIX}/slug/page-one`)
71
- expect(getCacheSize()).toBe(1)
72
- })
73
-
74
- test('Dispatch preview page with the correct live state returns 302', async () => {
75
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
76
- ...fixtures.form.metadata,
77
- live: fixtures.form.state
78
- })
79
-
80
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
81
-
82
- const options = {
83
- method: 'GET',
84
- url: `${FORM_PREFIX}/preview/live/slug`
85
- }
86
-
87
- const res = await server.inject(options)
88
-
89
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
90
- expect(res.headers.location).toBe(
91
- `${FORM_PREFIX}/preview/live/slug/page-one`
92
- )
93
- expect(getCacheSize()).toBe(1)
94
- })
95
-
96
- test('Dispatch preview page with the correct draft state returns 302', async () => {
97
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
98
- ...fixtures.form.metadata,
99
- draft: fixtures.form.state
100
- })
101
-
102
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
103
-
104
- const options = {
105
- method: 'GET',
106
- url: `${FORM_PREFIX}/preview/draft/slug`
107
- }
108
-
109
- const res = await server.inject(options)
110
-
111
- expect(res.statusCode).toBe(StatusCodes.MOVED_TEMPORARILY)
112
- expect(res.headers.location).toBe(
113
- `${FORM_PREFIX}/preview/draft/slug/page-one`
114
- )
115
- expect(getCacheSize()).toBe(1)
116
- })
117
-
118
- test('Get page with the correct live state returns 200', async () => {
119
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
120
- ...fixtures.form.metadata,
121
- live: fixtures.form.state
122
- })
123
-
124
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
125
-
126
- const options = {
127
- method: 'GET',
128
- url: `${FORM_PREFIX}/slug/page-one`
129
- }
130
-
131
- const res = await server.inject(options)
132
-
133
- expect(res.statusCode).toBe(StatusCodes.OK)
134
- expect(getCacheSize()).toBe(1)
135
- })
136
-
137
- test('Get preview page with the correct live state returns 200', async () => {
138
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
139
- ...fixtures.form.metadata,
140
- live: fixtures.form.state
141
- })
142
-
143
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
144
-
145
- const options = {
146
- method: 'GET',
147
- url: `${FORM_PREFIX}/preview/live/slug/page-one`
148
- }
149
-
150
- const res = await server.inject(options)
151
-
152
- expect(res.statusCode).toBe(StatusCodes.OK)
153
- expect(getCacheSize()).toBe(1)
154
- })
155
-
156
- test('Get preview page with the correct draft state returns 200', async () => {
157
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
158
- ...fixtures.form.metadata,
159
- draft: fixtures.form.state
160
- })
161
-
162
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
163
-
164
- const options = {
165
- method: 'GET',
166
- url: `${FORM_PREFIX}/preview/draft/slug/page-one`
167
- }
168
-
169
- const res = await server.inject(options)
170
-
171
- expect(res.statusCode).toBe(StatusCodes.OK)
172
- expect(getCacheSize()).toBe(1)
173
- })
174
-
175
- test('Get page with the correct state returns 200', async () => {
176
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
177
- ...fixtures.form.metadata,
178
- live: fixtures.form.state
179
- })
180
-
181
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
182
-
183
- const options = {
184
- method: 'GET',
185
- url: `${FORM_PREFIX}/slug/page-one`
186
- }
187
-
188
- const res = await server.inject(options)
189
-
190
- expect(res.statusCode).toBe(StatusCodes.OK)
191
- expect(getCacheSize()).toBe(1)
192
- })
193
-
194
- test('Get page with the correct state populates the cache correctly', async () => {
195
- jest.mocked(getFormMetadata).mockResolvedValue({
196
- ...fixtures.form.metadata,
197
- draft: fixtures.form.state,
198
- live: fixtures.form.state
199
- })
200
-
201
- jest.mocked(getFormDefinition).mockResolvedValue(fixtures.form.definition)
202
-
203
- // Populate live/live cache item
204
- const options1 = {
205
- method: 'GET',
206
- url: `${FORM_PREFIX}/slug/page-one`
207
- }
208
-
209
- const res1 = await server.inject(options1)
210
-
211
- expect(res1.statusCode).toBe(StatusCodes.OK)
212
- expect(getCacheSize()).toBe(1)
213
-
214
- // Populate live/preview cache item
215
- const options2 = {
216
- method: 'GET',
217
- url: `${FORM_PREFIX}/preview/live/slug/page-one`
218
- }
219
-
220
- const res2 = await server.inject(options2)
221
-
222
- expect(res2.statusCode).toBe(StatusCodes.OK)
223
- expect(getCacheSize()).toBe(2)
224
-
225
- // Populate draft/preview cache item
226
- const options3 = {
227
- method: 'GET',
228
- url: `${FORM_PREFIX}/preview/draft/slug/page-one`
229
- }
230
-
231
- const res3 = await server.inject(options3)
232
-
233
- expect(res3.statusCode).toBe(StatusCodes.OK)
234
- expect(getCacheSize()).toBe(3)
235
-
236
- // Execute each request again and
237
- // assert the cache size is unchanged
238
- await server.inject(options1)
239
- await server.inject(options2)
240
- await server.inject(options3)
241
-
242
- expect(getCacheSize()).toBe(3)
243
-
244
- // Check models cache item is regenerated on an update to the state
245
- const now2 = new Date()
246
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
247
- ...fixtures.form.metadata,
248
- draft: fixtures.form.state,
249
- live: { ...fixtures.form.state, updatedAt: now2 }
250
- })
251
-
252
- await server.inject(options1)
253
-
254
- // Expect `getFormDefinition` to be called as the updatedAt has moved on
255
- expect(getFormDefinition).toHaveBeenLastCalledWith(
256
- fixtures.form.metadata.id,
257
- FormStatus.Live
258
- )
259
-
260
- // Assert the live/live cache item has the correct updatedAt timestamp
261
- expect(
262
- getCacheItem(`${fixtures.form.metadata.id}_live_false`)?.updatedAt
263
- ).toBe(now2)
264
-
265
- // Expect the cache size to remain unchanged
266
- expect(getCacheSize()).toBe(3)
267
-
268
- // Assert the number of times `getFormDefinition`
269
- // has only been called 4 times for the 7 requests
270
- expect(getFormDefinition).toHaveBeenCalledTimes(4)
271
- })
272
- })
273
-
274
- describe('Error responses', () => {
275
- test('Dispatch page without the correct state returns 404', async () => {
276
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
277
-
278
- const options = {
279
- method: 'GET',
280
- url: `${FORM_PREFIX}/slug`
281
- }
282
-
283
- const res = await server.inject(options)
284
-
285
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
286
- expect(getCacheSize()).toBe(0)
287
- })
288
-
289
- test('Dispatch preview page without the correct draft state returns 404', async () => {
290
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
291
-
292
- const options = {
293
- method: 'GET',
294
- url: `${FORM_PREFIX}/preview/draft/slug`
295
- }
296
-
297
- const res = await server.inject(options)
298
-
299
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
300
- expect(getCacheSize()).toBe(0)
301
- })
302
-
303
- test('Dispatch preview page without the correct live state returns 404', async () => {
304
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
305
-
306
- const options = {
307
- method: 'GET',
308
- url: `${FORM_PREFIX}/preview/live/slug`
309
- }
310
-
311
- const res = await server.inject(options)
312
-
313
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
314
- expect(getCacheSize()).toBe(0)
315
- })
316
-
317
- test('Dispatch page with the correct live state but no definition returns 404', async () => {
318
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
319
- ...fixtures.form.metadata,
320
- live: fixtures.form.state
321
- })
322
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
323
-
324
- const options = {
325
- method: 'GET',
326
- url: `${FORM_PREFIX}/slug`
327
- }
328
-
329
- const res = await server.inject(options)
330
-
331
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
332
- expect(getCacheSize()).toBe(0)
333
- })
334
-
335
- test('Dispatch preview page with the correct draft state but no definition returns 404', async () => {
336
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
337
- ...fixtures.form.metadata,
338
- live: fixtures.form.state
339
- })
340
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
341
-
342
- const options = {
343
- method: 'GET',
344
- url: `${FORM_PREFIX}/preview/draft/slug`
345
- }
346
-
347
- const res = await server.inject(options)
348
-
349
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
350
- expect(getCacheSize()).toBe(0)
351
- })
352
-
353
- test('Dispatch preview page with the correct live state but no definition returns 404', async () => {
354
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
355
- ...fixtures.form.metadata,
356
- live: fixtures.form.state
357
- })
358
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
359
-
360
- const options = {
361
- method: 'GET',
362
- url: `${FORM_PREFIX}/preview/live/slug`
363
- }
364
-
365
- const res = await server.inject(options)
366
-
367
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
368
- expect(getCacheSize()).toBe(0)
369
- })
370
-
371
- test('Get page without the correct state returns 404', async () => {
372
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
373
-
374
- const options = {
375
- method: 'GET',
376
- url: `${FORM_PREFIX}/slug/page-one`
377
- }
378
-
379
- const res = await server.inject(options)
380
-
381
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
382
- expect(getCacheSize()).toBe(0)
383
- })
384
-
385
- test('Get preview page without the correct draft state returns 404', async () => {
386
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
387
-
388
- const options = {
389
- method: 'GET',
390
- url: `${FORM_PREFIX}/preview/draft/slug/page-one`
391
- }
392
-
393
- const res = await server.inject(options)
394
-
395
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
396
- expect(getCacheSize()).toBe(0)
397
- })
398
-
399
- test('Get preview page without the correct live state returns 404', async () => {
400
- jest.mocked(getFormMetadata).mockResolvedValueOnce(fixtures.form.metadata)
401
-
402
- const options = {
403
- method: 'GET',
404
- url: `${FORM_PREFIX}/preview/live/slug/page-one`
405
- }
406
-
407
- const res = await server.inject(options)
408
-
409
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
410
- expect(getCacheSize()).toBe(0)
411
- })
412
-
413
- test('Get page with the correct live state but no definition returns 404', async () => {
414
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
415
- ...fixtures.form.metadata,
416
- live: fixtures.form.state
417
- })
418
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
419
-
420
- const options = {
421
- method: 'GET',
422
- url: `${FORM_PREFIX}/slug/page-one`
423
- }
424
-
425
- const res = await server.inject(options)
426
-
427
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
428
- expect(getCacheSize()).toBe(0)
429
- })
430
-
431
- test('Get preview page with the correct draft state but no definition returns 404', async () => {
432
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
433
- ...fixtures.form.metadata,
434
- live: fixtures.form.state
435
- })
436
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
437
-
438
- const options = {
439
- method: 'GET',
440
- url: `${FORM_PREFIX}/preview/draft/slug/page-one`
441
- }
442
-
443
- const res = await server.inject(options)
444
-
445
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
446
- expect(getCacheSize()).toBe(0)
447
- })
448
-
449
- test('Get preview page with the correct live state but no definition returns 404', async () => {
450
- jest.mocked(getFormMetadata).mockResolvedValueOnce({
451
- ...fixtures.form.metadata,
452
- live: fixtures.form.state
453
- })
454
- jest.mocked(getFormDefinition).mockResolvedValue(undefined)
455
-
456
- const options = {
457
- method: 'GET',
458
- url: `${FORM_PREFIX}/preview/live/slug/page-one`
459
- }
460
-
461
- const res = await server.inject(options)
462
-
463
- expect(res.statusCode).toBe(StatusCodes.NOT_FOUND)
464
- expect(getCacheSize()).toBe(0)
465
- })
466
- })
467
- })
468
-
469
- describe('Upload status route', () => {
470
- let server: Server
471
-
472
- beforeAll(async () => {
473
- server = await createServer()
474
- await server.initialize()
475
- })
476
-
477
- afterAll(async () => {
478
- await server.stop()
479
- })
480
-
481
- beforeEach(() => {
482
- jest.resetAllMocks()
483
- })
484
-
485
- test('GET /upload-status/{uploadId} returns upload status with 200 when successful', async () => {
486
- const mockStatus: UploadStatusResponse = {
487
- uploadStatus: UploadStatus.ready,
488
- metadata: {
489
- retrievalKey: 'some-key'
490
- },
491
- form: {
492
- file: {
493
- fileId: 'some-file-id',
494
- filename: 'some-file-name',
495
- contentLength: 1024,
496
- fileStatus: FileStatus.complete
497
- }
498
- },
499
- numberOfRejectedFiles: 0
500
- }
501
- jest.mocked(getUploadStatus).mockResolvedValueOnce(mockStatus)
502
-
503
- const options = {
504
- method: 'GET',
505
- url: `${FORM_PREFIX}/upload-status/123e4567-e89b-12d3-a456-426614174000`
506
- }
507
-
508
- const res = await server.inject(options)
509
-
510
- expect(res.statusCode).toBe(StatusCodes.OK)
511
- expect(res.result).toEqual({
512
- uploadStatus: UploadStatus.ready
513
- })
514
- expect(getUploadStatus).toHaveBeenCalledWith(
515
- '123e4567-e89b-12d3-a456-426614174000'
516
- )
517
- })
518
-
519
- test('GET /upload-status/{uploadId} returns 400 when status check fails', async () => {
520
- jest.mocked(getUploadStatus).mockResolvedValueOnce(undefined)
521
-
522
- const options = {
523
- method: 'GET',
524
- url: `${FORM_PREFIX}/upload-status/123e4567-e89b-12d3-a456-426614174000`
525
- }
526
-
527
- const res = await server.inject(options)
528
-
529
- expect(res.statusCode).toBe(StatusCodes.BAD_REQUEST)
530
- expect(res.result).toEqual({ error: 'Status check failed' })
531
- })
532
-
533
- test('GET /upload-status/{uploadId} returns 500 when exception occurs', async () => {
534
- jest
535
- .mocked(getUploadStatus)
536
- .mockRejectedValueOnce(new Error('Service unavailable'))
537
-
538
- const options = {
539
- method: 'GET',
540
- url: `${FORM_PREFIX}/upload-status/123e4567-e89b-12d3-a456-426614174000`
541
- }
542
-
543
- const res = await server.inject(options)
544
-
545
- expect(res.statusCode).toBe(StatusCodes.INTERNAL_SERVER_ERROR)
546
- expect(res.result).toEqual({ error: 'Status check error' })
547
- })
548
-
549
- test('GET /upload-status/{uploadId} returns 400 for invalid uploadId format', async () => {
550
- const options = {
551
- method: 'GET',
552
- url: `${FORM_PREFIX}/upload-status/not-a-valid-guid`
553
- }
554
-
555
- const res = await server.inject(options)
556
-
557
- expect(res.statusCode).toBe(StatusCodes.BAD_REQUEST)
558
- })
559
- })
560
-
561
- describe('prepareEnvironment', () => {
562
- const mockEnv = {
563
- addFilter: jest.fn(),
564
- addGlobal: jest.fn()
565
- } as unknown as Environment
566
-
567
- const mockPluginOptions: PluginOptions = {
568
- baseUrl: 'http://localhost',
569
- nunjucks: {
570
- baseLayoutPath: '',
571
- paths: []
572
- },
573
- viewContext: undefined
574
- }
575
-
576
- beforeEach(() => {
577
- jest.clearAllMocks()
578
- })
579
-
580
- const expectedBaseFilters = [
581
- 'highlight',
582
- 'inspect',
583
- 'evaluate',
584
- 'answer',
585
- 'href',
586
- 'field',
587
- 'page',
588
- 'merge',
589
- 'markdown'
590
- ]
591
-
592
- test('registers base filters', () => {
593
- prepareNunjucksEnvironment(mockEnv, mockPluginOptions)
594
-
595
- expect(mockEnv.addFilter).toHaveBeenCalledTimes(expectedBaseFilters.length)
596
- expectedBaseFilters.forEach((name) => {
597
- expect(mockEnv.addFilter).toHaveBeenCalledWith(name, expect.any(Function))
598
- })
599
- })
600
-
601
- test('registers additional filters', () => {
602
- prepareNunjucksEnvironment(mockEnv, {
603
- ...mockPluginOptions,
604
- filters: {
605
- customFilter: (value) => value
606
- }
607
- })
608
-
609
- expect(mockEnv.addFilter).toHaveBeenCalledWith(
610
- 'customFilter',
611
- expect.any(Function)
612
- )
613
- })
614
-
615
- test('registers base globals', () => {
616
- const expectedGlobals = [
617
- 'checkComponentTemplates',
618
- 'checkErrorTemplates',
619
- 'evaluate',
620
- 'govukRebrand'
621
- ]
622
-
623
- prepareNunjucksEnvironment(mockEnv, mockPluginOptions)
624
-
625
- expect(mockEnv.addGlobal).toHaveBeenCalledTimes(expectedGlobals.length)
626
- expectedGlobals.forEach((name) => {
627
- expect(mockEnv.addGlobal).toHaveBeenCalledWith(name, expect.any(Function))
628
- })
629
- })
630
-
631
- test('registers additional globals', () => {
632
- prepareNunjucksEnvironment(mockEnv, {
633
- ...mockPluginOptions,
634
- globals: {
635
- customGlobal: (value) => value
636
- }
637
- })
638
-
639
- expect(mockEnv.addGlobal).toHaveBeenCalledWith(
640
- 'customGlobal',
641
- expect.any(Function)
642
- )
643
- })
644
- })