@defra/forms-engine-plugin 4.7.2 → 4.7.3

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 (402) hide show
  1. package/.server/client/javascripts/geospatial-map.d.ts +6 -6
  2. package/.server/client/javascripts/geospatial-map.js +3 -3
  3. package/.server/client/javascripts/location-map.d.ts +1 -1
  4. package/.server/client/javascripts/location-map.js +1 -1
  5. package/.server/client/javascripts/map.d.ts +1 -1
  6. package/.server/client/javascripts/map.js +1 -1
  7. package/.server/client/javascripts/shared.d.ts +7 -7
  8. package/.server/server/index.d.ts +1 -1
  9. package/.server/server/plugins/crumb.d.ts +1 -1
  10. package/.server/server/plugins/engine/beta/form-context.d.ts +6 -6
  11. package/.server/server/plugins/engine/components/AutocompleteField.d.ts +4 -4
  12. package/.server/server/plugins/engine/components/CheckboxesField.d.ts +2 -2
  13. package/.server/server/plugins/engine/components/CheckboxesField.js +2 -2
  14. package/.server/server/plugins/engine/components/CheckboxesField.js.map +1 -1
  15. package/.server/server/plugins/engine/components/ComponentBase.d.ts +5 -5
  16. package/.server/server/plugins/engine/components/ComponentCollection.d.ts +8 -8
  17. package/.server/server/plugins/engine/components/DatePartsField.d.ts +11 -11
  18. package/.server/server/plugins/engine/components/DeclarationField.d.ts +3 -3
  19. package/.server/server/plugins/engine/components/Details.d.ts +1 -1
  20. package/.server/server/plugins/engine/components/EastingNorthingField.d.ts +22 -22
  21. package/.server/server/plugins/engine/components/EmailAddressField.d.ts +4 -4
  22. package/.server/server/plugins/engine/components/FileUploadField.d.ts +3 -3
  23. package/.server/server/plugins/engine/components/FormComponent.d.ts +10 -10
  24. package/.server/server/plugins/engine/components/GeospatialField.d.ts +6 -6
  25. package/.server/server/plugins/engine/components/HiddenField.d.ts +2 -2
  26. package/.server/server/plugins/engine/components/Html.d.ts +1 -1
  27. package/.server/server/plugins/engine/components/InsetText.d.ts +1 -1
  28. package/.server/server/plugins/engine/components/LatLongField.d.ts +22 -22
  29. package/.server/server/plugins/engine/components/List.d.ts +8 -8
  30. package/.server/server/plugins/engine/components/ListFormComponent.d.ts +10 -10
  31. package/.server/server/plugins/engine/components/LocationFieldBase.d.ts +6 -6
  32. package/.server/server/plugins/engine/components/LocationFieldHelpers.d.ts +14 -14
  33. package/.server/server/plugins/engine/components/Markdown.d.ts +1 -1
  34. package/.server/server/plugins/engine/components/MonthYearField.d.ts +11 -11
  35. package/.server/server/plugins/engine/components/MultilineTextField.d.ts +5 -5
  36. package/.server/server/plugins/engine/components/NationalGridFieldNumberField.d.ts +1 -1
  37. package/.server/server/plugins/engine/components/NumberField.d.ts +3 -3
  38. package/.server/server/plugins/engine/components/OsGridRefField.d.ts +1 -1
  39. package/.server/server/plugins/engine/components/PaymentField.d.ts +12 -12
  40. package/.server/server/plugins/engine/components/RadiosField.d.ts +1 -1
  41. package/.server/server/plugins/engine/components/SelectField.d.ts +4 -4
  42. package/.server/server/plugins/engine/components/SelectionControlField.d.ts +10 -10
  43. package/.server/server/plugins/engine/components/TelephoneNumberField.d.ts +4 -4
  44. package/.server/server/plugins/engine/components/TextField.d.ts +2 -2
  45. package/.server/server/plugins/engine/components/UkAddressField.d.ts +11 -11
  46. package/.server/server/plugins/engine/components/YesNoField.d.ts +2 -2
  47. package/.server/server/plugins/engine/components/helpers/__stubs__/geospatial.d.ts +1 -1
  48. package/.server/server/plugins/engine/components/helpers/components.d.ts +5 -5
  49. package/.server/server/plugins/engine/components/helpers/geospatial.d.ts +1 -1
  50. package/.server/server/plugins/engine/components/index.d.ts +27 -27
  51. package/.server/server/plugins/engine/components/types.d.ts +1 -1
  52. package/.server/server/plugins/engine/configureEnginePlugin.d.ts +4 -4
  53. package/.server/server/plugins/engine/date-helper.d.ts +1 -1
  54. package/.server/server/plugins/engine/helpers.d.ts +8 -8
  55. package/.server/server/plugins/engine/index.d.ts +5 -5
  56. package/.server/server/plugins/engine/models/FormModel.d.ts +6 -6
  57. package/.server/server/plugins/engine/models/SummaryViewModel.d.ts +6 -6
  58. package/.server/server/plugins/engine/models/index.d.ts +2 -2
  59. package/.server/server/plugins/engine/models/types.d.ts +4 -4
  60. package/.server/server/plugins/engine/options.d.ts +1 -1
  61. package/.server/server/plugins/engine/options.js +1 -1
  62. package/.server/server/plugins/engine/options.test.js +1 -1
  63. package/.server/server/plugins/engine/outputFormatters/adapter/v1.d.ts +4 -4
  64. package/.server/server/plugins/engine/outputFormatters/human/v1.d.ts +4 -4
  65. package/.server/server/plugins/engine/outputFormatters/index.d.ts +5 -5
  66. package/.server/server/plugins/engine/outputFormatters/machine/v1.d.ts +4 -4
  67. package/.server/server/plugins/engine/outputFormatters/machine/v2.d.ts +4 -4
  68. package/.server/server/plugins/engine/pageControllers/FileUploadPageController.d.ts +8 -8
  69. package/.server/server/plugins/engine/pageControllers/PageController.d.ts +6 -6
  70. package/.server/server/plugins/engine/pageControllers/QuestionPageController.d.ts +8 -8
  71. package/.server/server/plugins/engine/pageControllers/RepeatPageController.d.ts +5 -5
  72. package/.server/server/plugins/engine/pageControllers/StartPageController.d.ts +4 -4
  73. package/.server/server/plugins/engine/pageControllers/StatusPageController.d.ts +4 -4
  74. package/.server/server/plugins/engine/pageControllers/SummaryPageController.d.ts +5 -5
  75. package/.server/server/plugins/engine/pageControllers/TerminalPageController.d.ts +3 -3
  76. package/.server/server/plugins/engine/pageControllers/__stubs__/request.d.ts +2 -2
  77. package/.server/server/plugins/engine/pageControllers/errors.d.ts +1 -1
  78. package/.server/server/plugins/engine/pageControllers/helpers/pages.d.ts +2 -2
  79. package/.server/server/plugins/engine/pageControllers/helpers/state.d.ts +5 -5
  80. package/.server/server/plugins/engine/pageControllers/helpers/state.js +1 -1
  81. package/.server/server/plugins/engine/pageControllers/helpers/state.js.map +1 -1
  82. package/.server/server/plugins/engine/pageControllers/helpers/submission.d.ts +1 -1
  83. package/.server/server/plugins/engine/pageControllers/index.d.ts +7 -7
  84. package/.server/server/plugins/engine/plugin.d.ts +1 -1
  85. package/.server/server/plugins/engine/routes/file-upload.d.ts +1 -1
  86. package/.server/server/plugins/engine/routes/index.d.ts +3 -3
  87. package/.server/server/plugins/engine/routes/payment-helper.d.ts +3 -3
  88. package/.server/server/plugins/engine/routes/payment-helper.js +2 -2
  89. package/.server/server/plugins/engine/routes/payment.js +5 -5
  90. package/.server/server/plugins/engine/routes/payment.test.js +1 -1
  91. package/.server/server/plugins/engine/routes/questions.d.ts +2 -2
  92. package/.server/server/plugins/engine/routes/repeaters/item-delete.d.ts +2 -2
  93. package/.server/server/plugins/engine/routes/repeaters/summary.d.ts +2 -2
  94. package/.server/server/plugins/engine/services/index.d.ts +3 -3
  95. package/.server/server/plugins/engine/services/notifyService.d.ts +4 -4
  96. package/.server/server/plugins/engine/services/uploadService.d.ts +2 -2
  97. package/.server/server/plugins/engine/services/uploadService.js +1 -1
  98. package/.server/server/plugins/engine/types/index.d.ts +10 -10
  99. package/.server/server/plugins/engine/types/schema.d.ts +1 -1
  100. package/.server/server/plugins/engine/types.d.ts +25 -16
  101. package/.server/server/plugins/engine/types.js.map +1 -1
  102. package/.server/server/plugins/engine/validationHelpers.d.ts +2 -2
  103. package/.server/server/plugins/engine/vision.d.ts +1 -1
  104. package/.server/server/plugins/map/index.d.ts +1 -1
  105. package/.server/server/plugins/map/index.js +1 -1
  106. package/.server/server/plugins/map/routes/get-os-token.d.ts +11 -1
  107. package/.server/server/plugins/map/routes/get-os-token.js +12 -2
  108. package/.server/server/plugins/map/routes/get-os-token.js.map +1 -1
  109. package/.server/server/plugins/map/routes/index.d.ts +4 -4
  110. package/.server/server/plugins/map/routes/index.js +3 -2
  111. package/.server/server/plugins/map/routes/index.js.map +1 -1
  112. package/.server/server/plugins/map/service.d.ts +1 -1
  113. package/.server/server/plugins/map/service.js +5 -2
  114. package/.server/server/plugins/map/service.js.map +1 -1
  115. package/.server/server/plugins/map/test/__stubs__/find.d.ts +1 -1
  116. package/.server/server/plugins/map/test/__stubs__/find.js +1 -1
  117. package/.server/server/plugins/nunjucks/context.d.ts +2 -2
  118. package/.server/server/plugins/nunjucks/context.js +2 -2
  119. package/.server/server/plugins/nunjucks/context.test.js +1 -1
  120. package/.server/server/plugins/nunjucks/enviroment.test.js +1 -1
  121. package/.server/server/plugins/nunjucks/environment.d.ts +3 -3
  122. package/.server/server/plugins/nunjucks/environment.js +3 -3
  123. package/.server/server/plugins/nunjucks/filters/answer.d.ts +1 -1
  124. package/.server/server/plugins/nunjucks/filters/answer.js +2 -2
  125. package/.server/server/plugins/nunjucks/filters/answer.test.js +1 -1
  126. package/.server/server/plugins/nunjucks/filters/evaluate.d.ts +1 -1
  127. package/.server/server/plugins/nunjucks/filters/evaluate.js +1 -1
  128. package/.server/server/plugins/nunjucks/filters/field.d.ts +1 -1
  129. package/.server/server/plugins/nunjucks/filters/field.js +1 -1
  130. package/.server/server/plugins/nunjucks/filters/field.test.js +1 -1
  131. package/.server/server/plugins/nunjucks/filters/href.d.ts +1 -1
  132. package/.server/server/plugins/nunjucks/filters/href.js +1 -1
  133. package/.server/server/plugins/nunjucks/filters/href.test.js +1 -1
  134. package/.server/server/plugins/nunjucks/filters/index.d.ts +8 -8
  135. package/.server/server/plugins/nunjucks/filters/page.d.ts +1 -1
  136. package/.server/server/plugins/nunjucks/filters/page.js +1 -1
  137. package/.server/server/plugins/nunjucks/filters/page.test.js +1 -1
  138. package/.server/server/plugins/nunjucks/index.d.ts +3 -3
  139. package/.server/server/plugins/nunjucks/render.d.ts +2 -2
  140. package/.server/server/plugins/nunjucks/render.js +1 -1
  141. package/.server/server/plugins/nunjucks/types.d.ts +1 -1
  142. package/.server/server/plugins/nunjucks/types.js +1 -1
  143. package/.server/server/plugins/payment/helper.d.ts +2 -2
  144. package/.server/server/plugins/payment/helper.js +1 -1
  145. package/.server/server/plugins/payment/service.d.ts +3 -3
  146. package/.server/server/plugins/payment/service.js +1 -1
  147. package/.server/server/plugins/postcode-lookup/index.d.ts +1 -1
  148. package/.server/server/plugins/postcode-lookup/index.js +1 -1
  149. package/.server/server/plugins/postcode-lookup/models/index.d.ts +6 -6
  150. package/.server/server/plugins/postcode-lookup/models/index.js +1 -1
  151. package/.server/server/plugins/postcode-lookup/routes/index.d.ts +6 -6
  152. package/.server/server/plugins/postcode-lookup/routes/index.js +15 -15
  153. package/.server/server/plugins/postcode-lookup/routes/index.js.map +1 -1
  154. package/.server/server/plugins/postcode-lookup/service.d.ts +1 -1
  155. package/.server/server/plugins/postcode-lookup/service.js +5 -2
  156. package/.server/server/plugins/postcode-lookup/service.js.map +1 -1
  157. package/.server/server/plugins/postcode-lookup/types.js +1 -1
  158. package/.server/server/routes/index.d.ts +2 -2
  159. package/.server/server/routes/types.d.ts +1 -1
  160. package/.server/server/schemas/index.d.ts +2 -2
  161. package/.server/server/services/cacheService.d.ts +8 -8
  162. package/.server/server/services/cacheService.js +2 -5
  163. package/.server/server/services/cacheService.js.map +1 -1
  164. package/.server/server/services/httpService.test.js +1 -1
  165. package/.server/server/services/index.d.ts +1 -1
  166. package/.server/server/types.d.ts +7 -7
  167. package/.server/server/utils/file-form-service.d.ts +2 -2
  168. package/.server/server/utils/file-form-service.js +1 -1
  169. package/package.json +8 -4
  170. package/src/client/javascripts/application.js +1 -1
  171. package/src/client/javascripts/geospatial-map.js +4 -4
  172. package/src/client/javascripts/location-map.js +2 -2
  173. package/src/client/javascripts/map.js +3 -3
  174. package/src/client/javascripts/shared.js +7 -7
  175. package/src/index.ts +3 -3
  176. package/src/server/common/helpers/logging/logger-options.ts +1 -1
  177. package/src/server/common/helpers/logging/logger.ts +1 -1
  178. package/src/server/common/helpers/logging/request-logger.ts +1 -1
  179. package/src/server/common/helpers/logging/request-tracing.js +1 -1
  180. package/src/server/common/helpers/redis-client.js +2 -2
  181. package/src/server/index.ts +13 -13
  182. package/src/server/plugins/crumb.ts +2 -2
  183. package/src/server/plugins/engine/beta/form-context.ts +9 -9
  184. package/src/server/plugins/engine/components/AutocompleteField.ts +3 -3
  185. package/src/server/plugins/engine/components/CheckboxesField.ts +7 -8
  186. package/src/server/plugins/engine/components/ComponentBase.ts +5 -5
  187. package/src/server/plugins/engine/components/ComponentCollection.ts +9 -9
  188. package/src/server/plugins/engine/components/DatePartsField.ts +8 -8
  189. package/src/server/plugins/engine/components/DeclarationField.ts +3 -3
  190. package/src/server/plugins/engine/components/Details.ts +1 -1
  191. package/src/server/plugins/engine/components/EastingNorthingField.ts +9 -9
  192. package/src/server/plugins/engine/components/EmailAddressField.ts +3 -3
  193. package/src/server/plugins/engine/components/FileUploadField.ts +6 -6
  194. package/src/server/plugins/engine/components/FormComponent.ts +4 -4
  195. package/src/server/plugins/engine/components/GeospatialField.ts +5 -5
  196. package/src/server/plugins/engine/components/HiddenField.ts +4 -4
  197. package/src/server/plugins/engine/components/Html.ts +1 -1
  198. package/src/server/plugins/engine/components/InsetText.ts +1 -1
  199. package/src/server/plugins/engine/components/LatLongField.ts +9 -9
  200. package/src/server/plugins/engine/components/List.ts +2 -2
  201. package/src/server/plugins/engine/components/ListFormComponent.ts +4 -4
  202. package/src/server/plugins/engine/components/LocationFieldBase.ts +5 -5
  203. package/src/server/plugins/engine/components/LocationFieldHelpers.ts +5 -5
  204. package/src/server/plugins/engine/components/Markdown.ts +1 -1
  205. package/src/server/plugins/engine/components/MonthYearField.ts +8 -8
  206. package/src/server/plugins/engine/components/MultilineTextField.ts +4 -4
  207. package/src/server/plugins/engine/components/NationalGridFieldNumberField.ts +2 -2
  208. package/src/server/plugins/engine/components/NumberField.ts +3 -3
  209. package/src/server/plugins/engine/components/OsGridRefField.ts +2 -2
  210. package/src/server/plugins/engine/components/PaymentField.ts +8 -8
  211. package/src/server/plugins/engine/components/RadiosField.ts +1 -1
  212. package/src/server/plugins/engine/components/SelectField.ts +2 -2
  213. package/src/server/plugins/engine/components/SelectionControlField.ts +4 -4
  214. package/src/server/plugins/engine/components/TelephoneNumberField.ts +4 -4
  215. package/src/server/plugins/engine/components/TextField.ts +3 -3
  216. package/src/server/plugins/engine/components/UkAddressField.ts +7 -7
  217. package/src/server/plugins/engine/components/YesNoField.ts +5 -5
  218. package/src/server/plugins/engine/components/helpers/__stubs__/geospatial.ts +1 -1
  219. package/src/server/plugins/engine/components/helpers/components.ts +8 -8
  220. package/src/server/plugins/engine/components/helpers/geospatial.ts +1 -1
  221. package/src/server/plugins/engine/components/index.ts +27 -27
  222. package/src/server/plugins/engine/components/types.ts +1 -1
  223. package/src/server/plugins/engine/configureEnginePlugin.ts +10 -10
  224. package/src/server/plugins/engine/date-helper.ts +1 -1
  225. package/src/server/plugins/engine/helpers.ts +8 -8
  226. package/src/server/plugins/engine/index.ts +8 -8
  227. package/src/server/plugins/engine/models/FormModel.ts +15 -15
  228. package/src/server/plugins/engine/models/SummaryViewModel.ts +10 -10
  229. package/src/server/plugins/engine/models/index.ts +2 -2
  230. package/src/server/plugins/engine/models/types.ts +4 -4
  231. package/src/server/plugins/engine/options.js +3 -3
  232. package/src/server/plugins/engine/outputFormatters/adapter/v1.ts +6 -6
  233. package/src/server/plugins/engine/outputFormatters/human/v1.ts +9 -9
  234. package/src/server/plugins/engine/outputFormatters/index.ts +8 -8
  235. package/src/server/plugins/engine/outputFormatters/machine/v1.ts +7 -7
  236. package/src/server/plugins/engine/outputFormatters/machine/v2.ts +6 -6
  237. package/src/server/plugins/engine/pageControllers/FileUploadPageController.ts +9 -9
  238. package/src/server/plugins/engine/pageControllers/PageController.ts +7 -7
  239. package/src/server/plugins/engine/pageControllers/QuestionPageController.ts +13 -13
  240. package/src/server/plugins/engine/pageControllers/RepeatPageController.ts +6 -6
  241. package/src/server/plugins/engine/pageControllers/StartPageController.ts +3 -3
  242. package/src/server/plugins/engine/pageControllers/StatusPageController.ts +5 -5
  243. package/src/server/plugins/engine/pageControllers/SummaryPageController.ts +12 -12
  244. package/src/server/plugins/engine/pageControllers/TerminalPageController.ts +3 -3
  245. package/src/server/plugins/engine/pageControllers/__stubs__/request.ts +3 -3
  246. package/src/server/plugins/engine/pageControllers/__stubs__/server.ts +2 -2
  247. package/src/server/plugins/engine/pageControllers/errors.ts +1 -1
  248. package/src/server/plugins/engine/pageControllers/helpers/pages.ts +2 -2
  249. package/src/server/plugins/engine/pageControllers/helpers/state.ts +9 -9
  250. package/src/server/plugins/engine/pageControllers/helpers/submission.ts +5 -5
  251. package/src/server/plugins/engine/pageControllers/index.ts +7 -7
  252. package/src/server/plugins/engine/pageControllers/validationOptions.ts +1 -1
  253. package/src/server/plugins/engine/plugin.ts +14 -14
  254. package/src/server/plugins/engine/routes/file-upload.ts +2 -2
  255. package/src/server/plugins/engine/routes/index.ts +10 -10
  256. package/src/server/plugins/engine/routes/payment-helper.js +4 -4
  257. package/src/server/plugins/engine/routes/payment.js +9 -9
  258. package/src/server/plugins/engine/routes/questions.ts +10 -10
  259. package/src/server/plugins/engine/routes/repeaters/item-delete.ts +6 -6
  260. package/src/server/plugins/engine/routes/repeaters/summary.ts +5 -5
  261. package/src/server/plugins/engine/services/formSubmissionService.js +2 -2
  262. package/src/server/plugins/engine/services/index.js +3 -3
  263. package/src/server/plugins/engine/services/localFormsService.js +2 -2
  264. package/src/server/plugins/engine/services/notifyService.ts +9 -9
  265. package/src/server/plugins/engine/services/uploadService.js +3 -3
  266. package/src/server/plugins/engine/types/index.ts +10 -10
  267. package/src/server/plugins/engine/types/schema.ts +2 -2
  268. package/src/server/plugins/engine/types.ts +22 -17
  269. package/src/server/plugins/engine/validationHelpers.ts +3 -3
  270. package/src/server/plugins/engine/vision.ts +3 -3
  271. package/src/server/plugins/map/index.js +2 -2
  272. package/src/server/plugins/map/routes/get-os-token.js +15 -3
  273. package/src/server/plugins/map/routes/index.js +7 -5
  274. package/src/server/plugins/map/service.js +7 -4
  275. package/src/server/plugins/map/test/__stubs__/find.js +1 -1
  276. package/src/server/plugins/nunjucks/context.js +5 -5
  277. package/src/server/plugins/nunjucks/environment.js +6 -6
  278. package/src/server/plugins/nunjucks/filters/answer.js +3 -3
  279. package/src/server/plugins/nunjucks/filters/evaluate.js +2 -2
  280. package/src/server/plugins/nunjucks/filters/field.js +1 -1
  281. package/src/server/plugins/nunjucks/filters/href.js +2 -2
  282. package/src/server/plugins/nunjucks/filters/index.js +8 -8
  283. package/src/server/plugins/nunjucks/filters/page.js +1 -1
  284. package/src/server/plugins/nunjucks/index.js +3 -3
  285. package/src/server/plugins/nunjucks/plugin.js +3 -3
  286. package/src/server/plugins/nunjucks/render.js +2 -2
  287. package/src/server/plugins/nunjucks/types.js +1 -1
  288. package/src/server/plugins/payment/helper.js +2 -2
  289. package/src/server/plugins/payment/service.js +4 -4
  290. package/src/server/plugins/postcode-lookup/index.js +2 -2
  291. package/src/server/plugins/postcode-lookup/models/index.js +3 -3
  292. package/src/server/plugins/postcode-lookup/routes/index.js +24 -14
  293. package/src/server/plugins/postcode-lookup/service.js +7 -4
  294. package/src/server/plugins/postcode-lookup/types.js +1 -1
  295. package/src/server/plugins/session.ts +1 -1
  296. package/src/server/routes/index.ts +2 -2
  297. package/src/server/routes/public.ts +1 -1
  298. package/src/server/routes/types.ts +1 -1
  299. package/src/server/schemas/index.ts +2 -2
  300. package/src/server/secure-context.js +1 -1
  301. package/src/server/services/cacheService.ts +13 -18
  302. package/src/server/services/httpService.ts +1 -1
  303. package/src/server/services/index.ts +1 -1
  304. package/src/server/types.ts +7 -7
  305. package/src/server/utils/notify.ts +2 -2
  306. package/src/server/utils/utils.js +1 -1
  307. package/src/typings/hapi/index.d.ts +4 -4
  308. package/src/typings/joi/index.d.ts +1 -1
  309. package/src/server/common/helpers/logging/logger-options.test.ts +0 -50
  310. package/src/server/index.test.ts +0 -644
  311. package/src/server/plugins/engine/beta/form-context.test.ts +0 -373
  312. package/src/server/plugins/engine/components/AutocompleteField.test.ts +0 -362
  313. package/src/server/plugins/engine/components/CheckboxesField.test.ts +0 -486
  314. package/src/server/plugins/engine/components/DatePartsField.test.ts +0 -927
  315. package/src/server/plugins/engine/components/DeclarationField.test.ts +0 -560
  316. package/src/server/plugins/engine/components/Details.test.ts +0 -49
  317. package/src/server/plugins/engine/components/EastingNorthingField.test.ts +0 -727
  318. package/src/server/plugins/engine/components/EmailAddressField.test.ts +0 -445
  319. package/src/server/plugins/engine/components/FileUploadField.test.ts +0 -1079
  320. package/src/server/plugins/engine/components/GeospatialField.test.ts +0 -380
  321. package/src/server/plugins/engine/components/HiddenField.test.ts +0 -188
  322. package/src/server/plugins/engine/components/Html.test.ts +0 -48
  323. package/src/server/plugins/engine/components/InsetText.test.ts +0 -48
  324. package/src/server/plugins/engine/components/LatLongField.test.ts +0 -898
  325. package/src/server/plugins/engine/components/List.test.ts +0 -79
  326. package/src/server/plugins/engine/components/LocationFieldBase.test.ts +0 -253
  327. package/src/server/plugins/engine/components/LocationFieldHelpers.test.ts +0 -743
  328. package/src/server/plugins/engine/components/Markdown.test.ts +0 -48
  329. package/src/server/plugins/engine/components/MonthYearField.test.ts +0 -617
  330. package/src/server/plugins/engine/components/MultilineTextField.test.ts +0 -647
  331. package/src/server/plugins/engine/components/NationalGridFieldNumberField.test.ts +0 -449
  332. package/src/server/plugins/engine/components/NumberField.test.ts +0 -723
  333. package/src/server/plugins/engine/components/OsGridRefField.test.ts +0 -460
  334. package/src/server/plugins/engine/components/PaymentField.test.ts +0 -745
  335. package/src/server/plugins/engine/components/RadiosField.test.ts +0 -297
  336. package/src/server/plugins/engine/components/SelectField.test.ts +0 -289
  337. package/src/server/plugins/engine/components/TelephoneNumberField.test.ts +0 -384
  338. package/src/server/plugins/engine/components/TextField.test.ts +0 -521
  339. package/src/server/plugins/engine/components/UkAddressField.test.ts +0 -806
  340. package/src/server/plugins/engine/components/YesNoField.test.ts +0 -256
  341. package/src/server/plugins/engine/components/helpers/components.test.ts +0 -399
  342. package/src/server/plugins/engine/components/helpers/geospatial.test.js +0 -55
  343. package/src/server/plugins/engine/components/helpers/helpers.test.ts +0 -219
  344. package/src/server/plugins/engine/date-helper.test.ts +0 -47
  345. package/src/server/plugins/engine/helpers.test.ts +0 -868
  346. package/src/server/plugins/engine/models/FormModel.test.ts +0 -725
  347. package/src/server/plugins/engine/models/SummaryViewModel.test.ts +0 -472
  348. package/src/server/plugins/engine/options.test.js +0 -63
  349. package/src/server/plugins/engine/outputFormatters/adapter/v1.location.test.ts +0 -356
  350. package/src/server/plugins/engine/outputFormatters/adapter/v1.test.ts +0 -871
  351. package/src/server/plugins/engine/outputFormatters/human/v1.payment.test.ts +0 -147
  352. package/src/server/plugins/engine/outputFormatters/human/v1.test.ts +0 -145
  353. package/src/server/plugins/engine/outputFormatters/index.test.ts +0 -17
  354. package/src/server/plugins/engine/outputFormatters/machine/v1.test.ts +0 -268
  355. package/src/server/plugins/engine/outputFormatters/machine/v2.location.test.ts +0 -341
  356. package/src/server/plugins/engine/outputFormatters/machine/v2.payment.test.ts +0 -115
  357. package/src/server/plugins/engine/outputFormatters/machine/v2.test.ts +0 -311
  358. package/src/server/plugins/engine/pageControllers/FileUploadPageController.test.ts +0 -1372
  359. package/src/server/plugins/engine/pageControllers/PageController.test.ts +0 -246
  360. package/src/server/plugins/engine/pageControllers/QuestionPageController.test.ts +0 -1686
  361. package/src/server/plugins/engine/pageControllers/RepeatPageController.test.ts +0 -279
  362. package/src/server/plugins/engine/pageControllers/StartPageController.test.ts +0 -32
  363. package/src/server/plugins/engine/pageControllers/StatusPageController.test.ts +0 -32
  364. package/src/server/plugins/engine/pageControllers/SummaryPageController.test.ts +0 -89
  365. package/src/server/plugins/engine/pageControllers/TerminalController.test.ts +0 -37
  366. package/src/server/plugins/engine/pageControllers/errors.test.ts +0 -78
  367. package/src/server/plugins/engine/pageControllers/helpers/helpers.test.ts +0 -182
  368. package/src/server/plugins/engine/pageControllers/helpers/state.test.ts +0 -359
  369. package/src/server/plugins/engine/pageControllers/helpers/submission.test.ts +0 -373
  370. package/src/server/plugins/engine/referenceNumbers.test.ts +0 -74
  371. package/src/server/plugins/engine/routes/index.test.ts +0 -332
  372. package/src/server/plugins/engine/routes/payment-helper.test.js +0 -136
  373. package/src/server/plugins/engine/routes/payment.test.js +0 -180
  374. package/src/server/plugins/engine/routes/questions.test.ts +0 -502
  375. package/src/server/plugins/engine/routes/repeaters/item-delete.test.ts +0 -83
  376. package/src/server/plugins/engine/routes/repeaters/summary.test.ts +0 -75
  377. package/src/server/plugins/engine/services/formsService.test.js +0 -26
  378. package/src/server/plugins/engine/services/notifyService.test.ts +0 -310
  379. package/src/server/plugins/engine/types/schema.test.ts +0 -234
  380. package/src/server/plugins/engine/views/components/service-banner/template.test.js +0 -43
  381. package/src/server/plugins/engine/views/components/tag-env/template.test.js +0 -28
  382. package/src/server/plugins/engine/views/partials/preview-banner.test.js +0 -122
  383. package/src/server/plugins/map/routes/get-os-token.test.js +0 -55
  384. package/src/server/plugins/map/service.test.js +0 -144
  385. package/src/server/plugins/nunjucks/context.test.js +0 -109
  386. package/src/server/plugins/nunjucks/enviroment.test.js +0 -207
  387. package/src/server/plugins/nunjucks/filters/answer.test.js +0 -92
  388. package/src/server/plugins/nunjucks/filters/field.test.js +0 -75
  389. package/src/server/plugins/nunjucks/filters/href.test.js +0 -80
  390. package/src/server/plugins/nunjucks/filters/merge.test.js +0 -15
  391. package/src/server/plugins/nunjucks/filters/page.test.js +0 -65
  392. package/src/server/plugins/payment/helper.test.js +0 -29
  393. package/src/server/plugins/payment/service.test.js +0 -218
  394. package/src/server/plugins/postcode-lookup/service.test.js +0 -177
  395. package/src/server/postcode-lookup.test.ts +0 -64
  396. package/src/server/routes/dummy-api.test.ts +0 -97
  397. package/src/server/services/cacheService.test.ts +0 -308
  398. package/src/server/services/httpService.test.js +0 -491
  399. package/src/server/utils/file-form-service.test.js +0 -127
  400. package/src/server/utils/notify.test.ts +0 -37
  401. package/src/server/utils/secure-context/get-trust-store-certs.test.js +0 -19
  402. package/src/server/utils/utils.test.js +0 -69
