@defra/forms-engine-plugin 4.7.2-alpha → 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,92 +0,0 @@
1
- import { getAnswer } from '~/src/server/plugins/engine/components/helpers/components.js'
2
- import { answer } from '~/src/server/plugins/nunjucks/filters/answer.js'
3
-
4
- jest.mock(
5
- '~/src/server/plugins/engine/components/helpers/components.ts',
6
- () => ({
7
- getAnswer: jest.fn()
8
- })
9
- )
10
-
11
- describe('answer Nunjucks filter', () => {
12
- /** @type { NunjucksContext } */
13
- let mockThis
14
-
15
- beforeEach(() => {
16
- jest.clearAllMocks()
17
-
18
- mockThis = /** @type {NunjucksContext} */ (
19
- /** @type {unknown} */ ({
20
- ctx: {
21
- context: {
22
- componentMap: new Map(),
23
- relevantState: { someState: 'value' }
24
- }
25
- }
26
- })
27
- )
28
-
29
- jest.mocked(getAnswer).mockReturnValue('test answer')
30
- })
31
-
32
- describe('missing context', () => {
33
- it('returns undefined', () => {
34
- mockThis.ctx.context = undefined
35
-
36
- const result = answer.call(mockThis, 'componentName')
37
-
38
- expect(result).toBeUndefined()
39
- expect(getAnswer).not.toHaveBeenCalled()
40
- })
41
- })
42
-
43
- describe('component lookup', () => {
44
- it('returns undefined for non-existent component', () => {
45
- const result = answer.call(mockThis, 'nonExistentComponent')
46
-
47
- expect(result).toBeUndefined()
48
- expect(getAnswer).not.toHaveBeenCalled()
49
- })
50
- })
51
-
52
- describe('non-form component', () => {
53
- it('returns undefined', () => {
54
- mockThis.ctx.context?.componentMap.set(
55
- 'nonFormComponent',
56
- // @ts-expect-error - simplified mock component for testing
57
- { isFormComponent: false }
58
- )
59
-
60
- const result = answer.call(mockThis, 'nonFormComponent')
61
-
62
- expect(result).toBeUndefined()
63
- expect(getAnswer).not.toHaveBeenCalled()
64
- })
65
- })
66
-
67
- describe('valid form component', () => {
68
- it('returns the answer', () => {
69
- const mockFormComponent = {
70
- isFormComponent: true,
71
- someProperty: 'value'
72
- }
73
- mockThis.ctx.context?.componentMap.set(
74
- 'validFormComponent',
75
- // @ts-expect-error - simplified mock component for testing
76
- mockFormComponent
77
- )
78
-
79
- const result = answer.call(mockThis, 'validFormComponent')
80
-
81
- expect(getAnswer).toHaveBeenCalledWith(
82
- mockFormComponent,
83
- mockThis.ctx.context?.relevantState
84
- )
85
- expect(result).toBe('test answer')
86
- })
87
- })
88
- })
89
-
90
- /**
91
- * @import { NunjucksContext } from '~/src/server/plugins/nunjucks/types.js'
92
- */
@@ -1,75 +0,0 @@
1
- import { field } from '~/src/server/plugins/nunjucks/filters/field.js'
2
-
3
- describe('field Nunjucks filter', () => {
4
- /** @type {NunjucksContext} */
5
- let mockThis
6
-
7
- beforeEach(() => {
8
- mockThis = /** @type {NunjucksContext} */ (
9
- /** @type {unknown} */ ({
10
- ctx: {
11
- context: {
12
- componentMap: new Map()
13
- }
14
- }
15
- })
16
- )
17
- })
18
-
19
- describe('invalid inputs', () => {
20
- it('returns undefined for non-string name parameter', () => {
21
- // @ts-expect-error - testing invalid input
22
- const result = field.call(mockThis, 123)
23
- expect(result).toBeUndefined()
24
- })
25
- })
26
-
27
- describe('missing context', () => {
28
- it('returns undefined', () => {
29
- mockThis.ctx.context = undefined
30
- const result = field.call(mockThis, 'componentName')
31
- expect(result).toBeUndefined()
32
- })
33
- })
34
-
35
- describe('component lookup', () => {
36
- it('returns undefined for non-existent component', () => {
37
- const result = field.call(mockThis, 'nonExistentComponent')
38
- expect(result).toBeUndefined()
39
- })
40
- })
41
-
42
- describe('non-form component', () => {
43
- it('returns undefined', () => {
44
- mockThis.ctx.context?.componentMap.set(
45
- 'nonFormComponent',
46
- // @ts-expect-error - simplified mock component for testing
47
- { isFormComponent: false }
48
- )
49
-
50
- const result = field.call(mockThis, 'nonFormComponent')
51
- expect(result).toBeUndefined()
52
- })
53
- })
54
-
55
- describe('valid form component', () => {
56
- it('returns the component', () => {
57
- const mockFormComponent = {
58
- isFormComponent: true,
59
- someProperty: 'value'
60
- }
61
- mockThis.ctx.context?.componentMap.set(
62
- 'validFormComponent',
63
- // @ts-expect-error - simplified mock component for testing
64
- mockFormComponent
65
- )
66
-
67
- const result = field.call(mockThis, 'validFormComponent')
68
- expect(result).toBe(mockFormComponent)
69
- })
70
- })
71
- })
72
-
73
- /**
74
- * @import { NunjucksContext } from '~/src/server/plugins/nunjucks/types.js'
75
- */
@@ -1,80 +0,0 @@
1
- import { getPageHref } from '~/src/server/plugins/engine/index.js'
2
- import { href } from '~/src/server/plugins/nunjucks/filters/href.js'
3
-
4
- jest.mock('~/src/server/plugins/engine/index.ts', () => ({
5
- getPageHref: jest.fn()
6
- }))
7
-
8
- describe('href Nunjucks filter', () => {
9
- /** @type { NunjucksContext } */
10
- let mockThis
11
-
12
- beforeEach(() => {
13
- jest.clearAllMocks()
14
-
15
- mockThis = /** @type {NunjucksContext} */ (
16
- /** @type {unknown} */ ({
17
- ctx: {
18
- context: {
19
- pageMap: new Map()
20
- }
21
- }
22
- })
23
- )
24
-
25
- jest.mocked(getPageHref).mockReturnValue('/some-page')
26
- })
27
-
28
- describe('invalid inputs', () => {
29
- it('returns undefined for non-string path parameter', () => {
30
- // @ts-expect-error - testing invalid input
31
- const result = href.call(mockThis, 123)
32
-
33
- expect(result).toBeUndefined()
34
- expect(getPageHref).not.toHaveBeenCalled()
35
- })
36
- })
37
-
38
- describe('missing context', () => {
39
- it('returns undefined', () => {
40
- mockThis.ctx.context = undefined
41
-
42
- const result = href.call(mockThis, 'pagePath')
43
-
44
- expect(result).toBeUndefined()
45
- expect(getPageHref).not.toHaveBeenCalled()
46
- })
47
- })
48
-
49
- describe('page lookup', () => {
50
- it('returns undefined for non-existent page', () => {
51
- const result = href.call(mockThis, 'nonExistentPage')
52
-
53
- expect(result).toBeUndefined()
54
- expect(getPageHref).not.toHaveBeenCalled()
55
- })
56
- })
57
-
58
- describe('valid page', () => {
59
- it('returns the href for the page', () => {
60
- const mockPage = {
61
- path: '/some-page',
62
- someProperty: 'value'
63
- }
64
- mockThis.ctx.context?.pageMap.set(
65
- 'validPage',
66
- // @ts-expect-error - simplified mock page for testing
67
- mockPage
68
- )
69
-
70
- const result = href.call(mockThis, 'validPage')
71
-
72
- expect(getPageHref).toHaveBeenCalledWith(mockPage)
73
- expect(result).toBe('/some-page')
74
- })
75
- })
76
- })
77
-
78
- /**
79
- * @import { NunjucksContext } from '~/src/server/plugins/nunjucks/types.js'
80
- */
@@ -1,15 +0,0 @@
1
- import { merge } from '~/src/server/plugins/nunjucks/filters/merge.js'
2
-
3
- describe('merge', () => {
4
- const propertyToMerge = { lorem: 'ipsum' }
5
- it('should return the target if source is not an object', () => {
6
- expect(merge(propertyToMerge, 'dolar')).toBe(propertyToMerge)
7
- })
8
-
9
- it('should merge the properties if they are valid', () => {
10
- expect(merge({ lorem: 'dolar', dolar: 'sit' }, propertyToMerge)).toEqual({
11
- lorem: 'ipsum',
12
- dolar: 'sit'
13
- })
14
- })
15
- })
@@ -1,65 +0,0 @@
1
- import { page } from '~/src/server/plugins/nunjucks/filters/page.js'
2
-
3
- describe('page Nunjucks filter', () => {
4
- /** @type { NunjucksContext } */
5
- let mockThis
6
-
7
- beforeEach(() => {
8
- mockThis = /** @type {NunjucksContext} */ (
9
- /** @type {unknown} */ ({
10
- ctx: {
11
- context: {
12
- pageMap: new Map()
13
- }
14
- }
15
- })
16
- )
17
- })
18
-
19
- describe('invalid inputs', () => {
20
- it('returns undefined for non-string path parameter', () => {
21
- // @ts-expect-error - testing invalid input
22
- const result = page.call(mockThis, 123)
23
-
24
- expect(result).toBeUndefined()
25
- })
26
- })
27
-
28
- describe('missing context', () => {
29
- it('returns undefined', () => {
30
- mockThis.ctx.context = undefined
31
-
32
- const result = page.call(mockThis, 'pagePath')
33
-
34
- expect(result).toBeUndefined()
35
- })
36
- })
37
-
38
- describe('page lookup', () => {
39
- it('returns undefined for non-existent page', () => {
40
- const result = page.call(mockThis, 'nonExistentPage')
41
-
42
- expect(result).toBeUndefined()
43
- })
44
-
45
- it('returns the page when found', () => {
46
- const mockPage = {
47
- path: '/some-page',
48
- someProperty: 'value'
49
- }
50
- mockThis.ctx.context?.pageMap.set(
51
- 'validPage',
52
- // @ts-expect-error - simplified mock page for testing
53
- mockPage
54
- )
55
-
56
- const result = page.call(mockThis, 'validPage')
57
-
58
- expect(result).toBe(mockPage)
59
- })
60
- })
61
- })
62
-
63
- /**
64
- * @import { NunjucksContext } from '~/src/server/plugins/nunjucks/types.js'
65
- */
@@ -1,29 +0,0 @@
1
- import {
2
- formatCurrency,
3
- formatPaymentDate
4
- } from '~/src/server/plugins/payment/helper.js'
5
-
6
- describe('formatPaymentDate', () => {
7
- it('should format ISO date string to en-GB format', () => {
8
- const result = formatPaymentDate('2025-11-10T17:01:29.000Z')
9
- expect(result).toBe('10 November 2025 5:01pm')
10
- })
11
- })
12
-
13
- describe('formatCurrency', () => {
14
- it('should format whole number with currency symbol', () => {
15
- expect(formatCurrency(10)).toBe('£10.00')
16
- })
17
-
18
- it('should format decimal amount with currency symbol', () => {
19
- expect(formatCurrency(99.5)).toBe('£99.50')
20
- })
21
-
22
- it('should format large amounts with thousand separators', () => {
23
- expect(formatCurrency(1234.56)).toBe('£1,234.56')
24
- })
25
-
26
- it('should format very large amounts with thousand separators', () => {
27
- expect(formatCurrency(20000)).toBe('£20,000.00')
28
- })
29
- })
@@ -1,218 +0,0 @@
1
- import { PaymentService } from '~/src/server/plugins/payment/service.js'
2
- import { get, post, postJson } from '~/src/server/services/httpService.js'
3
-
4
- jest.mock('~/src/server/services/httpService.ts')
5
-
6
- describe('payment service', () => {
7
- const service = new PaymentService('my-api-key')
8
- describe('constructor', () => {
9
- it('should create instance', () => {
10
- expect(service).toBeDefined()
11
- })
12
- })
13
-
14
- describe('createPayment', () => {
15
- it('should create a payment', async () => {
16
- const createPaymentResult = {
17
- payment_id: 'payment-id-12345',
18
- _links: {
19
- next_url: {
20
- href: 'http://next-url-href/payment'
21
- }
22
- },
23
- state: {
24
- status: 'created'
25
- }
26
- }
27
- jest.mocked(postJson).mockResolvedValueOnce({
28
- res: /** @type {IncomingMessage} */ ({
29
- statusCode: 200,
30
- headers: {}
31
- }),
32
- payload: createPaymentResult,
33
- error: undefined
34
- })
35
-
36
- const referenceNumber = 'ABC-DEF-123'
37
- const returnUrl = 'http://localhost:3009/payment-callback-handler'
38
- const metadata = { formId: 'form-id', slug: 'my-form-slug' }
39
- const payment = await service.createPayment(
40
- 100,
41
- 'Payment description',
42
- returnUrl,
43
- referenceNumber,
44
- false,
45
- metadata
46
- )
47
- expect(payment?.paymentId).toBe('payment-id-12345')
48
- expect(payment?.paymentUrl).toBe('http://next-url-href/payment')
49
- })
50
-
51
- it('should return undefined if fails to create a payment - failed API call', async () => {
52
- jest
53
- .mocked(postJson)
54
- .mockRejectedValueOnce(new Error('internal creation error'))
55
-
56
- const referenceNumber = 'ABC-DEF-123'
57
- const returnUrl = 'http://localhost:3009/payment-callback-handler'
58
- const metadata = { formId: 'form-id', slug: 'my-form-slug' }
59
- const res = await service.createPayment(
60
- 100,
61
- 'Payment description',
62
- returnUrl,
63
- referenceNumber,
64
- false,
65
- metadata
66
- )
67
- expect(res).toBeUndefined()
68
- })
69
-
70
- it('should return undefined if fails to create a payment - bad result from API call', async () => {
71
- const createPaymentResult = {
72
- state: {
73
- status: 'failed'
74
- }
75
- }
76
- jest.mocked(postJson).mockResolvedValueOnce({
77
- res: /** @type {IncomingMessage} */ ({
78
- statusCode: 200,
79
- headers: {}
80
- }),
81
- payload: createPaymentResult,
82
- error: undefined
83
- })
84
-
85
- const referenceNumber = 'ABC-DEF-123'
86
- const returnUrl = 'http://localhost:3009/payment-callback-handler'
87
- const metadata = { formId: 'form-id', slug: 'my-form-slug' }
88
- const res = await service.createPayment(
89
- 100,
90
- 'Payment description',
91
- returnUrl,
92
- referenceNumber,
93
- false,
94
- metadata
95
- )
96
- expect(res).toBeUndefined()
97
- })
98
- })
99
-
100
- describe('getPaymentStatus', () => {
101
- it('should get payment status if exists', async () => {
102
- const getPaymentStatusResult = {
103
- payment_id: 'payment-id-12345',
104
- _links: {
105
- next_url: {
106
- href: 'http://next-url-href/payment'
107
- }
108
- },
109
- state: {
110
- status: 'created'
111
- }
112
- }
113
-
114
- jest.mocked(get).mockResolvedValueOnce({
115
- res: /** @type {IncomingMessage} */ ({
116
- statusCode: 200,
117
- headers: {}
118
- }),
119
- payload: getPaymentStatusResult,
120
- error: undefined
121
- })
122
-
123
- const paymentStatus = await service.getPaymentStatus(
124
- 'payment-id-12345',
125
- false
126
- )
127
- expect(paymentStatus.paymentId).toBe('payment-id-12345')
128
- expect(paymentStatus._links.next_url?.href).toBe(
129
- 'http://next-url-href/payment'
130
- )
131
- })
132
-
133
- it('should handle payment status error', async () => {
134
- jest.mocked(get).mockResolvedValueOnce({
135
- res: /** @type {IncomingMessage} */ ({
136
- statusCode: 200,
137
- headers: {}
138
- }),
139
- payload: undefined,
140
- error: new Error('some-error')
141
- })
142
-
143
- await expect(() =>
144
- service.getPaymentStatus('payment-id-12345', false)
145
- ).rejects.toThrow('Failed to get payment status: some-error')
146
- })
147
- })
148
-
149
- describe('capturePayment', () => {
150
- it('should return true when successful capture with statusCode 200', async () => {
151
- const capturePaymentResult = {}
152
- jest.mocked(post).mockResolvedValueOnce({
153
- res: /** @type {IncomingMessage} */ ({
154
- statusCode: 200,
155
- headers: {}
156
- }),
157
- payload: capturePaymentResult,
158
- error: undefined
159
- })
160
-
161
- const captureResult = await service.capturePayment(
162
- 'payment-id-12345',
163
- 100
164
- )
165
- expect(captureResult).toBe(true)
166
- })
167
-
168
- it('should return true when successful capture with statusCode 204', async () => {
169
- const capturePaymentResult = {}
170
- jest.mocked(post).mockResolvedValueOnce({
171
- res: /** @type {IncomingMessage} */ ({
172
- statusCode: 204,
173
- headers: {}
174
- }),
175
- payload: capturePaymentResult,
176
- error: undefined
177
- })
178
-
179
- const captureResult = await service.capturePayment(
180
- 'payment-id-12345',
181
- 100
182
- )
183
- expect(captureResult).toBe(true)
184
- })
185
-
186
- it('should return false when status code not 200 or 204', async () => {
187
- const capturePaymentResult = {}
188
- jest.mocked(post).mockResolvedValueOnce({
189
- res: /** @type {IncomingMessage} */ ({
190
- statusCode: 500,
191
- headers: {}
192
- }),
193
- payload: capturePaymentResult,
194
- error: undefined
195
- })
196
-
197
- const captureResult = await service.capturePayment(
198
- 'payment-id-12345',
199
- 100
200
- )
201
- expect(captureResult).toBe(false)
202
- })
203
-
204
- it('should throw when internal error', async () => {
205
- jest
206
- .mocked(post)
207
- .mockRejectedValueOnce(new Error('internal capture error'))
208
-
209
- await expect(() =>
210
- service.capturePayment('payment-id-12345', 100)
211
- ).rejects.toThrow('internal capture error')
212
- })
213
- })
214
- })
215
-
216
- /**
217
- * @import { IncomingMessage } from 'node:http'
218
- */