@@ -1,491 +0,0 @@
1
- import { getTraceId } from '@defra/hapi-tracing'
2
- import Boom from '@hapi/boom'
3
- import Wreck from '@hapi/wreck'
4
- import { StatusCodes } from 'http-status-codes'
5
-
6
- import {
7
- get,
8
- getJson,
9
- post,
10
- postJson,
11
- put
12
- } from '~/src/server/services/httpService.js'
13
-
14
- jest.mock('@defra/hapi-tracing')
15
-
16
- describe('HTTP service', () => {
17
- /** @type {RequestOptions} */
18
- let authOptions
19
- /** @type {RequestOptions} */
20
- let blankOptions
21
- /** @type {RequestOptions} */
22
- let timeoutOptions
23
-
24
- beforeEach(() => {
25
- authOptions = {
26
- headers: { Authorization: 'Bearer ey56yDSASDFfbgcbc' }
27
- }
28
- blankOptions = {}
29
- timeoutOptions = {
30
- timeout: 5000
31
- }
32
- })
33
-
34
- describe('GET', () => {
35
- beforeEach(() => {
36
- jest.spyOn(Wreck, 'get').mockResolvedValue({
37
- res: /** @type {IncomingMessage} */ ({
38
- statusCode: StatusCodes.OK
39
- }),
40
- payload: undefined
41
- })
42
- })
43
-
44
- it('passes headers', async () => {
45
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
46
- await expect(get('/test', blankOptions)).resolves.toEqual({
47
- res: { statusCode: StatusCodes.OK }
48
- })
49
-
50
- expect(Wreck.get).toHaveBeenCalledWith('/test', {
51
- headers: { 'x-cdp-request-id': 'my-trace-id' }
52
- })
53
- })
54
-
55
- it('passes additional headers', async () => {
56
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
57
- await expect(get('/test', authOptions)).resolves.toEqual({
58
- res: { statusCode: StatusCodes.OK }
59
- })
60
-
61
- expect(Wreck.get).toHaveBeenCalledWith('/test', {
62
- headers: {
63
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
64
- 'x-cdp-request-id': 'my-trace-id'
65
- }
66
- })
67
- })
68
-
69
- it('passes non headers options', async () => {
70
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
71
- await expect(get('/test', timeoutOptions)).resolves.toEqual({
72
- res: { statusCode: StatusCodes.OK }
73
- })
74
-
75
- expect(Wreck.get).toHaveBeenCalledWith('/test', {
76
- headers: {
77
- 'x-cdp-request-id': 'my-trace-id'
78
- },
79
- timeout: 5000
80
- })
81
- })
82
-
83
- it('sends request', async () => {
84
- await expect(get('/test', blankOptions)).resolves.toEqual({
85
- res: { statusCode: StatusCodes.OK }
86
- })
87
-
88
- expect(Wreck.get).toHaveBeenCalledWith('/test', {})
89
- })
90
-
91
- it('sends request as JSON', async () => {
92
- await expect(getJson('/test')).resolves.toEqual({
93
- res: { statusCode: StatusCodes.OK }
94
- })
95
-
96
- expect(Wreck.get).toHaveBeenCalledWith('/test', { json: true })
97
- })
98
- })
99
-
100
- describe('GET (with error)', () => {
101
- const error = Boom.notFound()
102
-
103
- beforeEach(() => {
104
- jest.spyOn(Wreck, 'get').mockResolvedValue({
105
- res: /** @type {IncomingMessage} */ ({
106
- statusCode: StatusCodes.NOT_FOUND
107
- }),
108
- payload: error
109
- })
110
- })
111
-
112
- it('passes headers', async () => {
113
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
114
- await expect(get('/error', blankOptions)).resolves.toEqual({
115
- res: { statusCode: StatusCodes.NOT_FOUND },
116
- error
117
- })
118
-
119
- expect(Wreck.get).toHaveBeenCalledWith('/error', {
120
- headers: { 'x-cdp-request-id': 'my-trace-id' }
121
- })
122
- })
123
-
124
- it('passes additional headers', async () => {
125
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
126
- await expect(get('/error', authOptions)).resolves.toEqual({
127
- res: { statusCode: StatusCodes.NOT_FOUND },
128
- error
129
- })
130
-
131
- expect(Wreck.get).toHaveBeenCalledWith('/error', {
132
- headers: {
133
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
134
- 'x-cdp-request-id': 'my-trace-id'
135
- }
136
- })
137
- })
138
-
139
- it('passes non headers options', async () => {
140
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
141
- await expect(get('/error', timeoutOptions)).resolves.toEqual({
142
- res: { statusCode: StatusCodes.NOT_FOUND },
143
- error
144
- })
145
-
146
- expect(Wreck.get).toHaveBeenCalledWith('/error', {
147
- headers: {
148
- 'x-cdp-request-id': 'my-trace-id'
149
- },
150
- timeout: 5000
151
- })
152
- })
153
-
154
- it('sends request (with error)', async () => {
155
- await expect(get('/error', blankOptions)).resolves.toEqual({
156
- res: { statusCode: StatusCodes.NOT_FOUND },
157
- error
158
- })
159
-
160
- expect(Wreck.get).toHaveBeenCalledWith('/error', {})
161
- })
162
-
163
- it('sends request as JSON (with error)', async () => {
164
- await expect(getJson('/error')).resolves.toEqual({
165
- res: { statusCode: StatusCodes.NOT_FOUND },
166
- error
167
- })
168
-
169
- expect(Wreck.get).toHaveBeenCalledWith('/error', { json: true })
170
- })
171
-
172
- it('sends request (unknown error)', async () => {
173
- jest.spyOn(Wreck, 'get').mockResolvedValue({
174
- res: /** @type {IncomingMessage} */ ({
175
- statusCode: StatusCodes.NOT_FOUND
176
- }),
177
- payload: undefined
178
- })
179
-
180
- await expect(get('/error', blankOptions)).resolves.toEqual({
181
- res: { statusCode: StatusCodes.NOT_FOUND },
182
- error: new Error('Unknown error')
183
- })
184
-
185
- expect(Wreck.get).toHaveBeenCalledWith('/error', {})
186
- })
187
- })
188
-
189
- describe('POST', () => {
190
- beforeEach(() => {
191
- jest.spyOn(Wreck, 'post').mockResolvedValue({
192
- res: /** @type {IncomingMessage} */ ({
193
- statusCode: StatusCodes.OK
194
- }),
195
- payload: { reference: '1234' }
196
- })
197
- })
198
-
199
- it('passes headers', async () => {
200
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
201
- await expect(post('/test', blankOptions)).resolves.toEqual({
202
- res: { statusCode: StatusCodes.OK },
203
- payload: { reference: '1234' }
204
- })
205
-
206
- expect(Wreck.post).toHaveBeenCalledWith('/test', {
207
- headers: { 'x-cdp-request-id': 'my-trace-id' }
208
- })
209
- })
210
-
211
- it('passes additonal headers', async () => {
212
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
213
- await expect(post('/test', authOptions)).resolves.toEqual({
214
- res: { statusCode: StatusCodes.OK },
215
- payload: { reference: '1234' }
216
- })
217
-
218
- expect(Wreck.post).toHaveBeenCalledWith('/test', {
219
- headers: {
220
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
221
- 'x-cdp-request-id': 'my-trace-id'
222
- }
223
- })
224
- })
225
-
226
- it('passes non headers options', async () => {
227
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
228
- await expect(post('/test', timeoutOptions)).resolves.toEqual({
229
- res: { statusCode: StatusCodes.OK },
230
- payload: { reference: '1234' }
231
- })
232
-
233
- expect(Wreck.post).toHaveBeenCalledWith('/test', {
234
- headers: {
235
- 'x-cdp-request-id': 'my-trace-id'
236
- },
237
- timeout: 5000
238
- })
239
- })
240
-
241
- it('sends request', async () => {
242
- await expect(post('/test', blankOptions)).resolves.toEqual({
243
- res: { statusCode: StatusCodes.OK },
244
- payload: { reference: '1234' }
245
- })
246
-
247
- expect(Wreck.post).toHaveBeenCalledWith('/test', {})
248
- })
249
-
250
- it('sends request as JSON', async () => {
251
- await expect(postJson('/test', blankOptions)).resolves.toEqual({
252
- res: { statusCode: StatusCodes.OK },
253
- payload: { reference: '1234' }
254
- })
255
-
256
- expect(Wreck.post).toHaveBeenCalledWith('/test', { json: true })
257
- })
258
- })
259
-
260
- describe('POST (with error)', () => {
261
- const error = Boom.notFound()
262
-
263
- beforeEach(() => {
264
- jest.spyOn(Wreck, 'post').mockResolvedValue({
265
- res: /** @type {IncomingMessage} */ ({
266
- statusCode: StatusCodes.NOT_FOUND
267
- }),
268
- payload: error
269
- })
270
- })
271
-
272
- it('passes headers', async () => {
273
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
274
- await expect(post('/error', blankOptions)).resolves.toEqual({
275
- res: { statusCode: StatusCodes.NOT_FOUND },
276
- error
277
- })
278
-
279
- expect(Wreck.post).toHaveBeenCalledWith('/error', {
280
- headers: { 'x-cdp-request-id': 'my-trace-id' }
281
- })
282
- })
283
-
284
- it('passes additional headers', async () => {
285
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
286
- await expect(post('/error', authOptions)).resolves.toEqual({
287
- res: { statusCode: StatusCodes.NOT_FOUND },
288
- error
289
- })
290
-
291
- expect(Wreck.post).toHaveBeenCalledWith('/error', {
292
- headers: {
293
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
294
- 'x-cdp-request-id': 'my-trace-id'
295
- }
296
- })
297
- })
298
-
299
- it('passes non headers options', async () => {
300
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
301
- await expect(post('/error', timeoutOptions)).resolves.toEqual({
302
- res: { statusCode: StatusCodes.NOT_FOUND },
303
- error
304
- })
305
-
306
- expect(Wreck.post).toHaveBeenCalledWith('/error', {
307
- headers: {
308
- 'x-cdp-request-id': 'my-trace-id'
309
- },
310
- timeout: 5000
311
- })
312
- })
313
-
314
- it('sends request (with error)', async () => {
315
- await expect(post('/error', blankOptions)).resolves.toEqual({
316
- res: { statusCode: StatusCodes.NOT_FOUND },
317
- error
318
- })
319
-
320
- expect(Wreck.post).toHaveBeenCalledWith('/error', {})
321
- })
322
-
323
- it('sends request as JSON (with error)', async () => {
324
- await expect(postJson('/error', blankOptions)).resolves.toEqual({
325
- res: { statusCode: StatusCodes.NOT_FOUND },
326
- error
327
- })
328
-
329
- expect(Wreck.post).toHaveBeenCalledWith('/error', { json: true })
330
- })
331
-
332
- it('sends request (unknown error)', async () => {
333
- jest.spyOn(Wreck, 'post').mockResolvedValue({
334
- res: /** @type {IncomingMessage} */ ({
335
- statusCode: StatusCodes.NOT_FOUND
336
- }),
337
- payload: undefined
338
- })
339
-
340
- await expect(post('/error', blankOptions)).resolves.toEqual({
341
- res: { statusCode: StatusCodes.NOT_FOUND },
342
- error: new Error('Unknown error')
343
- })
344
-
345
- expect(Wreck.post).toHaveBeenCalledWith('/error', {})
346
- })
347
- })
348
-
349
- describe('PUT', () => {
350
- beforeEach(() => {
351
- jest.spyOn(Wreck, 'put').mockResolvedValue({
352
- res: /** @type {IncomingMessage} */ ({
353
- statusCode: StatusCodes.OK
354
- }),
355
- payload: undefined
356
- })
357
- })
358
-
359
- it('passes headers', async () => {
360
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
361
- await expect(put('/test', blankOptions)).resolves.toEqual({
362
- res: { statusCode: StatusCodes.OK }
363
- })
364
-
365
- expect(Wreck.put).toHaveBeenCalledWith('/test', {
366
- headers: { 'x-cdp-request-id': 'my-trace-id' }
367
- })
368
- })
369
-
370
- it('passes additional headers', async () => {
371
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
372
- await expect(put('/test', authOptions)).resolves.toEqual({
373
- res: { statusCode: StatusCodes.OK }
374
- })
375
-
376
- expect(Wreck.put).toHaveBeenCalledWith('/test', {
377
- headers: {
378
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
379
- 'x-cdp-request-id': 'my-trace-id'
380
- }
381
- })
382
- })
383
-
384
- it('passes non headers options', async () => {
385
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
386
- await expect(put('/test', timeoutOptions)).resolves.toEqual({
387
- res: { statusCode: StatusCodes.OK }
388
- })
389
-
390
- expect(Wreck.put).toHaveBeenCalledWith('/test', {
391
- headers: {
392
- 'x-cdp-request-id': 'my-trace-id'
393
- },
394
- timeout: 5000
395
- })
396
- })
397
-
398
- it('sends request', async () => {
399
- await expect(put('/test', blankOptions)).resolves.toEqual({
400
- res: { statusCode: StatusCodes.OK }
401
- })
402
-
403
- expect(Wreck.put).toHaveBeenCalledWith('/test', {})
404
- })
405
- })
406
-
407
- describe('PUT (with error)', () => {
408
- const error = Boom.notFound()
409
-
410
- beforeEach(() => {
411
- jest.spyOn(Wreck, 'put').mockResolvedValue({
412
- res: /** @type {IncomingMessage} */ ({
413
- statusCode: StatusCodes.NOT_FOUND
414
- }),
415
- payload: error
416
- })
417
- })
418
-
419
- it('passes headers', async () => {
420
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
421
- await expect(put('/error', blankOptions)).resolves.toEqual({
422
- res: { statusCode: StatusCodes.NOT_FOUND },
423
- error
424
- })
425
-
426
- expect(Wreck.put).toHaveBeenCalledWith('/error', {
427
- headers: { 'x-cdp-request-id': 'my-trace-id' }
428
- })
429
- })
430
-
431
- it('passes additional headers', async () => {
432
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
433
- await expect(put('/error', authOptions)).resolves.toEqual({
434
- res: { statusCode: StatusCodes.NOT_FOUND },
435
- error
436
- })
437
-
438
- expect(Wreck.put).toHaveBeenCalledWith('/error', {
439
- headers: {
440
- Authorization: 'Bearer ey56yDSASDFfbgcbc',
441
- 'x-cdp-request-id': 'my-trace-id'
442
- }
443
- })
444
- })
445
-
446
- it('passes non headers options', async () => {
447
- jest.mocked(getTraceId).mockReturnValue('my-trace-id')
448
- await expect(put('/error', timeoutOptions)).resolves.toEqual({
449
- res: { statusCode: StatusCodes.NOT_FOUND },
450
- error
451
- })
452
-
453
- expect(Wreck.put).toHaveBeenCalledWith('/error', {
454
- headers: {
455
- 'x-cdp-request-id': 'my-trace-id'
456
- },
457
- timeout: 5000
458
- })
459
- })
460
-
461
- it('sends request (with error)', async () => {
462
- await expect(put('/error', blankOptions)).resolves.toEqual({
463
- res: { statusCode: StatusCodes.NOT_FOUND },
464
- error
465
- })
466
-
467
- expect(Wreck.put).toHaveBeenCalledWith('/error', {})
468
- })
469
-
470
- it('sends request (unknown error)', async () => {
471
- jest.spyOn(Wreck, 'put').mockResolvedValue({
472
- res: /** @type {IncomingMessage} */ ({
473
- statusCode: StatusCodes.NOT_FOUND
474
- }),
475
- payload: undefined
476
- })
477
-
478
- await expect(put('/error', blankOptions)).resolves.toEqual({
479
- res: { statusCode: StatusCodes.NOT_FOUND },
480
- error: new Error('Unknown error')
481
- })
482
-
483
- expect(Wreck.put).toHaveBeenCalledWith('/error', {})
484
- })
485
- })
486
- })
487
-
488
- /**
489
- * @import { IncomingMessage } from 'node:http'
490
- * @import { RequestOptions } from '~/src/server/services/httpService.js'
491
- */
@@ -1,127 +0,0 @@
1
- import { join } from 'node:path'
2
-
3
- import { FormStatus } from '~/src/server/routes/types.js'
4
- import { FileFormService } from '~/src/server/utils/file-form-service.js'
5
-
6
- describe('File-form-service', () => {
7
- /** @type {FileFormService} */
8
- let service
9
- beforeEach(async () => {
10
- const now = new Date()
11
- const user = { id: 'user', displayName: 'Username' }
12
- const author = {
13
- createdAt: now,
14
- createdBy: user,
15
- updatedAt: now,
16
- updatedBy: user
17
- }
18
- service = new FileFormService()
19
- const metadata = {
20
- organisation: 'Defra',
21
- teamName: 'Team name',
22
- teamEmail: 'team@defra.gov.uk',
23
- submissionGuidance: "Thanks for your submission, we'll be in touch",
24
- notificationEmail: 'email@domain.com',
25
- ...author,
26
- live: author
27
- }
28
- await service.addForm(
29
- `${join(import.meta.dirname, '../../../test/form/definitions')}/components.json`,
30
- {
31
- ...metadata,
32
- id: '95e92559-968d-44ae-8666-2b1ad3dffd31',
33
- title: 'Form test',
34
- slug: 'form-test'
35
- }
36
- )
37
- })
38
-
39
- describe('metadata by slug', () => {
40
- it('should get form metadata by slug', () => {
41
- const meta = service.getFormMetadata('form-test')
42
- expect(meta.id).toBe('95e92559-968d-44ae-8666-2b1ad3dffd31')
43
- expect(meta.title).toBe('Form test')
44
- })
45
-
46
- it('should throw if not found', () => {
47
- expect(() => service.getFormMetadata('form-test-missing')).toThrow(
48
- "Form metadata 'form-test-missing' not found"
49
- )
50
- })
51
- })
52
-
53
- describe('metadata by id', () => {
54
- it('should get form metadata by id', () => {
55
- const meta = service.getFormMetadataById(
56
- '95e92559-968d-44ae-8666-2b1ad3dffd31'
57
- )
58
- expect(meta.id).toBe('95e92559-968d-44ae-8666-2b1ad3dffd31')
59
- expect(meta.title).toBe('Form test')
60
- })
61
-
62
- it('should throw if not found', () => {
63
- expect(() => service.getFormMetadataById('id-missing')).toThrow(
64
- "Form metadata id 'id-missing' not found"
65
- )
66
- })
67
- })
68
-
69
- describe('definition by id', () => {
70
- it('should get form definition by id', () => {
71
- const form = service.getFormDefinition(
72
- '95e92559-968d-44ae-8666-2b1ad3dffd31'
73
- )
74
- expect(form.name).toBe('All components')
75
- expect(form.startPage).toBe('/all-components')
76
- })
77
-
78
- it('should throw if not found', () => {
79
- expect(() => service.getFormDefinition('id-missing')).toThrow(
80
- "Form definition 'id-missing' not found"
81
- )
82
- })
83
- })
84
-
85
- describe('toFormsService', () => {
86
- it('should create interface', async () => {
87
- const interfaceImpl = service.toFormsService()
88
- const res1 = await interfaceImpl.getFormMetadata('form-test')
89
- expect(res1.id).toBe('95e92559-968d-44ae-8666-2b1ad3dffd31')
90
- expect(res1.title).toBe('Form test')
91
-
92
- const res2 = await interfaceImpl.getFormMetadataById(
93
- '95e92559-968d-44ae-8666-2b1ad3dffd31'
94
- )
95
- expect(res2.id).toBe('95e92559-968d-44ae-8666-2b1ad3dffd31')
96
- expect(res2.title).toBe('Form test')
97
-
98
- const res3 = await interfaceImpl.getFormDefinition(
99
- '95e92559-968d-44ae-8666-2b1ad3dffd31',
100
- FormStatus.Draft
101
- )
102
- expect(res3?.name).toBe('All components')
103
- expect(res3?.startPage).toBe('/all-components')
104
-
105
- const res4 = await interfaceImpl.getFormSecret(
106
- '95e92559-968d-44ae-8666-2b1ad3dffd31',
107
- 'my-secret-name'
108
- )
109
- expect(res4).toBe('test-api-key')
110
-
111
- delete process.env.PAYMENT_PROVIDER_API_KEY_TEST
112
- const res5 = await interfaceImpl.getFormSecret(
113
- '95e92559-968d-44ae-8666-2b1ad3dffd31',
114
- 'my-secret-name'
115
- )
116
- expect(res5).toBe('')
117
- })
118
- })
119
-
120
- describe('readForm', () => {
121
- it('should throw if invalid extension', async () => {
122
- await expect(
123
- service.readForm('/some-folder/some-file.bad')
124
- ).rejects.toThrow("Invalid file extension '.bad'")
125
- })
126
- })
127
- })
@@ -1,37 +0,0 @@
1
- import { postJson } from '~/src/server/services/httpService.js'
2
- import { sendNotification } from '~/src/server/utils/notify.js'
3
-
4
- jest.mock('~/src/server/services/httpService')
5
-
6
- describe('Utils: Notify', () => {
7
- const templateId = 'example-template-id'
8
- const emailAddress = 'enrique.chase@defra.gov.uk'
9
- const personalisation = {
10
- subject: 'Hello',
11
- body: 'World'
12
- }
13
-
14
- describe('sendNotification', () => {
15
- it('calls postJson with personalised email payload', async () => {
16
- await sendNotification({
17
- templateId,
18
- emailAddress,
19
- personalisation
20
- })
21
-
22
- expect(postJson).toHaveBeenCalledWith(
23
- 'https://api.notifications.service.gov.uk/v2/notifications/email',
24
- {
25
- payload: {
26
- template_id: templateId,
27
- email_address: emailAddress,
28
- personalisation
29
- },
30
- headers: {
31
- Authorization: expect.stringMatching(/^Bearer /)
32
- }
33
- }
34
- )
35
- })
36
- })
37
- })
@@ -1,19 +0,0 @@
1
- import { getTrustStoreCerts } from '~/src/server/utils/secure-context/get-trust-store-certs.js'
2
-
3
- describe('#getTrustStoreCerts', () => {
4
- const mockProcessEnvWithCerts = {
5
- TRUSTSTORE_CA_ONE:
6
- 'LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCm1vY2stY2VydC1kb3JpcwotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg==',
7
- UNRELATED_ENV: 'not-a-cert'
8
- }
9
-
10
- test('Should provide expected result with "certs"', () => {
11
- expect(getTrustStoreCerts(mockProcessEnvWithCerts)).toEqual([
12
- '-----BEGIN CERTIFICATE-----\nmock-cert-doris\n-----END CERTIFICATE-----'
13
- ])
14
- })
15
-
16
- test('Should provide expected empty array', () => {
17
- expect(getTrustStoreCerts({})).toEqual([])
18
- })
19
- })