@natlibfi/marc-record-validators-melinda 11.6.7 → 12.0.0-alpha.12

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 (563) hide show
  1. package/.github/workflows/{melinda-node-tests.yml → melinda-node-tests-and-publish.yml} +37 -12
  2. package/dist/access-rights.js +63 -91
  3. package/dist/access-rights.js.map +7 -1
  4. package/dist/access-rights.test.js +137 -0
  5. package/dist/access-rights.test.js.map +7 -0
  6. package/dist/addMissingField041.js +21 -53
  7. package/dist/addMissingField041.js.map +7 -1
  8. package/dist/addMissingField041.test.js +39 -0
  9. package/dist/addMissingField041.test.js.map +7 -0
  10. package/dist/addMissingField336.js +99 -191
  11. package/dist/addMissingField336.js.map +7 -1
  12. package/dist/addMissingField336.test.js +39 -0
  13. package/dist/addMissingField336.test.js.map +7 -0
  14. package/dist/addMissingField337.js +63 -132
  15. package/dist/addMissingField337.js.map +7 -1
  16. package/dist/addMissingField337.test.js +39 -0
  17. package/dist/addMissingField337.test.js.map +7 -0
  18. package/dist/addMissingField338.js +147 -253
  19. package/dist/addMissingField338.js.map +7 -1
  20. package/dist/addMissingField338.test.js +39 -0
  21. package/dist/addMissingField338.test.js.map +7 -0
  22. package/dist/cyrillux-usemarcon-replacement.js +119 -272
  23. package/dist/cyrillux-usemarcon-replacement.js.map +7 -1
  24. package/dist/cyrillux-usemarcon-replacement.test.js +43 -0
  25. package/dist/cyrillux-usemarcon-replacement.test.js.map +7 -0
  26. package/dist/cyrillux.js +119 -223
  27. package/dist/cyrillux.js.map +7 -1
  28. package/dist/cyrillux.test.js +39 -0
  29. package/dist/cyrillux.test.js.map +7 -0
  30. package/dist/disambiguateSeriesStatements.js +40 -81
  31. package/dist/disambiguateSeriesStatements.js.map +7 -1
  32. package/dist/disambiguateSeriesStatements.test.js +44 -0
  33. package/dist/disambiguateSeriesStatements.test.js.map +7 -0
  34. package/dist/double-commas.js +7 -14
  35. package/dist/double-commas.js.map +7 -1
  36. package/dist/double-commas.test.js +48 -0
  37. package/dist/double-commas.test.js.map +7 -0
  38. package/dist/duplicates-ind1.js +10 -31
  39. package/dist/duplicates-ind1.js.map +7 -1
  40. package/dist/duplicates-ind1.test.js +40 -0
  41. package/dist/duplicates-ind1.test.js.map +7 -0
  42. package/dist/empty-fields.js +10 -22
  43. package/dist/empty-fields.js.map +7 -1
  44. package/dist/empty-fields.test.js +129 -0
  45. package/dist/empty-fields.test.js.map +7 -0
  46. package/dist/ending-punctuation-conf.js +873 -769
  47. package/dist/ending-punctuation-conf.js.map +7 -1
  48. package/dist/ending-punctuation.js +156 -169
  49. package/dist/ending-punctuation.js.map +7 -1
  50. package/dist/ending-punctuation.test.js +2385 -0
  51. package/dist/ending-punctuation.test.js.map +7 -0
  52. package/dist/ending-whitespace.js +10 -35
  53. package/dist/ending-whitespace.js.map +7 -1
  54. package/dist/ending-whitespace.test.js +38 -0
  55. package/dist/ending-whitespace.test.js.map +7 -0
  56. package/dist/field-008-18-34-character-groups.js +40 -125
  57. package/dist/field-008-18-34-character-groups.js.map +7 -1
  58. package/dist/field-008-18-34-character-groups.test.js +45 -0
  59. package/dist/field-008-18-34-character-groups.test.js.map +7 -0
  60. package/dist/field-505-separators.js +19 -39
  61. package/dist/field-505-separators.js.map +7 -1
  62. package/dist/field-505-separators.test.js +45 -0
  63. package/dist/field-505-separators.test.js.map +7 -0
  64. package/dist/field-521-fix.js +19 -47
  65. package/dist/field-521-fix.js.map +7 -1
  66. package/dist/field-521-fix.test.js +44 -0
  67. package/dist/field-521-fix.test.js.map +7 -0
  68. package/dist/field-exclusion.js +37 -91
  69. package/dist/field-exclusion.js.map +7 -1
  70. package/dist/field-exclusion.test.js +821 -0
  71. package/dist/field-exclusion.test.js.map +7 -0
  72. package/dist/field-structure.js +52 -104
  73. package/dist/field-structure.js.map +7 -1
  74. package/dist/field-structure.test.js +587 -0
  75. package/dist/field-structure.test.js.map +7 -0
  76. package/dist/field33XUtils.js +119 -503
  77. package/dist/field33XUtils.js.map +7 -1
  78. package/dist/fields-present.js +11 -23
  79. package/dist/fields-present.js.map +7 -1
  80. package/dist/fields-present.test.js +95 -0
  81. package/dist/fields-present.test.js.map +7 -0
  82. package/dist/fix-33X.js +393 -431
  83. package/dist/fix-33X.js.map +7 -1
  84. package/dist/fix-33X.test.js +39 -0
  85. package/dist/fix-33X.test.js.map +7 -0
  86. package/dist/fix-country-codes.js +20 -50
  87. package/dist/fix-country-codes.js.map +7 -1
  88. package/dist/fix-country-codes.test.js +44 -0
  89. package/dist/fix-country-codes.test.js.map +7 -0
  90. package/dist/fix-language-codes.js +23 -53
  91. package/dist/fix-language-codes.js.map +7 -1
  92. package/dist/fix-language-codes.test.js +38 -0
  93. package/dist/fix-language-codes.test.js.map +7 -0
  94. package/dist/fixRelatorTerms.js +82 -209
  95. package/dist/fixRelatorTerms.js.map +7 -1
  96. package/dist/fixRelatorTerms.test.js +44 -0
  97. package/dist/fixRelatorTerms.test.js.map +7 -0
  98. package/dist/fixed-fields.js +21 -30
  99. package/dist/fixed-fields.js.map +7 -1
  100. package/dist/fixed-fields.test.js +87 -0
  101. package/dist/fixed-fields.test.js.map +7 -0
  102. package/dist/identical-fields.js +8 -24
  103. package/dist/identical-fields.js.map +7 -1
  104. package/dist/identical-fields.test.js +119 -0
  105. package/dist/identical-fields.test.js.map +7 -0
  106. package/dist/index.js +182 -413
  107. package/dist/index.js.map +7 -1
  108. package/dist/indicator-fixes.js +66 -94
  109. package/dist/indicator-fixes.js.map +7 -1
  110. package/dist/indicator-fixes.test.js +42 -0
  111. package/dist/indicator-fixes.test.js.map +7 -0
  112. package/dist/isbn-issn.js +71 -128
  113. package/dist/isbn-issn.js.map +7 -1
  114. package/dist/isbn-issn.test.js +398 -0
  115. package/dist/isbn-issn.test.js.map +7 -0
  116. package/dist/item-language.js +32 -65
  117. package/dist/item-language.js.map +7 -1
  118. package/dist/item-language.test.js +322 -0
  119. package/dist/item-language.test.js.map +7 -0
  120. package/dist/melindaCustomMergeFields.js +5182 -11233
  121. package/dist/melindaCustomMergeFields.js.map +7 -1
  122. package/dist/merge-fields/controlSubfields.js +75 -142
  123. package/dist/merge-fields/controlSubfields.js.map +7 -1
  124. package/dist/merge-fields/counterpartField.js +187 -379
  125. package/dist/merge-fields/counterpartField.js.map +7 -1
  126. package/dist/merge-fields/dataProvenance.js +29 -0
  127. package/dist/merge-fields/dataProvenance.js.map +7 -0
  128. package/dist/merge-fields/index.js +25 -50
  129. package/dist/merge-fields/index.js.map +7 -1
  130. package/dist/merge-fields/mergableIndicator.js +18 -51
  131. package/dist/merge-fields/mergableIndicator.js.map +7 -1
  132. package/dist/merge-fields/mergableTag.js +78 -30
  133. package/dist/merge-fields/mergableTag.js.map +7 -1
  134. package/dist/merge-fields/mergeConfig.js +66 -171
  135. package/dist/merge-fields/mergeConfig.js.map +7 -1
  136. package/dist/merge-fields/mergeConstraints.js +323 -1214
  137. package/dist/merge-fields/mergeConstraints.js.map +7 -1
  138. package/dist/merge-fields/mergeField.js +47 -111
  139. package/dist/merge-fields/mergeField.js.map +7 -1
  140. package/dist/merge-fields/mergeIndicator.js +64 -118
  141. package/dist/merge-fields/mergeIndicator.js.map +7 -1
  142. package/dist/merge-fields/mergeOrAddPostprocess.js +14 -38
  143. package/dist/merge-fields/mergeOrAddPostprocess.js.map +7 -1
  144. package/dist/merge-fields/mergeOrAddSubfield.js +62 -104
  145. package/dist/merge-fields/mergeOrAddSubfield.js.map +7 -1
  146. package/dist/merge-fields/mergeSubfield.js +47 -95
  147. package/dist/merge-fields/mergeSubfield.js.map +7 -1
  148. package/dist/merge-fields/removeDuplicateSubfields.js +18 -31
  149. package/dist/merge-fields/removeDuplicateSubfields.js.map +7 -1
  150. package/dist/merge-fields/worldKnowledge.js +15 -40
  151. package/dist/merge-fields/worldKnowledge.js.map +7 -1
  152. package/dist/merge-fields.test.js +46 -0
  153. package/dist/merge-fields.test.js.map +7 -0
  154. package/dist/mergeField500Lisapainokset.js +27 -56
  155. package/dist/mergeField500Lisapainokset.js.map +7 -1
  156. package/dist/mergeField500Lisapainokset.test.js +44 -0
  157. package/dist/mergeField500Lisapainokset.test.js.map +7 -0
  158. package/dist/mergeRelatorTermFields.js +33 -69
  159. package/dist/mergeRelatorTermFields.js.map +7 -1
  160. package/dist/mergeRelatorTermFields.test.js +44 -0
  161. package/dist/mergeRelatorTermFields.test.js.map +7 -0
  162. package/dist/modernize-502.js +23 -55
  163. package/dist/modernize-502.js.map +7 -1
  164. package/dist/modernize-502.test.js +38 -0
  165. package/dist/modernize-502.test.js.map +7 -0
  166. package/dist/multiple-subfield-0.js +23 -48
  167. package/dist/multiple-subfield-0.js.map +7 -1
  168. package/dist/multiple-subfield-0.test.js +44 -0
  169. package/dist/multiple-subfield-0.test.js.map +7 -0
  170. package/dist/non-breaking-space.js +11 -32
  171. package/dist/non-breaking-space.js.map +7 -1
  172. package/dist/non-breaking-space.test.js +38 -0
  173. package/dist/non-breaking-space.test.js.map +7 -0
  174. package/dist/normalize-dashes.js +18 -37
  175. package/dist/normalize-dashes.js.map +7 -1
  176. package/dist/normalize-dashes.test.js +44 -0
  177. package/dist/normalize-dashes.test.js.map +7 -0
  178. package/dist/normalize-identifiers.js +54 -140
  179. package/dist/normalize-identifiers.js.map +7 -1
  180. package/dist/normalize-identifiers.test.js +44 -0
  181. package/dist/normalize-identifiers.test.js.map +7 -0
  182. package/dist/normalize-qualifying-information.js +23 -48
  183. package/dist/normalize-qualifying-information.js.map +7 -1
  184. package/dist/normalize-qualifying-information.test.js +44 -0
  185. package/dist/normalize-qualifying-information.test.js.map +7 -0
  186. package/dist/normalize-utf8-diacritics.js +19 -105
  187. package/dist/normalize-utf8-diacritics.js.map +7 -1
  188. package/dist/normalize-utf8-diacritics.test.js +44 -0
  189. package/dist/normalize-utf8-diacritics.test.js.map +7 -0
  190. package/dist/normalizeFieldForComparison.js +91 -158
  191. package/dist/normalizeFieldForComparison.js.map +7 -1
  192. package/dist/normalizeSubfieldValueForComparison.js +37 -77
  193. package/dist/normalizeSubfieldValueForComparison.js.map +7 -1
  194. package/dist/prepublicationUtils.js +58 -111
  195. package/dist/prepublicationUtils.js.map +7 -1
  196. package/dist/punctuation/index.js +56 -72
  197. package/dist/punctuation/index.js.map +7 -1
  198. package/dist/punctuation/rules/aut.js +372 -331
  199. package/dist/punctuation/rules/aut.js.map +7 -1
  200. package/dist/punctuation/rules/bib.js +420 -373
  201. package/dist/punctuation/rules/bib.js.map +7 -1
  202. package/dist/punctuation/rules/index.js +7 -21
  203. package/dist/punctuation/rules/index.js.map +7 -1
  204. package/dist/punctuation.test.js +44 -0
  205. package/dist/punctuation.test.js.map +7 -0
  206. package/dist/punctuation2.js +259 -802
  207. package/dist/punctuation2.js.map +7 -1
  208. package/dist/punctuation2.test.js +44 -0
  209. package/dist/punctuation2.test.js.map +7 -0
  210. package/dist/reindexSubfield6OccurenceNumbers.js +61 -96
  211. package/dist/reindexSubfield6OccurenceNumbers.js.map +7 -1
  212. package/dist/reindexSubfield6OccurenceNumbers.test.js +44 -0
  213. package/dist/reindexSubfield6OccurenceNumbers.test.js.map +7 -0
  214. package/dist/removeDuplicateDataFields.js +102 -202
  215. package/dist/removeDuplicateDataFields.js.map +7 -1
  216. package/dist/removeDuplicateDataFields.test.js +44 -0
  217. package/dist/removeDuplicateDataFields.test.js.map +7 -0
  218. package/dist/removeInferiorDataFields.js +104 -227
  219. package/dist/removeInferiorDataFields.js.map +7 -1
  220. package/dist/removeInferiorDataFields.test.js +44 -0
  221. package/dist/removeInferiorDataFields.test.js.map +7 -0
  222. package/dist/resolvable-ext-references-melinda.js +25 -60
  223. package/dist/resolvable-ext-references-melinda.js.map +7 -1
  224. package/dist/resolvable-ext-references-melinda.test.js +160 -0
  225. package/dist/resolvable-ext-references-melinda.test.js.map +7 -0
  226. package/dist/resolveOrphanedSubfield6s.js +32 -63
  227. package/dist/resolveOrphanedSubfield6s.js.map +7 -1
  228. package/dist/resolveOrphanedSubfield6s.test.js +44 -0
  229. package/dist/resolveOrphanedSubfield6s.test.js.map +7 -0
  230. package/dist/sanitize-vocabulary-source-codes.js +27 -55
  231. package/dist/sanitize-vocabulary-source-codes.js.map +7 -1
  232. package/dist/sanitize-vocabulary-source-codes.test.js +45 -0
  233. package/dist/sanitize-vocabulary-source-codes.test.js.map +7 -0
  234. package/dist/sort-tags.js +13 -25
  235. package/dist/sort-tags.js.map +7 -1
  236. package/dist/sort-tags.test.js +261 -0
  237. package/dist/sort-tags.test.js.map +7 -0
  238. package/dist/sortFields.js +152 -222
  239. package/dist/sortFields.js.map +7 -1
  240. package/dist/sortFields.test.js +44 -0
  241. package/dist/sortFields.test.js.map +7 -0
  242. package/dist/sortRelatorTerms.js +30 -68
  243. package/dist/sortRelatorTerms.js.map +7 -1
  244. package/dist/sortRelatorTerms.test.js +44 -0
  245. package/dist/sortRelatorTerms.test.js.map +7 -0
  246. package/dist/sortSubfields.js +102 -255
  247. package/dist/sortSubfields.js.map +7 -1
  248. package/dist/sortSubfields.test.js +44 -0
  249. package/dist/sortSubfields.test.js.map +7 -0
  250. package/dist/stripPunctuation.js +13 -36
  251. package/dist/stripPunctuation.js.map +7 -1
  252. package/dist/stripPunctuation.test.js +44 -0
  253. package/dist/stripPunctuation.test.js.map +7 -0
  254. package/dist/subfield-exclusion.js +28 -75
  255. package/dist/subfield-exclusion.js.map +7 -1
  256. package/dist/subfield-exclusion.test.js +471 -0
  257. package/dist/subfield-exclusion.test.js.map +7 -0
  258. package/dist/subfield6Utils.js +107 -269
  259. package/dist/subfield6Utils.js.map +7 -1
  260. package/dist/subfield8Utils.js +26 -50
  261. package/dist/subfield8Utils.js.map +7 -1
  262. package/dist/subfieldValueNormalizations.js +40 -74
  263. package/dist/subfieldValueNormalizations.js.map +7 -1
  264. package/dist/subfieldValueNormalizations.test.js +45 -0
  265. package/dist/subfieldValueNormalizations.test.js.map +7 -0
  266. package/dist/sync-007-and-300.js +22 -53
  267. package/dist/sync-007-and-300.js.map +7 -1
  268. package/dist/sync-007-and-300.test.js +44 -0
  269. package/dist/sync-007-and-300.test.js.map +7 -0
  270. package/dist/translate-terms.js +67 -155
  271. package/dist/translate-terms.js.map +7 -1
  272. package/dist/translate-terms.test.js +54 -0
  273. package/dist/translate-terms.test.js.map +7 -0
  274. package/dist/typeOfDate-008.js +10 -25
  275. package/dist/typeOfDate-008.js.map +7 -1
  276. package/dist/typeOfDate-008.test.js +40 -0
  277. package/dist/typeOfDate-008.test.js.map +7 -0
  278. package/dist/unicode-decomposition.js +94 -107
  279. package/dist/unicode-decomposition.js.map +7 -1
  280. package/dist/unicode-decomposition.test.js +94 -0
  281. package/dist/unicode-decomposition.test.js.map +7 -0
  282. package/dist/update-field-540.js +30 -75
  283. package/dist/update-field-540.js.map +7 -1
  284. package/dist/update-field-540.test.js +44 -0
  285. package/dist/update-field-540.test.js.map +7 -0
  286. package/dist/urn.js +55 -128
  287. package/dist/urn.js.map +7 -1
  288. package/dist/urn.test.js +44 -0
  289. package/dist/urn.test.js.map +7 -0
  290. package/dist/utils.js +78 -126
  291. package/dist/utils.js.map +7 -1
  292. package/eslint.config.mjs +1 -2
  293. package/package.json +28 -101
  294. package/src/access-rights.js +1 -1
  295. package/src/{access-rights.spec.js → access-rights.test.js} +9 -10
  296. package/src/addMissingField041.js +1 -1
  297. package/src/{addMissingField336.spec.js → addMissingField041.test.js} +13 -14
  298. package/src/addMissingField336.js +3 -3
  299. package/src/{addMissingField041.spec.js → addMissingField336.test.js} +13 -14
  300. package/src/addMissingField337.js +2 -2
  301. package/src/{addMissingField337.spec.js → addMissingField337.test.js} +13 -14
  302. package/src/addMissingField338.js +2 -2
  303. package/src/{addMissingField338.spec.js → addMissingField338.test.js} +13 -14
  304. package/src/cyrillux-usemarcon-replacement.js +18 -18
  305. package/src/{cyrillux-usemarcon-replacement.spec.js → cyrillux-usemarcon-replacement.test.js} +17 -14
  306. package/src/cyrillux.js +19 -12
  307. package/src/{cyrillux.spec.js → cyrillux.test.js} +13 -14
  308. package/src/disambiguateSeriesStatements.js +2 -2
  309. package/src/{disambiguateSeriesStatements.spec.js → disambiguateSeriesStatements.test.js} +12 -13
  310. package/src/double-commas.js +1 -1
  311. package/src/{double-commas.spec.js → double-commas.test.js} +9 -11
  312. package/src/duplicates-ind1.js +1 -1
  313. package/src/{duplicates-ind1.spec.js → duplicates-ind1.test.js} +12 -13
  314. package/src/{empty-fields.spec.js → empty-fields.test.js} +11 -13
  315. package/src/ending-punctuation-conf.js +6 -5
  316. package/src/ending-punctuation.js +115 -24
  317. package/src/{ending-punctuation.spec.js → ending-punctuation.test.js} +357 -275
  318. package/src/{ending-whitespace.spec.js → ending-whitespace.test.js} +12 -13
  319. package/src/field-008-18-34-character-groups.js +2 -2
  320. package/src/{field-008-18-34-character-groups.spec.js → field-008-18-34-character-groups.test.js} +13 -13
  321. package/src/field-505-separators.js +3 -3
  322. package/src/{field-505-separators.spec.js → field-505-separators.test.js} +16 -14
  323. package/src/field-521-fix.js +2 -2
  324. package/src/{field-521-fix.spec.js → field-521-fix.test.js} +12 -13
  325. package/src/field-exclusion.js +1 -1
  326. package/src/{field-exclusion.spec.js → field-exclusion.test.js} +60 -57
  327. package/src/{field-structure.spec.js → field-structure.test.js} +29 -29
  328. package/src/{fields-present.spec.js → fields-present.test.js} +12 -15
  329. package/src/fix-33X.js +4 -4
  330. package/src/{fix-33X.spec.js → fix-33X.test.js} +13 -14
  331. package/src/fix-country-codes.js +1 -1
  332. package/src/{fix-country-codes.spec.js → fix-country-codes.test.js} +12 -13
  333. package/src/fix-language-codes.js +5 -5
  334. package/src/{fix-language-codes.spec.js → fix-language-codes.test.js} +12 -13
  335. package/src/fixRelatorTerms.js +5 -5
  336. package/src/{fixRelatorTerms.spec.js → fixRelatorTerms.test.js} +13 -13
  337. package/src/{fixed-fields.spec.js → fixed-fields.test.js} +11 -14
  338. package/src/identical-fields.js +1 -1
  339. package/src/{identical-fields.spec.js → identical-fields.test.js} +9 -11
  340. package/src/index.js +132 -59
  341. package/src/indicator-fixes.js +17 -4
  342. package/src/{indicator-fixes.spec.js → indicator-fixes.test.js} +9 -12
  343. package/src/isbn-issn.js +12 -7
  344. package/src/{isbn-issn.spec.js → isbn-issn.test.js} +20 -22
  345. package/src/{item-language.spec.js → item-language.test.js} +21 -22
  346. package/src/melindaCustomMergeFields.js +1 -1
  347. package/src/merge-fields/controlSubfields.js +1 -1
  348. package/src/merge-fields/counterpartField.js +14 -9
  349. package/src/merge-fields/dataProvenance.js +41 -0
  350. package/src/merge-fields/index.js +12 -3
  351. package/src/merge-fields/mergableIndicator.js +1 -1
  352. package/src/merge-fields/mergeField.js +8 -8
  353. package/src/merge-fields/mergeIndicator.js +1 -1
  354. package/src/merge-fields/mergeOrAddPostprocess.js +4 -4
  355. package/src/merge-fields/mergeOrAddSubfield.js +2 -2
  356. package/src/merge-fields/mergeSubfield.js +4 -4
  357. package/src/merge-fields/removeDuplicateSubfields.js +2 -2
  358. package/src/{merge-fields.spec.js → merge-fields.test.js} +18 -15
  359. package/src/mergeField500Lisapainokset.js +1 -1
  360. package/src/{mergeField500Lisapainokset.spec.js → mergeField500Lisapainokset.test.js} +12 -13
  361. package/src/mergeRelatorTermFields.js +5 -7
  362. package/src/{mergeRelatorTermFields.spec.js → mergeRelatorTermFields.test.js} +12 -13
  363. package/src/modernize-502.js +1 -1
  364. package/src/{modernize-502.spec.js → modernize-502.test.js} +12 -13
  365. package/src/multiple-subfield-0.js +3 -3
  366. package/src/{multiple-subfield-0.spec.js → multiple-subfield-0.test.js} +13 -13
  367. package/src/{non-breaking-space.spec.js → non-breaking-space.test.js} +12 -13
  368. package/src/normalize-dashes.js +2 -2
  369. package/src/{normalize-dashes.spec.js → normalize-dashes.test.js} +12 -13
  370. package/src/normalize-identifiers.js +1 -1
  371. package/src/{normalize-identifiers.spec.js → normalize-identifiers.test.js} +12 -13
  372. package/src/normalize-qualifying-information.js +2 -2
  373. package/src/{normalize-qualifying-information.spec.js → normalize-qualifying-information.test.js} +12 -13
  374. package/src/normalize-utf8-diacritics.js +2 -2
  375. package/src/{normalize-utf8-diacritics.spec.js → normalize-utf8-diacritics.test.js} +13 -13
  376. package/src/normalizeFieldForComparison.js +32 -6
  377. package/src/normalizeSubfieldValueForComparison.js +1 -1
  378. package/src/prepublicationUtils.js +4 -4
  379. package/src/punctuation/index.js +1 -1
  380. package/src/punctuation/rules/index.js +2 -2
  381. package/src/{punctuation.spec.js → punctuation.test.js} +12 -13
  382. package/src/punctuation2.js +17 -8
  383. package/src/{punctuation2.spec.js → punctuation2.test.js} +12 -13
  384. package/src/reindexSubfield6OccurenceNumbers.js +5 -7
  385. package/src/{reindexSubfield6OccurenceNumbers.spec.js → reindexSubfield6OccurenceNumbers.test.js} +12 -13
  386. package/src/removeDuplicateDataFields.js +11 -19
  387. package/src/{removeDuplicateDataFields.spec.js → removeDuplicateDataFields.test.js} +12 -13
  388. package/src/removeInferiorDataFields.js +15 -12
  389. package/src/{removeInferiorDataFields.spec.js → removeInferiorDataFields.test.js} +13 -13
  390. package/src/resolvable-ext-references-melinda.js +1 -1
  391. package/src/{resolvable-ext-references-melinda.spec.js → resolvable-ext-references-melinda.test.js} +42 -27
  392. package/src/resolveOrphanedSubfield6s.js +6 -6
  393. package/src/{resolveOrphanedSubfield6s.spec.js → resolveOrphanedSubfield6s.test.js} +13 -13
  394. package/src/sanitize-vocabulary-source-codes.js +4 -4
  395. package/src/{sanitize-vocabulary-source-codes.spec.js → sanitize-vocabulary-source-codes.test.js} +16 -14
  396. package/src/{sort-tags.spec.js → sort-tags.test.js} +9 -11
  397. package/src/sortFields.js +4 -4
  398. package/src/{sortFields.spec.js → sortFields.test.js} +12 -13
  399. package/src/sortRelatorTerms.js +3 -3
  400. package/src/{sortRelatorTerms.spec.js → sortRelatorTerms.test.js} +13 -13
  401. package/src/sortSubfields.js +8 -6
  402. package/src/{sortSubfields.spec.js → sortSubfields.test.js} +13 -13
  403. package/src/stripPunctuation.js +3 -3
  404. package/src/{stripPunctuation.spec.js → stripPunctuation.test.js} +13 -13
  405. package/src/subfield-exclusion.js +1 -1
  406. package/src/{subfield-exclusion.spec.js → subfield-exclusion.test.js} +45 -36
  407. package/src/subfield6Utils.js +6 -10
  408. package/src/subfield8Utils.js +4 -4
  409. package/src/subfieldValueNormalizations.js +3 -3
  410. package/src/{subfieldValueNormalizations.spec.js → subfieldValueNormalizations.test.js} +18 -14
  411. package/src/sync-007-and-300.js +2 -2
  412. package/src/{sync-007-and-300.spec.js → sync-007-and-300.test.js} +13 -13
  413. package/src/translate-terms.js +3 -3
  414. package/src/translate-terms.test.js +75 -0
  415. package/src/{typeOfDate-008.spec.js → typeOfDate-008.test.js} +12 -13
  416. package/src/{unicode-decomposition.spec.js → unicode-decomposition.test.js} +10 -16
  417. package/src/update-field-540.js +2 -2
  418. package/src/{update-field-540.spec.js → update-field-540.test.js} +13 -10
  419. package/src/urn.js +2 -2
  420. package/src/{urn.spec.js → urn.test.js} +12 -13
  421. package/src/utils.js +21 -5
  422. package/test-fixtures/field-505-separators/03/expectedResult.json +3 -1
  423. package/test-fixtures/field-505-separators/03/record.json +3 -0
  424. package/test-fixtures/indicator-fixes/10/expectedResult.json +11 -0
  425. package/test-fixtures/indicator-fixes/10/metadata.json +4 -0
  426. package/test-fixtures/indicator-fixes/10/record.json +11 -0
  427. package/test-fixtures/merge-fields/f05/expectedResult.json +24 -0
  428. package/test-fixtures/merge-fields/f05/metadata.json +6 -0
  429. package/test-fixtures/merge-fields/f05/record.json +30 -0
  430. package/test-fixtures/normalize-subfield-value/01/metadata.json +4 -1
  431. package/test-fixtures/normalize-subfield-value/01/record.json +3 -0
  432. package/test-fixtures/normalize-subfield-value/02/expectedResult.json +3 -1
  433. package/test-fixtures/normalize-subfield-value/02/metadata.json +2 -1
  434. package/test-fixtures/normalize-subfield-value/02/record.json +3 -0
  435. package/test-fixtures/remove-inferior-datafields/f16/expectedResult.json +12 -0
  436. package/test-fixtures/remove-inferior-datafields/f16/metadata.json +5 -0
  437. package/test-fixtures/remove-inferior-datafields/f16/record.json +14 -0
  438. package/test-fixtures/sanitize-vocabulary-source-codes/f03/expectedResult.json +3 -1
  439. package/test-fixtures/sanitize-vocabulary-source-codes/f04/expectedResult.json +3 -1
  440. package/test-fixtures/sanitize-vocabulary-source-codes/v04/metadata.json +1 -4
  441. package/test-fixtures/sanitize-vocabulary-source-codes/v04/record.json +1 -1
  442. package/test-fixtures/translate-terms-data.js +42 -0
  443. package/dist/access-rights.spec.js +0 -195
  444. package/dist/access-rights.spec.js.map +0 -1
  445. package/dist/addMissingField041.spec.js +0 -45
  446. package/dist/addMissingField041.spec.js.map +0 -1
  447. package/dist/addMissingField336.spec.js +0 -45
  448. package/dist/addMissingField336.spec.js.map +0 -1
  449. package/dist/addMissingField337.spec.js +0 -43
  450. package/dist/addMissingField337.spec.js.map +0 -1
  451. package/dist/addMissingField338.spec.js +0 -45
  452. package/dist/addMissingField338.spec.js.map +0 -1
  453. package/dist/cyrillux-usemarcon-replacement.spec.js +0 -45
  454. package/dist/cyrillux-usemarcon-replacement.spec.js.map +0 -1
  455. package/dist/cyrillux.spec.js +0 -46
  456. package/dist/cyrillux.spec.js.map +0 -1
  457. package/dist/disambiguateSeriesStatements.spec.js +0 -51
  458. package/dist/disambiguateSeriesStatements.spec.js.map +0 -1
  459. package/dist/double-commas.spec.js +0 -73
  460. package/dist/double-commas.spec.js.map +0 -1
  461. package/dist/duplicates-ind1.spec.js +0 -45
  462. package/dist/duplicates-ind1.spec.js.map +0 -1
  463. package/dist/empty-fields.spec.js +0 -118
  464. package/dist/empty-fields.spec.js.map +0 -1
  465. package/dist/ending-punctuation.spec.js +0 -2654
  466. package/dist/ending-punctuation.spec.js.map +0 -1
  467. package/dist/ending-whitespace.spec.js +0 -42
  468. package/dist/ending-whitespace.spec.js.map +0 -1
  469. package/dist/field-008-18-34-character-groups.spec.js +0 -51
  470. package/dist/field-008-18-34-character-groups.spec.js.map +0 -1
  471. package/dist/field-505-separators.spec.js +0 -51
  472. package/dist/field-505-separators.spec.js.map +0 -1
  473. package/dist/field-521-fix.spec.js +0 -51
  474. package/dist/field-521-fix.spec.js.map +0 -1
  475. package/dist/field-exclusion.spec.js +0 -1054
  476. package/dist/field-exclusion.spec.js.map +0 -1
  477. package/dist/field-structure.spec.js +0 -535
  478. package/dist/field-structure.spec.js.map +0 -1
  479. package/dist/fields-present.spec.js +0 -121
  480. package/dist/fields-present.spec.js.map +0 -1
  481. package/dist/fix-33X.spec.js +0 -45
  482. package/dist/fix-33X.spec.js.map +0 -1
  483. package/dist/fix-country-codes.spec.js +0 -51
  484. package/dist/fix-country-codes.spec.js.map +0 -1
  485. package/dist/fix-language-codes.spec.js +0 -44
  486. package/dist/fix-language-codes.spec.js.map +0 -1
  487. package/dist/fixRelatorTerms.spec.js +0 -51
  488. package/dist/fixRelatorTerms.spec.js.map +0 -1
  489. package/dist/fixed-fields.spec.js +0 -140
  490. package/dist/fixed-fields.spec.js.map +0 -1
  491. package/dist/identical-fields.spec.js +0 -99
  492. package/dist/identical-fields.spec.js.map +0 -1
  493. package/dist/indicator-fixes.spec.js +0 -51
  494. package/dist/indicator-fixes.spec.js.map +0 -1
  495. package/dist/isbn-issn.spec.js +0 -595
  496. package/dist/isbn-issn.spec.js.map +0 -1
  497. package/dist/item-language.spec.js +0 -306
  498. package/dist/item-language.spec.js.map +0 -1
  499. package/dist/melindaCustomMergeFields.json +0 -5120
  500. package/dist/merge-fields.spec.js +0 -51
  501. package/dist/merge-fields.spec.js.map +0 -1
  502. package/dist/mergeField500Lisapainokset.spec.js +0 -51
  503. package/dist/mergeField500Lisapainokset.spec.js.map +0 -1
  504. package/dist/mergeRelatorTermFields.spec.js +0 -51
  505. package/dist/mergeRelatorTermFields.spec.js.map +0 -1
  506. package/dist/modernize-502.spec.js +0 -49
  507. package/dist/modernize-502.spec.js.map +0 -1
  508. package/dist/multiple-subfield-0.spec.js +0 -51
  509. package/dist/multiple-subfield-0.spec.js.map +0 -1
  510. package/dist/non-breaking-space.spec.js +0 -42
  511. package/dist/non-breaking-space.spec.js.map +0 -1
  512. package/dist/normalize-dashes.spec.js +0 -51
  513. package/dist/normalize-dashes.spec.js.map +0 -1
  514. package/dist/normalize-identifiers.spec.js +0 -51
  515. package/dist/normalize-identifiers.spec.js.map +0 -1
  516. package/dist/normalize-qualifying-information.spec.js +0 -51
  517. package/dist/normalize-qualifying-information.spec.js.map +0 -1
  518. package/dist/normalize-utf8-diacritics.spec.js +0 -51
  519. package/dist/normalize-utf8-diacritics.spec.js.map +0 -1
  520. package/dist/punctuation.spec.js +0 -51
  521. package/dist/punctuation.spec.js.map +0 -1
  522. package/dist/punctuation2.spec.js +0 -51
  523. package/dist/punctuation2.spec.js.map +0 -1
  524. package/dist/reindexSubfield6OccurenceNumbers.spec.js +0 -51
  525. package/dist/reindexSubfield6OccurenceNumbers.spec.js.map +0 -1
  526. package/dist/removeDuplicateDataFields.spec.js +0 -51
  527. package/dist/removeDuplicateDataFields.spec.js.map +0 -1
  528. package/dist/removeInferiorDataFields.spec.js +0 -51
  529. package/dist/removeInferiorDataFields.spec.js.map +0 -1
  530. package/dist/resolvable-ext-references-melinda.spec.js +0 -166
  531. package/dist/resolvable-ext-references-melinda.spec.js.map +0 -1
  532. package/dist/resolveOrphanedSubfield6s.spec.js +0 -51
  533. package/dist/resolveOrphanedSubfield6s.spec.js.map +0 -1
  534. package/dist/sanitize-vocabulary-source-codes.spec.js +0 -51
  535. package/dist/sanitize-vocabulary-source-codes.spec.js.map +0 -1
  536. package/dist/sort-tags.spec.js +0 -207
  537. package/dist/sort-tags.spec.js.map +0 -1
  538. package/dist/sortFields.spec.js +0 -51
  539. package/dist/sortFields.spec.js.map +0 -1
  540. package/dist/sortRelatorTerms.spec.js +0 -51
  541. package/dist/sortRelatorTerms.spec.js.map +0 -1
  542. package/dist/sortSubfields.spec.js +0 -52
  543. package/dist/sortSubfields.spec.js.map +0 -1
  544. package/dist/stripPunctuation.spec.js +0 -51
  545. package/dist/stripPunctuation.spec.js.map +0 -1
  546. package/dist/subfield-exclusion.spec.js +0 -523
  547. package/dist/subfield-exclusion.spec.js.map +0 -1
  548. package/dist/subfieldValueNormalizations.spec.js +0 -51
  549. package/dist/subfieldValueNormalizations.spec.js.map +0 -1
  550. package/dist/sync-007-and-300.spec.js +0 -51
  551. package/dist/sync-007-and-300.spec.js.map +0 -1
  552. package/dist/translate-terms.spec.js +0 -51
  553. package/dist/translate-terms.spec.js.map +0 -1
  554. package/dist/typeOfDate-008.spec.js +0 -47
  555. package/dist/typeOfDate-008.spec.js.map +0 -1
  556. package/dist/unicode-decomposition.spec.js +0 -91
  557. package/dist/unicode-decomposition.spec.js.map +0 -1
  558. package/dist/update-field-540.spec.js +0 -51
  559. package/dist/update-field-540.spec.js.map +0 -1
  560. package/dist/urn.spec.js +0 -52
  561. package/dist/urn.spec.js.map +0 -1
  562. package/src/melindaCustomMergeFields.json +0 -5120
  563. package/src/translate-terms.spec.js +0 -52
@@ -0,0 +1,2385 @@
1
+ import assert from "node:assert";
2
+ import { MarcRecord } from "@natlibfi/marc-record";
3
+ import validatorFactory from "../src/ending-punctuation.js";
4
+ import { describe, it } from "node:test";
5
+ describe("ending-punctuation", () => {
6
+ describe("#validate: Indicators and subfields", () => {
7
+ const recordValid = new MarcRecord({
8
+ leader: "",
9
+ fields: [
10
+ {
11
+ tag: "245",
12
+ ind1: " ",
13
+ ind2: " ",
14
+ subfields: [
15
+ { code: "a", value: "El\xE4m\xE4ni ja tutkimusretkeni /" },
16
+ { code: "c", value: "Roald Amundsen ; suomentanut Sulo Veikko Pekkola." },
17
+ { code: "6", value: "FOO" }
18
+ ]
19
+ },
20
+ {
21
+ // Hackily putting 2nd 245 here
22
+ tag: "245",
23
+ ind1: "0",
24
+ ind2: "4",
25
+ subfields: [
26
+ { code: "a", value: "The Disaster /" },
27
+ { code: "c", value: "(J.L.)." }
28
+ ]
29
+ },
30
+ {
31
+ tag: "337",
32
+ // Range 336-338
33
+ ind1: " ",
34
+ ind2: " ",
35
+ subfields: [
36
+ { code: "a", value: "k\xE4ytett\xE4viss\xE4 ilman laitetta" },
37
+ { code: "b", value: "n" },
38
+ { code: "2", value: "rdamedia" }
39
+ ]
40
+ },
41
+ {
42
+ tag: "500",
43
+ // Range 500-509
44
+ ind1: " ",
45
+ ind2: " ",
46
+ subfields: [{ code: "a", value: "FOO (Bar)." }]
47
+ },
48
+ {
49
+ tag: "500",
50
+ // Range 500-509
51
+ ind1: " ",
52
+ ind2: " ",
53
+ subfields: [{ code: "a", value: '"Lorum ipsum."' }]
54
+ },
55
+ {
56
+ tag: "500",
57
+ // Range 500-509
58
+ ind1: " ",
59
+ ind2: " ",
60
+ subfields: [{ code: "a", value: 'Foo "Bar".' }]
61
+ }
62
+ ]
63
+ });
64
+ const recordInvalid = new MarcRecord({
65
+ leader: "",
66
+ fields: [
67
+ {
68
+ tag: "245",
69
+ ind1: " ",
70
+ ind2: " ",
71
+ subfields: [
72
+ { code: "a", value: "El\xE4m\xE4ni ja tutkimusretkeni /" },
73
+ { code: "c", value: "Roald Amundsen ; suomentanut Sulo Veikko Pekkola" },
74
+ { code: "6", value: "FOO" }
75
+ // NV: not changing this now, but this is wrong: $6 is *always* the first subfield. Also , the value is not valid for $6...
76
+ ]
77
+ },
78
+ {
79
+ // Hackily putting 2nd 245 here
80
+ tag: "245",
81
+ ind1: "0",
82
+ ind2: "4",
83
+ subfields: [
84
+ { code: "a", value: "The Disaster /" },
85
+ { code: "c", value: "(J.L.)" }
86
+ ]
87
+ },
88
+ {
89
+ tag: "337",
90
+ ind1: " ",
91
+ ind2: " ",
92
+ subfields: [
93
+ { code: "a", value: "k\xE4ytett\xE4viss\xE4 ilman laitetta" },
94
+ { code: "b", value: "n." },
95
+ // This can be abbreviation -> does not generate error (NV: huh?!?)
96
+ { code: "2", value: "rdamedia" }
97
+ ]
98
+ },
99
+ {
100
+ tag: "500",
101
+ ind1: " ",
102
+ ind2: " ",
103
+ subfields: [{ code: "a", value: "FOO (Bar)" }]
104
+ },
105
+ {
106
+ tag: "500",
107
+ // Range 500-509
108
+ ind1: " ",
109
+ ind2: " ",
110
+ subfields: [{ code: "a", value: '"Lorum ipsum.".' }]
111
+ },
112
+ {
113
+ tag: "500",
114
+ // Range 500-509
115
+ ind1: " ",
116
+ ind2: " ",
117
+ subfields: [{ code: "a", value: 'Foo "Bar"' }]
118
+ }
119
+ ]
120
+ });
121
+ const recordBroken = new MarcRecord({
122
+ leader: "",
123
+ fields: [
124
+ {
125
+ tag: "245",
126
+ ind1: " ",
127
+ ind2: " ",
128
+ subfields: [
129
+ { code: "a", value: "El\xE4m\xE4ni ja tutkimusretkeni /" },
130
+ { code: "c", value: "Roald Amundsen ; suomentanut Sulo Veikko Pekkola" },
131
+ { code: "6", value: "FOO" }
132
+ ]
133
+ },
134
+ {
135
+ // Hackily putting 2nd 245 here
136
+ tag: "245",
137
+ ind1: "0",
138
+ ind2: "4",
139
+ subfields: [
140
+ { code: "a", value: "The Disaster /" },
141
+ { code: "c", value: "(J.L.)" }
142
+ ]
143
+ },
144
+ {
145
+ tag: "337",
146
+ ind1: " ",
147
+ ind2: " ",
148
+ subfields: [
149
+ { code: "a", value: "k\xE4ytett\xE4viss\xE4 ilman laitetta" },
150
+ { code: "b", value: "n" },
151
+ // Dot removed from possible abbreviation as it cannot be removed in fixing (NV: huh?)
152
+ { code: "2", value: "rdamedia" }
153
+ ]
154
+ },
155
+ {
156
+ tag: "500",
157
+ ind1: " ",
158
+ ind2: " ",
159
+ subfields: [{ code: "a", value: "FOO (Bar)" }]
160
+ },
161
+ {
162
+ tag: "500",
163
+ // Range 500-509
164
+ ind1: " ",
165
+ ind2: " ",
166
+ subfields: [{ code: "a", value: '"Lorum ipsum.".' }]
167
+ },
168
+ {
169
+ tag: "500",
170
+ // Range 500-509
171
+ ind1: " ",
172
+ ind2: " ",
173
+ subfields: [{ code: "a", value: 'Foo "Bar"' }]
174
+ }
175
+ ]
176
+ });
177
+ it("Finds the record valid", async () => {
178
+ const validator = await validatorFactory();
179
+ const result = await validator.validate(recordValid);
180
+ assert.equal(result.valid, true);
181
+ });
182
+ it("Finds the record invalid", async () => {
183
+ const validator = await validatorFactory();
184
+ const result = await validator.validate(recordInvalid);
185
+ assert.deepEqual(result, {
186
+ message: ["Field 245 requires ending punctuation, ends in 'a'", "Field 245 requires ending punctuation, ends in ')'", "Field 500 requires ending punctuation, ends in ')'", `Field 500 has an extra dot in '.".'`, `Field 500 requires ending punctuation, ends in '"'`],
187
+ valid: false
188
+ });
189
+ });
190
+ it("Repairs the invalid record", async () => {
191
+ const validator = await validatorFactory();
192
+ const result = await validator.fix(recordBroken);
193
+ assert.deepEqual(result, {
194
+ message: ["Field 245 requires ending punctuation, ends in 'a'", "Field 245 requires ending punctuation, ends in ')'", "Field 500 requires ending punctuation, ends in ')'", `Field 500 has an extra dot in '.".'`, `Field 500 requires ending punctuation, ends in '"'`],
195
+ fix: ["Field 245 - Added punctuation to $c", "Field 245 - Added punctuation to $c", "Field 500 - Added punctuation to $a", `Field 500 - Removed '.' after '."'`, "Field 500 - Added punctuation to $a"],
196
+ valid: false
197
+ });
198
+ assert.equal(recordBroken.equalsTo(recordValid), true);
199
+ });
200
+ });
201
+ describe("#specials", () => {
202
+ describe("#036 TRUE - only after subfield $b", () => {
203
+ const recordValid = new MarcRecord({
204
+ leader: "",
205
+ fields: [
206
+ {
207
+ tag: "036",
208
+ ind1: " ",
209
+ ind2: " ",
210
+ subfields: [
211
+ { code: "a", value: "CNRS 84115" },
212
+ { code: "b", value: "Centre national de la recherche scientifique." }
213
+ ]
214
+ }
215
+ ]
216
+ });
217
+ const recordValidOnlyA = new MarcRecord({
218
+ leader: "",
219
+ fields: [
220
+ {
221
+ tag: "036",
222
+ ind1: " ",
223
+ ind2: " ",
224
+ subfields: [{ code: "a", value: "CNRS 84115" }]
225
+ }
226
+ ]
227
+ });
228
+ it("Finds record valid - Punc $b", async () => {
229
+ const validator = await validatorFactory();
230
+ const result = await validator.validate(recordValid);
231
+ assert.equal(result.valid, true);
232
+ });
233
+ it("Finds record valid - Only $a without punc", async () => {
234
+ const validator = await validatorFactory();
235
+ const result = await validator.validate(recordValidOnlyA);
236
+ assert.equal(result.valid, true);
237
+ });
238
+ const recordInvalid = new MarcRecord({
239
+ leader: "",
240
+ fields: [
241
+ {
242
+ tag: "036",
243
+ ind1: " ",
244
+ ind2: " ",
245
+ subfields: [
246
+ { code: "a", value: "CNRS 84115" },
247
+ { code: "b", value: "Centre national de la recherche scientifique" }
248
+ ]
249
+ }
250
+ ]
251
+ });
252
+ const recordInvalidOnlyA = new MarcRecord({
253
+ leader: "",
254
+ fields: [
255
+ {
256
+ tag: "036",
257
+ ind1: " ",
258
+ ind2: " ",
259
+ subfields: [{ code: "a", value: "CNRS 84115." }]
260
+ // $a is register number, no change for abbreviation
261
+ }
262
+ ]
263
+ });
264
+ it("Finds record invalid - No punc $b", async () => {
265
+ const validator = await validatorFactory();
266
+ const result = await validator.validate(recordInvalid);
267
+ assert.deepEqual(result, {
268
+ message: ["Field 036 requires ending punctuation, ends in 'e'"],
269
+ valid: false
270
+ });
271
+ });
272
+ it("Finds record invalid - Only $a with punc", async () => {
273
+ const validator = await validatorFactory();
274
+ const result = await validator.validate(recordInvalidOnlyA);
275
+ assert.deepEqual(result, {
276
+ message: ["Field 036 has unwanted ending punctuation '.'"],
277
+ valid: false
278
+ });
279
+ });
280
+ it("Repairs the invalid record - Add punc $b", async () => {
281
+ const validator = await validatorFactory();
282
+ const result = await validator.fix(recordInvalid);
283
+ assert.equal(recordInvalid.equalsTo(recordValid), true);
284
+ assert.deepEqual(result, {
285
+ message: ["Field 036 requires ending punctuation, ends in 'e'"],
286
+ fix: ["Field 036 - Added punctuation to $b"],
287
+ valid: false
288
+ });
289
+ });
290
+ it("Repairs the invalid record - Removes punc $a (register)", async () => {
291
+ const validator = await validatorFactory();
292
+ const result = await validator.fix(recordInvalidOnlyA);
293
+ assert.equal(recordInvalidOnlyA.equalsTo(recordValidOnlyA), true);
294
+ assert.deepEqual(result, {
295
+ message: ["Field 036 has unwanted ending punctuation '.'"],
296
+ fix: ["Field 036 - Removed punctuation from $a"],
297
+ valid: false
298
+ });
299
+ });
300
+ });
301
+ describe("#242 TRUE - if last subfield $y, punc before it", () => {
302
+ const recordValidOnlyA = new MarcRecord({
303
+ leader: "",
304
+ fields: [
305
+ {
306
+ tag: "242",
307
+ ind1: " ",
308
+ ind2: " ",
309
+ subfields: [
310
+ { code: "a", value: "World of art." },
311
+ { code: "y", value: "eng" }
312
+ ]
313
+ }
314
+ ]
315
+ });
316
+ const recordValidMultiple = new MarcRecord({
317
+ leader: "",
318
+ fields: [
319
+ {
320
+ tag: "242",
321
+ ind1: " ",
322
+ ind2: " ",
323
+ subfields: [
324
+ { code: "a", value: "Annals of chemistry." },
325
+ { code: "n", value: "Series C," },
326
+ { code: "p", value: "Organic chemistry and biochemistry." },
327
+ { code: "y", value: "eng" }
328
+ ]
329
+ }
330
+ ]
331
+ });
332
+ const recordValidWithoutY = new MarcRecord({
333
+ leader: "",
334
+ fields: [
335
+ {
336
+ tag: "242",
337
+ ind1: " ",
338
+ ind2: " ",
339
+ subfields: [{ code: "a", value: "World of art." }]
340
+ }
341
+ ]
342
+ });
343
+ it("Finds record valid - Punc $a", async () => {
344
+ const validator = await validatorFactory();
345
+ const result = await validator.validate(recordValidOnlyA);
346
+ assert.equal(result.valid, true);
347
+ });
348
+ it("Finds record valid - Punc $p", async () => {
349
+ const validator = await validatorFactory();
350
+ const result = await validator.validate(recordValidMultiple);
351
+ assert.equal(result.valid, true);
352
+ });
353
+ it("Finds record valid - Punc $a without $y", async () => {
354
+ const validator = await validatorFactory();
355
+ const result = await validator.validate(recordValidWithoutY);
356
+ assert.equal(result.valid, true);
357
+ });
358
+ const recordInvalidOnlyAMissingA = new MarcRecord({
359
+ leader: "",
360
+ fields: [
361
+ {
362
+ tag: "242",
363
+ ind1: " ",
364
+ ind2: " ",
365
+ subfields: [
366
+ { code: "a", value: "World of art" },
367
+ { code: "y", value: "eng" }
368
+ ]
369
+ }
370
+ ]
371
+ });
372
+ const recordInvalidOnlyAPuncY = new MarcRecord({
373
+ leader: "",
374
+ fields: [
375
+ {
376
+ tag: "242",
377
+ ind1: " ",
378
+ ind2: " ",
379
+ subfields: [
380
+ { code: "a", value: "World of art." },
381
+ { code: "y", value: "eng." }
382
+ // $y is also checked as rule is explicit
383
+ ]
384
+ }
385
+ ]
386
+ });
387
+ const recordInvalidOnlyAMissingAPuncY = new MarcRecord({
388
+ leader: "",
389
+ fields: [
390
+ {
391
+ tag: "242",
392
+ ind1: " ",
393
+ ind2: " ",
394
+ subfields: [
395
+ { code: "a", value: "World of art" },
396
+ { code: "y", value: "eng." }
397
+ // $y is also checked as rule is explicit
398
+ ]
399
+ }
400
+ ]
401
+ });
402
+ const recordValidMultipleMissingP = new MarcRecord({
403
+ leader: "",
404
+ fields: [
405
+ {
406
+ tag: "242",
407
+ ind1: " ",
408
+ ind2: " ",
409
+ subfields: [
410
+ { code: "a", value: "Annals of chemistry." },
411
+ { code: "n", value: "Series C," },
412
+ { code: "p", value: "Organic chemistry and biochemistry" },
413
+ { code: "y", value: "eng" }
414
+ ]
415
+ }
416
+ ]
417
+ });
418
+ const recordValidWithoutYMissingA = new MarcRecord({
419
+ leader: "",
420
+ fields: [
421
+ {
422
+ tag: "242",
423
+ ind1: " ",
424
+ ind2: " ",
425
+ subfields: [{ code: "a", value: "World of art" }]
426
+ }
427
+ ]
428
+ });
429
+ it("Finds record invalid - No punc at $a (only before $y)", async () => {
430
+ const validator = await validatorFactory();
431
+ const result = await validator.validate(recordInvalidOnlyAMissingA);
432
+ assert.deepEqual(result, {
433
+ message: ["Field 242 requires ending punctuation, ends in 't'"],
434
+ valid: false
435
+ });
436
+ });
437
+ it("Finds record invalid - Punc at $y (Language field)", async () => {
438
+ const validator = await validatorFactory();
439
+ const result = await validator.validate(recordInvalidOnlyAPuncY);
440
+ assert.deepEqual(result, {
441
+ message: ["Field 242 has unwanted ending punctuation '.'"],
442
+ valid: false
443
+ });
444
+ });
445
+ it("Finds record invalid - No punc at $a & punc $y", async () => {
446
+ const validator = await validatorFactory();
447
+ const result = await validator.validate(recordInvalidOnlyAMissingAPuncY);
448
+ assert.deepEqual(result, {
449
+ message: ["Field 242 has unwanted ending punctuation '.'", "Field 242 requires ending punctuation, ends in 't'"],
450
+ valid: false
451
+ });
452
+ });
453
+ it("Finds record invalid - No punc $p (last before $y)", async () => {
454
+ const validator = await validatorFactory();
455
+ const result = await validator.validate(recordValidMultipleMissingP);
456
+ assert.deepEqual(result, {
457
+ message: ["Field 242 requires ending punctuation, ends in 'y'"],
458
+ valid: false
459
+ });
460
+ });
461
+ it("Finds record invalid - No punc $a (only)", async () => {
462
+ const validator = await validatorFactory();
463
+ const result = await validator.validate(recordValidWithoutYMissingA);
464
+ assert.deepEqual(result, {
465
+ message: ["Field 242 requires ending punctuation, ends in 't'"],
466
+ valid: false
467
+ });
468
+ });
469
+ it("Repairs the invalid record - Add punc $a", async () => {
470
+ const validator = await validatorFactory();
471
+ const result = await validator.fix(recordInvalidOnlyAMissingA);
472
+ assert.equal(recordInvalidOnlyAMissingA.equalsTo(recordValidOnlyA), true);
473
+ assert.deepEqual(result, {
474
+ message: ["Field 242 requires ending punctuation, ends in 't'"],
475
+ fix: ["Field 242 - Added punctuation to $a"],
476
+ valid: false
477
+ });
478
+ });
479
+ it("Repairs the invalid record - Remove punc $y (Language field)", async () => {
480
+ const validator = await validatorFactory();
481
+ const result = await validator.fix(recordInvalidOnlyAPuncY);
482
+ assert.equal(recordInvalidOnlyAPuncY.equalsTo(recordValidOnlyA), true);
483
+ assert.deepEqual(result, {
484
+ message: ["Field 242 has unwanted ending punctuation '.'"],
485
+ fix: ["Field 242 - Removed punctuation from $y"],
486
+ valid: false
487
+ });
488
+ });
489
+ it("Repairs the invalid record - Add punc $a & remove punc $y (Language field)", async () => {
490
+ const validator = await validatorFactory();
491
+ const result = await validator.fix(recordInvalidOnlyAMissingAPuncY);
492
+ assert.equal(recordInvalidOnlyAMissingAPuncY.equalsTo(recordValidOnlyA), true);
493
+ assert.deepEqual(result, {
494
+ message: ["Field 242 has unwanted ending punctuation '.'", "Field 242 requires ending punctuation, ends in 't'"],
495
+ fix: ["Field 242 - Removed punctuation from $y", "Field 242 - Added punctuation to $a"],
496
+ valid: false
497
+ });
498
+ });
499
+ it("Repairs the invalid record - Add punc $p", async () => {
500
+ const validator = await validatorFactory();
501
+ const result = await validator.fix(recordValidMultipleMissingP);
502
+ assert.equal(recordValidMultipleMissingP.equalsTo(recordValidMultiple), true);
503
+ assert.deepEqual(result, {
504
+ message: ["Field 242 requires ending punctuation, ends in 'y'"],
505
+ fix: ["Field 242 - Added punctuation to $p"],
506
+ valid: false
507
+ });
508
+ });
509
+ it("Repairs the invalid record - Add punc $a", async () => {
510
+ const validator = await validatorFactory();
511
+ const result = await validator.fix(recordValidWithoutYMissingA);
512
+ assert.equal(recordValidWithoutYMissingA.equalsTo(recordValidWithoutY), true);
513
+ assert.deepEqual(result, {
514
+ message: ["Field 242 requires ending punctuation, ends in 't'"],
515
+ fix: ["Field 242 - Added punctuation to $a"],
516
+ valid: false
517
+ });
518
+ });
519
+ });
520
+ describe("#260 TRUE - Punc only if last subfield c", () => {
521
+ const recordValidEndC = new MarcRecord({
522
+ leader: "",
523
+ fields: [
524
+ {
525
+ tag: "260",
526
+ ind1: " ",
527
+ ind2: " ",
528
+ subfields: [
529
+ { code: "a", value: "Helsinki" },
530
+ { code: "b", value: "Suomen atk-kustannus," },
531
+ { code: "c", value: "1982." }
532
+ ]
533
+ }
534
+ ]
535
+ });
536
+ const recordValidEndG = new MarcRecord({
537
+ leader: "",
538
+ fields: [
539
+ {
540
+ tag: "260",
541
+ ind1: " ",
542
+ ind2: " ",
543
+ subfields: [
544
+ { code: "a", value: "London" },
545
+ { code: "b", value: "Macmillan," },
546
+ { code: "c", value: "1971" },
547
+ { code: "g", value: "(1973 printing)" }
548
+ ]
549
+ }
550
+ ]
551
+ });
552
+ const recordValidEndB = new MarcRecord({
553
+ leader: "",
554
+ fields: [
555
+ {
556
+ tag: "260",
557
+ ind1: " ",
558
+ ind2: " ",
559
+ subfields: [
560
+ { code: "3", value: "June 1993-" },
561
+ { code: "a", value: "London" },
562
+ { code: "b", value: "Elle" }
563
+ ]
564
+ }
565
+ ]
566
+ });
567
+ it("Finds record valid - Punc $c", async () => {
568
+ const validator = await validatorFactory();
569
+ const result = await validator.validate(recordValidEndC);
570
+ assert.equal(result.valid, true);
571
+ });
572
+ it("Finds record valid - Punc char $g (after $c)", async () => {
573
+ const validator = await validatorFactory();
574
+ const result = await validator.validate(recordValidEndG);
575
+ assert.equal(result.valid, true);
576
+ });
577
+ it("Finds record valid - No punc $b", async () => {
578
+ const validator = await validatorFactory();
579
+ const result = await validator.validate(recordValidEndB);
580
+ assert.equal(result.valid, true);
581
+ });
582
+ const recordInvalidEndC = new MarcRecord({
583
+ leader: "",
584
+ fields: [
585
+ {
586
+ tag: "260",
587
+ ind1: " ",
588
+ ind2: " ",
589
+ subfields: [
590
+ { code: "a", value: "Helsinki" },
591
+ { code: "b", value: "Suomen atk-kustannus," },
592
+ { code: "c", value: "1982" }
593
+ ]
594
+ }
595
+ ]
596
+ });
597
+ const recordInvalidEndGDouble = new MarcRecord({
598
+ leader: "",
599
+ fields: [
600
+ {
601
+ tag: "260",
602
+ ind1: " ",
603
+ ind2: " ",
604
+ subfields: [
605
+ { code: "a", value: "London" },
606
+ { code: "b", value: "Macmillan," },
607
+ { code: "c", value: "1971" },
608
+ { code: "g", value: "(1973 printing)." }
609
+ ]
610
+ }
611
+ ]
612
+ });
613
+ it("Finds record invalid", async () => {
614
+ const validator = await validatorFactory();
615
+ const result = await validator.validate(recordInvalidEndC);
616
+ assert.deepEqual(result, {
617
+ message: ["Field 260 requires ending punctuation, ends in '2'"],
618
+ valid: false
619
+ });
620
+ });
621
+ it("Finds record invalid", async () => {
622
+ const validator = await validatorFactory();
623
+ const result = await validator.validate(recordInvalidEndGDouble);
624
+ assert.deepEqual(result, {
625
+ message: ["Field 260 has an extra dot after ')'"],
626
+ valid: false
627
+ });
628
+ });
629
+ it("Repairs the invalid record - Add punc $c", async () => {
630
+ const validator = await validatorFactory();
631
+ const result = await validator.fix(recordInvalidEndC);
632
+ assert.equal(recordInvalidEndC.equalsTo(recordValidEndC), true);
633
+ assert.deepEqual(result, {
634
+ message: ["Field 260 requires ending punctuation, ends in '2'"],
635
+ fix: ["Field 260 - Added punctuation to $c"],
636
+ valid: false
637
+ });
638
+ });
639
+ it("Repairs the invalid record - Remove double punc $g", async () => {
640
+ const validator = await validatorFactory();
641
+ const result = await validator.fix(recordInvalidEndGDouble);
642
+ assert.equal(recordInvalidEndGDouble.equalsTo(recordValidEndG), true);
643
+ assert.deepEqual(result, {
644
+ message: ["Field 260 has an extra dot after ')'"],
645
+ fix: ["Field 260 - Removed dot after punctuation from $g"],
646
+ valid: false
647
+ });
648
+ });
649
+ });
650
+ describe("#264 TRUE - If ind2 === 0, 1, 2 or 3, punc at the end", () => {
651
+ const recordValidInd2v1 = new MarcRecord({
652
+ leader: "",
653
+ fields: [
654
+ {
655
+ tag: "264",
656
+ ind1: "#",
657
+ ind2: "1",
658
+ subfields: [
659
+ { code: "a", value: "Helsinki" },
660
+ { code: "b", value: "Helsingin yliopisto" },
661
+ { code: "c", value: "1995-2006." }
662
+ ]
663
+ }
664
+ ]
665
+ });
666
+ const recordValidInd2v1Short = new MarcRecord({
667
+ leader: "",
668
+ fields: [
669
+ {
670
+ tag: "264",
671
+ ind1: "#",
672
+ ind2: "1",
673
+ subfields: [
674
+ { code: "a", value: "Helsinki" },
675
+ { code: "b", value: "Helsingin yliopisto" },
676
+ { code: "c", value: "1995-" }
677
+ ]
678
+ }
679
+ ]
680
+ });
681
+ const recordValidInd2v2WithoutC = new MarcRecord({
682
+ leader: "",
683
+ fields: [
684
+ {
685
+ tag: "264",
686
+ ind1: "#",
687
+ ind2: "2",
688
+ subfields: [
689
+ { code: "a", value: "Kouvola" },
690
+ { code: "b", value: "Nuorisovirasto" }
691
+ ]
692
+ }
693
+ ]
694
+ });
695
+ const recordValidCopyright = new MarcRecord({
696
+ leader: "",
697
+ fields: [
698
+ {
699
+ tag: "264",
700
+ ind1: " ",
701
+ ind2: "4",
702
+ subfields: [
703
+ { code: "a", value: "Helsinki : " },
704
+ { code: "b", value: "Suomen poliisikoirayhdistys." },
705
+ { code: "c", value: "\xA9 1974" }
706
+ ]
707
+ }
708
+ ]
709
+ });
710
+ it("Finds record valid - Ind2 = 1, $c 1995-2006.", async () => {
711
+ const validator = await validatorFactory();
712
+ const result = await validator.validate(recordValidInd2v1);
713
+ assert.equal(result.valid, true);
714
+ });
715
+ it("Finds record valid - Ind2 = 1, $c 1995-", async () => {
716
+ const validator = await validatorFactory();
717
+ const result = await validator.validate(recordValidInd2v1Short);
718
+ assert.equal(result.valid, true);
719
+ });
720
+ it("Finds record valid - Ind2 = 2, no $c", async () => {
721
+ const validator = await validatorFactory();
722
+ const result = await validator.validate(recordValidInd2v2WithoutC);
723
+ assert.equal(result.valid, true);
724
+ });
725
+ it("Finds record valid - Ind2 = 4, copyright", async () => {
726
+ const validator = await validatorFactory();
727
+ const result = await validator.validate(recordValidCopyright);
728
+ assert.equal(result.valid, true);
729
+ });
730
+ const recordInvalidInd2v1 = new MarcRecord({
731
+ leader: "",
732
+ fields: [
733
+ {
734
+ tag: "264",
735
+ ind1: "#",
736
+ ind2: "1",
737
+ subfields: [
738
+ { code: "a", value: "Helsinki" },
739
+ { code: "b", value: "Helsingin yliopisto" },
740
+ { code: "c", value: "1995-2006" }
741
+ ]
742
+ }
743
+ ]
744
+ });
745
+ const recordInvalidCopyrightCExtra = new MarcRecord({
746
+ leader: "",
747
+ fields: [
748
+ {
749
+ tag: "264",
750
+ ind1: " ",
751
+ ind2: "4",
752
+ subfields: [
753
+ { code: "a", value: "Helsinki : " },
754
+ { code: "b", value: "Suomen poliisikoirayhdistys." },
755
+ { code: "c", value: "\xA9 1974." }
756
+ ]
757
+ }
758
+ ]
759
+ });
760
+ it("Finds record invalid - No punc $c", async () => {
761
+ const validator = await validatorFactory();
762
+ const result = await validator.validate(recordInvalidInd2v1);
763
+ assert.deepEqual(result, {
764
+ message: ["Field 264 requires ending punctuation, ends in '6'"],
765
+ valid: false
766
+ });
767
+ });
768
+ it("Finds record invalid - Ind2 = 4, copyright, extra punc $c", async () => {
769
+ const validator = await validatorFactory();
770
+ const result = await validator.validate(recordInvalidCopyrightCExtra);
771
+ assert.deepEqual(result, {
772
+ message: ["Field 264 has unwanted ending punctuation '.'"],
773
+ valid: false
774
+ });
775
+ });
776
+ it("Repairs the invalid record - Add punc $c", async () => {
777
+ const validator = await validatorFactory();
778
+ const result = await validator.fix(recordInvalidInd2v1);
779
+ assert.equal(recordInvalidInd2v1.equalsTo(recordValidInd2v1), true);
780
+ assert.deepEqual(result, {
781
+ message: ["Field 264 requires ending punctuation, ends in '6'"],
782
+ fix: ["Field 264 - Added punctuation to $c"],
783
+ valid: false
784
+ });
785
+ });
786
+ it("Repairs the invalid record - Remove punc $c ($c has \xA9, should not have punc)", async () => {
787
+ const validator = await validatorFactory();
788
+ const result = await validator.fix(recordInvalidCopyrightCExtra);
789
+ assert.equal(recordInvalidCopyrightCExtra.equalsTo(recordValidCopyright), true);
790
+ assert.deepEqual(result, {
791
+ message: ["Field 264 has unwanted ending punctuation '.'"],
792
+ fix: ["Field 264 - Removed punctuation from $c"],
793
+ valid: false
794
+ });
795
+ });
796
+ });
797
+ describe("#340 TRUE - Punc at $b always and to last of [$a, $d, $e, $f, $h, $i]", () => {
798
+ const recordValidA = new MarcRecord({
799
+ leader: "",
800
+ fields: [
801
+ {
802
+ tag: "340",
803
+ ind1: " ",
804
+ ind2: " ",
805
+ subfields: [{ code: "a", value: "marble." }]
806
+ }
807
+ ]
808
+ });
809
+ const recordValidAB = new MarcRecord({
810
+ leader: "",
811
+ fields: [
812
+ {
813
+ tag: "340",
814
+ ind1: " ",
815
+ ind2: " ",
816
+ subfields: [
817
+ { code: "a", value: "parchment." },
818
+ // This punc doesn't match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/3XX.htm#340
819
+ { code: "b", value: "20 cm. folded to 10 x 12 cm." }
820
+ ]
821
+ }
822
+ ]
823
+ });
824
+ const recordValidDD = new MarcRecord({
825
+ leader: "",
826
+ fields: [
827
+ {
828
+ tag: "340",
829
+ ind1: " ",
830
+ ind2: " ",
831
+ subfields: [
832
+ { code: "d", value: "handwritten" },
833
+ { code: "d", value: "typed." }
834
+ ]
835
+ }
836
+ ]
837
+ });
838
+ const recordValidComplex = new MarcRecord({
839
+ leader: "",
840
+ fields: [
841
+ {
842
+ tag: "340",
843
+ ind1: " ",
844
+ ind2: " ",
845
+ subfields: [
846
+ { code: "a", value: "wove paper" },
847
+ { code: "c", value: "ink" },
848
+ { code: "c", value: "gouache" },
849
+ { code: "d", value: "lithography" },
850
+ { code: "d", value: "collage." },
851
+ // This punc doesn't match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/3XX.htm#340
852
+ { code: "g", value: "polychrome" }
853
+ ]
854
+ }
855
+ ]
856
+ });
857
+ const recordValidJ2 = new MarcRecord({
858
+ leader: "",
859
+ fields: [
860
+ {
861
+ tag: "340",
862
+ ind1: " ",
863
+ ind2: " ",
864
+ subfields: [
865
+ { code: "j", value: "original" },
866
+ { code: "2", value: "rda" }
867
+ ]
868
+ }
869
+ ]
870
+ });
871
+ it("Finds record valid - Punc $a (only)", async () => {
872
+ const validator = await validatorFactory();
873
+ const result = await validator.validate(recordValidA);
874
+ assert.equal(result.valid, true);
875
+ });
876
+ it("Finds record valid - Punc $a (last) & punc $b (mandatory)", async () => {
877
+ const validator = await validatorFactory();
878
+ const result = await validator.validate(recordValidAB);
879
+ assert.equal(result.valid, true);
880
+ });
881
+ it("Finds record valid - Punc $d (last of two)", async () => {
882
+ const validator = await validatorFactory();
883
+ const result = await validator.validate(recordValidDD);
884
+ assert.equal(result.valid, true);
885
+ });
886
+ it("Finds record valid - Punc $d (last of two) followed by $g", async () => {
887
+ const validator = await validatorFactory();
888
+ const result = await validator.validate(recordValidComplex);
889
+ assert.equal(result.valid, true);
890
+ });
891
+ it("Finds record valid - No punc (not $b, nor from list)", async () => {
892
+ const validator = await validatorFactory();
893
+ const result = await validator.validate(recordValidJ2);
894
+ assert.equal(result.valid, true);
895
+ });
896
+ const recordInvalidA = new MarcRecord({
897
+ leader: "",
898
+ fields: [
899
+ {
900
+ tag: "340",
901
+ ind1: " ",
902
+ ind2: " ",
903
+ subfields: [{ code: "a", value: "marble" }]
904
+ }
905
+ ]
906
+ });
907
+ const recordInvalidAMissingB = new MarcRecord({
908
+ leader: "",
909
+ fields: [
910
+ {
911
+ tag: "340",
912
+ ind1: " ",
913
+ ind2: " ",
914
+ subfields: [
915
+ { code: "a", value: "parchment" },
916
+ // This punc doesn't match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/3XX.htm#340
917
+ { code: "b", value: "20 cm. folded to 10 x 12 cm." }
918
+ ]
919
+ }
920
+ ]
921
+ });
922
+ const recordInvalidABMissing = new MarcRecord({
923
+ leader: "",
924
+ fields: [
925
+ {
926
+ tag: "340",
927
+ ind1: " ",
928
+ ind2: " ",
929
+ subfields: [
930
+ { code: "a", value: "parchment." },
931
+ // This punc doesn't match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/3XX.htm#340
932
+ { code: "b", value: "20 cm. folded to 10 x 12 cm" }
933
+ ]
934
+ }
935
+ ]
936
+ });
937
+ const recordInvalidDDMissing = new MarcRecord({
938
+ leader: "",
939
+ fields: [
940
+ {
941
+ tag: "340",
942
+ ind1: " ",
943
+ ind2: " ",
944
+ subfields: [
945
+ { code: "d", value: "handwritten" },
946
+ { code: "d", value: "typed" }
947
+ ]
948
+ }
949
+ ]
950
+ });
951
+ const recordInvalidComplexDMissing = new MarcRecord({
952
+ leader: "",
953
+ fields: [
954
+ {
955
+ tag: "340",
956
+ ind1: " ",
957
+ ind2: " ",
958
+ subfields: [
959
+ { code: "a", value: "wove paper" },
960
+ { code: "c", value: "ink" },
961
+ { code: "c", value: "gouache" },
962
+ { code: "d", value: "lithography" },
963
+ { code: "d", value: "collage" },
964
+ // This punc doesn't match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/3XX.htm#340
965
+ { code: "g", value: "polychrome" }
966
+ ]
967
+ }
968
+ ]
969
+ });
970
+ it("Finds record invalid - No punc $a (only)", async () => {
971
+ const validator = await validatorFactory();
972
+ const result = await validator.validate(recordInvalidA);
973
+ assert.deepEqual(result, {
974
+ message: ["Field 340 requires ending punctuation, ends in 'e'"],
975
+ valid: false
976
+ });
977
+ });
978
+ it("Finds record invalid - No punc $a (last)", async () => {
979
+ const validator = await validatorFactory();
980
+ const result = await validator.validate(recordInvalidAMissingB);
981
+ assert.deepEqual(result, {
982
+ message: ["Field 340 requires ending punctuation, ends in 't'"],
983
+ valid: false
984
+ });
985
+ });
986
+ it("Finds record invalid - No punc $b (mandatory)", async () => {
987
+ const validator = await validatorFactory();
988
+ const result = await validator.validate(recordInvalidABMissing);
989
+ assert.deepEqual(result, {
990
+ message: ["Field 340 requires ending punctuation, ends in 'm'"],
991
+ valid: false
992
+ });
993
+ });
994
+ it("Finds record invalid - No punc $d (last of two)", async () => {
995
+ const validator = await validatorFactory();
996
+ const result = await validator.validate(recordInvalidDDMissing);
997
+ assert.deepEqual(result, {
998
+ message: ["Field 340 requires ending punctuation, ends in 'd'"],
999
+ valid: false
1000
+ });
1001
+ });
1002
+ it("Finds record invalid - No punc $d (last of two) followed by $g", async () => {
1003
+ const validator = await validatorFactory();
1004
+ const result = await validator.validate(recordInvalidComplexDMissing);
1005
+ assert.deepEqual(result, {
1006
+ message: ["Field 340 requires ending punctuation, ends in 'e'"],
1007
+ valid: false
1008
+ });
1009
+ });
1010
+ it("Repairs the invalid record - Add punc $a (only)", async () => {
1011
+ const validator = await validatorFactory();
1012
+ const result = await validator.fix(recordInvalidA);
1013
+ assert.equal(recordInvalidA.equalsTo(recordInvalidA), true);
1014
+ assert.deepEqual(result, {
1015
+ message: ["Field 340 requires ending punctuation, ends in 'e'"],
1016
+ fix: ["Field 340 - Added punctuation to $a"],
1017
+ valid: false
1018
+ });
1019
+ });
1020
+ it("Repairs the invalid record - Add punc $a (last)", async () => {
1021
+ const validator = await validatorFactory();
1022
+ const result = await validator.fix(recordInvalidAMissingB);
1023
+ assert.equal(recordInvalidAMissingB.equalsTo(recordValidAB), true);
1024
+ assert.deepEqual(result, {
1025
+ message: ["Field 340 requires ending punctuation, ends in 't'"],
1026
+ fix: ["Field 340 - Added punctuation to $a"],
1027
+ valid: false
1028
+ });
1029
+ });
1030
+ it("Repairs the invalid record - Add punc $b (mandatory)", async () => {
1031
+ const validator = await validatorFactory();
1032
+ const result = await validator.fix(recordInvalidABMissing);
1033
+ assert.equal(recordInvalidABMissing.equalsTo(recordValidAB), true);
1034
+ assert.deepEqual(result, {
1035
+ message: ["Field 340 requires ending punctuation, ends in 'm'"],
1036
+ fix: ["Field 340 - Added punctuation to $b"],
1037
+ valid: false
1038
+ });
1039
+ });
1040
+ it("Repairs the invalid record - Add punc $d (last of two)", async () => {
1041
+ const validator = await validatorFactory();
1042
+ const result = await validator.fix(recordInvalidDDMissing);
1043
+ assert.equal(recordInvalidDDMissing.equalsTo(recordValidDD), true);
1044
+ assert.deepEqual(result, {
1045
+ message: ["Field 340 requires ending punctuation, ends in 'd'"],
1046
+ fix: ["Field 340 - Added punctuation to $d"],
1047
+ valid: false
1048
+ });
1049
+ });
1050
+ it("Repairs the invalid record - Add punc $d (last of list)", async () => {
1051
+ const validator = await validatorFactory();
1052
+ const result = await validator.fix(recordInvalidComplexDMissing);
1053
+ assert.equal(recordInvalidComplexDMissing.equalsTo(recordInvalidComplexDMissing), true);
1054
+ assert.deepEqual(result, {
1055
+ message: ["Field 340 requires ending punctuation, ends in 'e'"],
1056
+ fix: ["Field 340 - Added punctuation to $d"],
1057
+ valid: false
1058
+ });
1059
+ });
1060
+ });
1061
+ describe("#520 TRUE - If last subfield $u, punc before it", () => {
1062
+ const recordValid = new MarcRecord({
1063
+ leader: "",
1064
+ fields: [
1065
+ {
1066
+ tag: "520",
1067
+ ind1: " ",
1068
+ ind2: " ",
1069
+ subfields: [{ code: "a", value: "Mediav\xE4kivalta ja sen yleis\xF6." }]
1070
+ }
1071
+ ]
1072
+ });
1073
+ const recordValidWithU = new MarcRecord({
1074
+ leader: "",
1075
+ fields: [
1076
+ {
1077
+ tag: "520",
1078
+ ind1: " ",
1079
+ ind2: " ",
1080
+ subfields: [
1081
+ { code: "a", value: "Abstrakti." },
1082
+ // This does not match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/50X-53X.htm#520
1083
+ { code: "u", value: "http://www.ojp.usdoj.gov/bjs/abstract/cchrie98.htm" }
1084
+ ]
1085
+ }
1086
+ ]
1087
+ });
1088
+ const recordValidU = new MarcRecord({
1089
+ leader: "",
1090
+ fields: [
1091
+ {
1092
+ tag: "520",
1093
+ ind1: " ",
1094
+ ind2: " ",
1095
+ subfields: [
1096
+ { code: "a", value: "Abstrakti." },
1097
+ // This does not match example: https://www.kansalliskirjasto.fi/extra/marc21/bib/50X-53X.htm#520
1098
+ { code: "u", value: "http://www.ojp.usdoj.gov/bjs/abstract/cchrie98.htm." }
1099
+ ]
1100
+ }
1101
+ ]
1102
+ });
1103
+ it("Finds record valid - Punc $a (without $u)", async () => {
1104
+ const validator = await validatorFactory();
1105
+ const result = await validator.validate(recordValid);
1106
+ assert.equal(result.valid, true);
1107
+ });
1108
+ it("Finds record valid - Punc $a (with $u) ", async () => {
1109
+ const validator = await validatorFactory();
1110
+ const result = await validator.validate(recordValidWithU);
1111
+ assert.equal(result.valid, true);
1112
+ });
1113
+ it("Finds record valid - Punc $a & $u (punc at $u should be ignored) ", async () => {
1114
+ const validator = await validatorFactory();
1115
+ const result = await validator.validate(recordValidU);
1116
+ assert.equal(result.valid, true);
1117
+ });
1118
+ const recordInvalid = new MarcRecord({
1119
+ leader: "",
1120
+ fields: [
1121
+ {
1122
+ tag: "520",
1123
+ ind1: " ",
1124
+ ind2: " ",
1125
+ subfields: [{ code: "a", value: "Mediav\xE4kivalta ja sen yleis\xF6" }]
1126
+ }
1127
+ ]
1128
+ });
1129
+ const recordInvalidWithU = new MarcRecord({
1130
+ leader: "",
1131
+ fields: [
1132
+ {
1133
+ tag: "520",
1134
+ ind1: " ",
1135
+ ind2: " ",
1136
+ subfields: [
1137
+ { code: "a", value: "Abstrakti" },
1138
+ { code: "u", value: "http://www.ojp.usdoj.gov/bjs/abstract/cchrie98.htm" }
1139
+ ]
1140
+ }
1141
+ ]
1142
+ });
1143
+ it("Finds record invalid - No punc $a (without $u)", async () => {
1144
+ const validator = await validatorFactory();
1145
+ const result = await validator.validate(recordInvalid);
1146
+ assert.deepEqual(result, {
1147
+ message: ["Field 520 requires ending punctuation, ends in '\xF6'"],
1148
+ valid: false
1149
+ });
1150
+ });
1151
+ it("Finds record invalid - No punc $a (with $u)", async () => {
1152
+ const validator = await validatorFactory();
1153
+ const result = await validator.validate(recordInvalidWithU);
1154
+ assert.deepEqual(result, {
1155
+ message: ["Field 520 requires ending punctuation, ends in 'i'"],
1156
+ valid: false
1157
+ });
1158
+ });
1159
+ it("Repairs the invalid record - Add punc $a (only)", async () => {
1160
+ const validator = await validatorFactory();
1161
+ const result = await validator.fix(recordInvalid);
1162
+ assert.equal(recordInvalid.equalsTo(recordValid), true);
1163
+ assert.deepEqual(result, {
1164
+ message: ["Field 520 requires ending punctuation, ends in '\xF6'"],
1165
+ fix: ["Field 520 - Added punctuation to $a"],
1166
+ valid: false
1167
+ });
1168
+ });
1169
+ it("Repairs the invalid record - Add punc $a (last before $u)", async () => {
1170
+ const validator = await validatorFactory();
1171
+ const result = await validator.fix(recordInvalidWithU);
1172
+ assert.equal(recordInvalidWithU.equalsTo(recordValidWithU), true);
1173
+ assert.deepEqual(result, {
1174
+ message: ["Field 520 requires ending punctuation, ends in 'i'"],
1175
+ fix: ["Field 520 - Added punctuation to $a"],
1176
+ valid: false
1177
+ });
1178
+ });
1179
+ });
1180
+ describe("#538 TRUE - If last subfield $u, punc before it", () => {
1181
+ const recordValid = new MarcRecord({
1182
+ leader: "",
1183
+ fields: [
1184
+ {
1185
+ tag: "538",
1186
+ ind1: " ",
1187
+ ind2: " ",
1188
+ subfields: [
1189
+ { code: "a", value: "Project methodology for digital version" },
1190
+ { code: "i", value: "Technical details." },
1191
+ // This ended to ':' in examples, but it doesn't match statet rules: https://www.kansalliskirjasto.fi/extra/marc21/bib/53X-58X.htm#538
1192
+ { code: "u", value: "http://www.columbia.edu/dlc/linglung/methodology.html" }
1193
+ ]
1194
+ }
1195
+ ]
1196
+ });
1197
+ const recordValidPuncU = new MarcRecord({
1198
+ leader: "",
1199
+ fields: [
1200
+ {
1201
+ tag: "538",
1202
+ ind1: " ",
1203
+ ind2: " ",
1204
+ subfields: [
1205
+ { code: "a", value: "Project methodology for digital version" },
1206
+ { code: "i", value: "Technical details." },
1207
+ { code: "u", value: "http://www.columbia.edu/dlc/linglung/methodology.html." }
1208
+ ]
1209
+ }
1210
+ ]
1211
+ });
1212
+ const recordValidOnlyA = new MarcRecord({
1213
+ leader: "",
1214
+ fields: [
1215
+ {
1216
+ tag: "538",
1217
+ ind1: " ",
1218
+ ind2: " ",
1219
+ subfields: [{ code: "a", value: "SECAM-videolaite." }]
1220
+ }
1221
+ ]
1222
+ });
1223
+ it("Finds record valid - Punc $i (last before $u)", async () => {
1224
+ const validator = await validatorFactory();
1225
+ const result = await validator.validate(recordValid);
1226
+ assert.equal(result.valid, true);
1227
+ });
1228
+ it("Finds record valid - Punc $i & punc $u ($u is URL, should pass)", async () => {
1229
+ const validator = await validatorFactory();
1230
+ const result = await validator.validate(recordValidPuncU);
1231
+ assert.equal(result.valid, true);
1232
+ });
1233
+ it("Finds record valid - Punc $a (only)", async () => {
1234
+ const validator = await validatorFactory();
1235
+ const result = await validator.validate(recordValidOnlyA);
1236
+ assert.equal(result.valid, true);
1237
+ });
1238
+ const recordInvalidMissingI = new MarcRecord({
1239
+ leader: "",
1240
+ fields: [
1241
+ {
1242
+ tag: "538",
1243
+ ind1: " ",
1244
+ ind2: " ",
1245
+ subfields: [
1246
+ { code: "a", value: "Project methodology for digital version" },
1247
+ { code: "i", value: "Technical details" },
1248
+ { code: "u", value: "http://www.columbia.edu/dlc/linglung/methodology.html" }
1249
+ ]
1250
+ }
1251
+ ]
1252
+ });
1253
+ const recordInvalidI = new MarcRecord({
1254
+ leader: "",
1255
+ fields: [
1256
+ {
1257
+ tag: "538",
1258
+ ind1: " ",
1259
+ ind2: " ",
1260
+ subfields: [
1261
+ { code: "a", value: "Project methodology for digital version" },
1262
+ { code: "i", value: "Technical details:" },
1263
+ // This is actually like in examples, but it doesn't match statet rules: https://www.kansalliskirjasto.fi/extra/marc21/bib/53X-58X.htm#538
1264
+ { code: "u", value: "http://www.columbia.edu/dlc/linglung/methodology.html" }
1265
+ ]
1266
+ }
1267
+ ]
1268
+ });
1269
+ const recordInvalidOnlyA = new MarcRecord({
1270
+ leader: "",
1271
+ fields: [
1272
+ {
1273
+ tag: "538",
1274
+ ind1: " ",
1275
+ ind2: " ",
1276
+ subfields: [{ code: "a", value: "SECAM-videolaite" }]
1277
+ }
1278
+ ]
1279
+ });
1280
+ it("Finds record invalid - No punc $i (last before $u)", async () => {
1281
+ const validator = await validatorFactory();
1282
+ const result = await validator.validate(recordInvalidMissingI);
1283
+ assert.deepEqual(result, {
1284
+ message: ["Field 538 requires ending punctuation, ends in 's'"],
1285
+ valid: false
1286
+ });
1287
+ });
1288
+ it('Finds record invalid - Invalid punc $i (":" not valid punc mark, but this is according example...)', async () => {
1289
+ const validator = await validatorFactory();
1290
+ const result = await validator.validate(recordInvalidI);
1291
+ assert.deepEqual(result, {
1292
+ message: ["Field 538 requires ending punctuation, ends in ':'"],
1293
+ valid: false
1294
+ });
1295
+ });
1296
+ it("Finds record invalid - No punc $a (only)", async () => {
1297
+ const validator = await validatorFactory();
1298
+ const result = await validator.validate(recordInvalidOnlyA);
1299
+ assert.deepEqual(result, {
1300
+ message: ["Field 538 requires ending punctuation, ends in 'e'"],
1301
+ valid: false
1302
+ });
1303
+ });
1304
+ it("Repairs the invalid record - Add punc $i (last)", async () => {
1305
+ const validator = await validatorFactory();
1306
+ const result = await validator.fix(recordInvalidMissingI);
1307
+ assert.equal(recordInvalidMissingI.equalsTo(recordValid), true);
1308
+ assert.deepEqual(result, {
1309
+ message: ["Field 538 requires ending punctuation, ends in 's'"],
1310
+ fix: ["Field 538 - Added punctuation to $i"],
1311
+ valid: false
1312
+ });
1313
+ });
1314
+ it("Repairs the invalid record - Add punc $a (only)", async () => {
1315
+ const validator = await validatorFactory();
1316
+ const result = await validator.fix(recordInvalidOnlyA);
1317
+ assert.equal(recordInvalidOnlyA.equalsTo(recordValidOnlyA), true);
1318
+ assert.deepEqual(result, {
1319
+ message: ["Field 538 requires ending punctuation, ends in 'e'"],
1320
+ fix: ["Field 538 - Added punctuation to $a"],
1321
+ valid: false
1322
+ });
1323
+ });
1324
+ });
1325
+ describe("#567 TRUE - After subfield $a, FALSE after others", () => {
1326
+ const recordValid = new MarcRecord({
1327
+ leader: "",
1328
+ fields: [
1329
+ {
1330
+ tag: "567",
1331
+ ind1: " ",
1332
+ ind2: " ",
1333
+ subfields: [{ code: "a", value: "Narratiivinen tutkimus." }]
1334
+ }
1335
+ ]
1336
+ });
1337
+ const recordValidWithoutA = new MarcRecord({
1338
+ leader: "",
1339
+ fields: [
1340
+ {
1341
+ tag: "567",
1342
+ ind1: " ",
1343
+ ind2: " ",
1344
+ subfields: [
1345
+ { code: "b", value: "Narrative inquiry" },
1346
+ { code: "2", value: "lcsh" }
1347
+ ]
1348
+ }
1349
+ ]
1350
+ });
1351
+ it("Finds record valid - Punc $a (only)", async () => {
1352
+ const validator = await validatorFactory();
1353
+ const result = await validator.validate(recordValid);
1354
+ assert.equal(result.valid, true);
1355
+ });
1356
+ it("Finds record valid - No punc $b (only data field)", async () => {
1357
+ const validator = await validatorFactory();
1358
+ const result = await validator.validate(recordValidWithoutA);
1359
+ assert.equal(result.valid, true);
1360
+ });
1361
+ const recordInvalid = new MarcRecord({
1362
+ leader: "",
1363
+ fields: [
1364
+ {
1365
+ tag: "567",
1366
+ ind1: " ",
1367
+ ind2: " ",
1368
+ subfields: [{ code: "a", value: "Narratiivinen tutkimus" }]
1369
+ }
1370
+ ]
1371
+ });
1372
+ const recordInvalidWithoutA = new MarcRecord({
1373
+ leader: "",
1374
+ fields: [
1375
+ {
1376
+ tag: "567",
1377
+ ind1: " ",
1378
+ ind2: " ",
1379
+ subfields: [
1380
+ { code: "b", value: "Narrative inquiry." },
1381
+ { code: "2", value: "lcsh" }
1382
+ ]
1383
+ }
1384
+ ]
1385
+ });
1386
+ it("Finds record invalid - No punc $a (only)", async () => {
1387
+ const validator = await validatorFactory();
1388
+ const result = await validator.validate(recordInvalid);
1389
+ assert.deepEqual(result, {
1390
+ message: ["Field 567 requires ending punctuation, ends in 's'"],
1391
+ valid: false
1392
+ });
1393
+ });
1394
+ it("Finds record invalid - Punc $b (only data field)", async () => {
1395
+ const validator = await validatorFactory();
1396
+ const result = await validator.validate(recordInvalidWithoutA);
1397
+ assert.deepEqual(result, {
1398
+ message: ["Field 567 has unwanted ending punctuation '.'"],
1399
+ valid: false
1400
+ });
1401
+ });
1402
+ it("Repairs the invalid record - Add punc $a (only)", async () => {
1403
+ const validator = await validatorFactory();
1404
+ const result = await validator.fix(recordInvalid);
1405
+ assert.equal(recordInvalid.equalsTo(recordValid), true);
1406
+ assert.deepEqual(result, {
1407
+ message: ["Field 567 requires ending punctuation, ends in 's'"],
1408
+ fix: ["Field 567 - Added punctuation to $a"],
1409
+ valid: false
1410
+ });
1411
+ });
1412
+ it("Repairs the invalid record - Remove punc $b (only data field)", async () => {
1413
+ const validator = await validatorFactory();
1414
+ const result = await validator.fix(recordInvalidWithoutA);
1415
+ assert.equal(recordInvalidWithoutA.equalsTo(recordValidWithoutA), true);
1416
+ assert.deepEqual(result, {
1417
+ message: ["Field 567 has unwanted ending punctuation '.'"],
1418
+ fix: ["Field 567 - Removed punctuation from $b"],
1419
+ valid: false
1420
+ });
1421
+ });
1422
+ });
1423
+ describe("#647-651 FALSE - If Finnish, else TRUE", () => {
1424
+ const recordValid647FastEndPunc = new MarcRecord({
1425
+ leader: "",
1426
+ fields: [
1427
+ {
1428
+ tag: "647",
1429
+ ind1: " ",
1430
+ ind2: "7",
1431
+ subfields: [
1432
+ { code: "a", value: "Hurricane Katrina" },
1433
+ { code: "d", value: "(2005)" },
1434
+ { code: "2", value: "fast" }
1435
+ ]
1436
+ }
1437
+ ]
1438
+ });
1439
+ const recordValid648FinNo = new MarcRecord({
1440
+ leader: "",
1441
+ fields: [
1442
+ {
1443
+ tag: "648",
1444
+ ind1: " ",
1445
+ ind2: "7",
1446
+ subfields: [
1447
+ { code: "a", value: "1900-luku" },
1448
+ { code: "2", value: "yso/swe" }
1449
+ ]
1450
+ },
1451
+ {
1452
+ // Exception: term ending in dot:
1453
+ tag: "648",
1454
+ ind1: " ",
1455
+ ind2: "7",
1456
+ subfields: [
1457
+ { code: "a", value: "1200-luku eaa." },
1458
+ { code: "2", value: "yso/fin" },
1459
+ { code: "0", value: "http://www.yso.fi/onto/yso/p1129911200" }
1460
+ ]
1461
+ }
1462
+ ]
1463
+ });
1464
+ const recordValid648FastNo = new MarcRecord({
1465
+ leader: "",
1466
+ fields: [
1467
+ {
1468
+ tag: "648",
1469
+ ind1: " ",
1470
+ ind2: "7",
1471
+ subfields: [
1472
+ { code: "a", value: "1862" },
1473
+ { code: "2", value: "fast" }
1474
+ // https://www.kansalliskirjasto.fi/extra/marc21/bib/6XX.htm#648
1475
+ ]
1476
+ }
1477
+ ]
1478
+ });
1479
+ const recordValid650FinNo = new MarcRecord({
1480
+ leader: "",
1481
+ fields: [
1482
+ { tag: "650", ind1: " ", ind2: "7", subfields: [
1483
+ { code: "a", value: "kirjastot" },
1484
+ { code: "x", value: "atk-j\xE4rjestelm\xE4t" },
1485
+ { code: "2", value: "kauno/fin" }
1486
+ ] },
1487
+ { tag: "650", ind1: " ", ind2: "7", subfields: [
1488
+ { code: "a", value: "ajovalot" },
1489
+ { code: "2", value: "juho" }
1490
+ ] }
1491
+ ]
1492
+ });
1493
+ const recordValid650EngNoControl = new MarcRecord({
1494
+ leader: "",
1495
+ fields: [
1496
+ {
1497
+ tag: "650",
1498
+ ind1: " ",
1499
+ ind2: " ",
1500
+ subfields: [
1501
+ { code: "a", value: "Flour industry" },
1502
+ { code: "v", value: "Periodicals." }
1503
+ ]
1504
+ }
1505
+ ]
1506
+ });
1507
+ const recordValid650EngControl = new MarcRecord({
1508
+ leader: "",
1509
+ fields: [
1510
+ {
1511
+ tag: "650",
1512
+ ind1: " ",
1513
+ ind2: "7",
1514
+ subfields: [
1515
+ { code: "a", value: "Career Exploration." },
1516
+ { code: "2", value: "ericd" }
1517
+ ]
1518
+ }
1519
+ ]
1520
+ });
1521
+ it("Finds record valid - 647 Fast, punc char at end", async () => {
1522
+ const validator = await validatorFactory();
1523
+ const result = await validator.validate(recordValid647FastEndPunc);
1524
+ assert.equal(result.valid, true);
1525
+ });
1526
+ it("Finds record valid - 648 Finnish, without punc", async () => {
1527
+ const validator = await validatorFactory();
1528
+ const result = await validator.validate(recordValid648FinNo);
1529
+ assert.equal(result.valid, true);
1530
+ });
1531
+ it("Finds record valid - 648 Fast, without punc", async () => {
1532
+ const validator = await validatorFactory();
1533
+ const result = await validator.validate(recordValid648FastNo);
1534
+ assert.equal(result.valid, true);
1535
+ });
1536
+ it("Finds record valid - 650 Finnish, without punc", async () => {
1537
+ const validator = await validatorFactory();
1538
+ const result = await validator.validate(recordValid650FinNo);
1539
+ assert.equal(result.valid, true);
1540
+ });
1541
+ it("Finds record valid - 650 English, punc (no control)", async () => {
1542
+ const validator = await validatorFactory();
1543
+ const result = await validator.validate(recordValid650EngNoControl);
1544
+ assert.equal(result.valid, true);
1545
+ });
1546
+ it("Finds record valid - 650 English, with punc", async () => {
1547
+ const validator = await validatorFactory();
1548
+ const result = await validator.validate(recordValid650EngControl);
1549
+ assert.equal(result.valid, true);
1550
+ });
1551
+ const recordInvalid647FastEndPunc = new MarcRecord({
1552
+ leader: "",
1553
+ fields: [
1554
+ {
1555
+ tag: "647",
1556
+ ind1: " ",
1557
+ ind2: "7",
1558
+ subfields: [
1559
+ { code: "a", value: "Hurricane Katrina" },
1560
+ { code: "d", value: "(2005)." },
1561
+ { code: "2", value: "fast" }
1562
+ ]
1563
+ }
1564
+ ]
1565
+ });
1566
+ const recordInvalid648FinYes = new MarcRecord({
1567
+ leader: "",
1568
+ fields: [
1569
+ {
1570
+ tag: "648",
1571
+ ind1: " ",
1572
+ ind2: "7",
1573
+ subfields: [
1574
+ { code: "a", value: "1900-luku." },
1575
+ { code: "2", value: "yso/swe" }
1576
+ ]
1577
+ },
1578
+ {
1579
+ // Exception:
1580
+ tag: "648",
1581
+ ind1: " ",
1582
+ ind2: "7",
1583
+ subfields: [
1584
+ { code: "a", value: "1200-luku eaa" },
1585
+ { code: "2", value: "yso/fin" },
1586
+ { code: "0", value: "http://www.yso.fi/onto/yso/p1129911200" }
1587
+ ]
1588
+ }
1589
+ ]
1590
+ });
1591
+ const recordInvalid648FastYes = new MarcRecord({
1592
+ leader: "",
1593
+ fields: [
1594
+ {
1595
+ tag: "648",
1596
+ ind1: " ",
1597
+ ind2: "7",
1598
+ subfields: [
1599
+ { code: "a", value: "1862." },
1600
+ { code: "2", value: "fast" }
1601
+ ]
1602
+ }
1603
+ ]
1604
+ });
1605
+ const recordInvalid650FinYes = new MarcRecord({
1606
+ leader: "",
1607
+ fields: [
1608
+ { tag: "650", ind1: " ", ind2: "7", subfields: [
1609
+ { code: "a", value: "kirjastot" },
1610
+ { code: "x", value: "atk-j\xE4rjestelm\xE4t." },
1611
+ { code: "2", value: "kauno/fin" }
1612
+ ] },
1613
+ { tag: "650", ind1: " ", ind2: "7", subfields: [
1614
+ { code: "a", value: "ajovalot." },
1615
+ { code: "2", value: "juho" }
1616
+ ] }
1617
+ ]
1618
+ });
1619
+ const recordInvalid650EngNoControl = new MarcRecord({
1620
+ leader: "",
1621
+ fields: [
1622
+ {
1623
+ tag: "650",
1624
+ ind1: " ",
1625
+ ind2: " ",
1626
+ subfields: [
1627
+ { code: "a", value: "Flour industry" },
1628
+ { code: "v", value: "Periodicals" }
1629
+ ]
1630
+ }
1631
+ ]
1632
+ });
1633
+ const recordInvalid650EngControl = new MarcRecord({
1634
+ leader: "",
1635
+ fields: [
1636
+ {
1637
+ tag: "650",
1638
+ ind1: " ",
1639
+ ind2: "7",
1640
+ subfields: [
1641
+ { code: "a", value: "Career Exploration" },
1642
+ { code: "2", value: "ericd" }
1643
+ ]
1644
+ }
1645
+ ]
1646
+ });
1647
+ it("Finds record invalid - 647 Fast, dot at end", async () => {
1648
+ const validator = await validatorFactory();
1649
+ const result = await validator.validate(recordInvalid647FastEndPunc);
1650
+ assert.deepEqual(result, {
1651
+ message: ["Field 647 has an extra dot after ')'"],
1652
+ valid: false
1653
+ });
1654
+ });
1655
+ it("Finds record invalid - 648 Finnish, with punc", async () => {
1656
+ const validator = await validatorFactory();
1657
+ const result = await validator.validate(recordInvalid648FinYes);
1658
+ assert.deepEqual(result, {
1659
+ message: ["Field 648 has unwanted ending punctuation '.'", "Field 648 requires ending punctuation, ends in 'a'"],
1660
+ valid: false
1661
+ });
1662
+ });
1663
+ it("Finds record invalid - 648 Fast, with punc", async () => {
1664
+ const validator = await validatorFactory();
1665
+ const result = await validator.validate(recordInvalid648FastYes);
1666
+ assert.deepEqual(result, {
1667
+ message: ["Field 648 has unwanted ending punctuation '.'"],
1668
+ valid: false
1669
+ });
1670
+ });
1671
+ const invalidField650Message = "Field 650 has unwanted ending punctuation '.'";
1672
+ it("Finds record invalid - 650 Finnish, with punc", async () => {
1673
+ const validator = await validatorFactory();
1674
+ const result = await validator.validate(recordInvalid650FinYes);
1675
+ assert.deepEqual(result, {
1676
+ message: [invalidField650Message, invalidField650Message],
1677
+ valid: false
1678
+ });
1679
+ });
1680
+ it("Finds record invalid - 650 !Finnish, without punc (no control)", async () => {
1681
+ const validator = await validatorFactory();
1682
+ const result = await validator.validate(recordInvalid650EngNoControl);
1683
+ assert.deepEqual(result, {
1684
+ message: ["Field 650 requires ending punctuation, ends in 's'"],
1685
+ valid: false
1686
+ });
1687
+ });
1688
+ it("Finds record invalid - 650 !Finnish, without punc", async () => {
1689
+ const validator = await validatorFactory();
1690
+ const result = await validator.validate(recordInvalid650EngControl);
1691
+ assert.deepEqual(result, {
1692
+ message: ["Field 650 requires ending punctuation, ends in 'n'"],
1693
+ valid: false
1694
+ });
1695
+ });
1696
+ it("Repairs the invalid record - 647 Fast, removes double punc $d", async () => {
1697
+ const validator = await validatorFactory();
1698
+ const result = await validator.fix(recordInvalid647FastEndPunc);
1699
+ assert.equal(recordInvalid647FastEndPunc.equalsTo(recordValid647FastEndPunc), true);
1700
+ assert.deepEqual(result, {
1701
+ message: ["Field 647 has an extra dot after ')'"],
1702
+ fix: ["Field 647 - Removed dot after punctuation from $d"],
1703
+ valid: false
1704
+ });
1705
+ });
1706
+ it("Repairs the invalid record - 648 Finnish, removes punc $a", async () => {
1707
+ const validator = await validatorFactory();
1708
+ const result = await validator.fix(recordInvalid648FinYes);
1709
+ assert.deepEqual(recordInvalid648FinYes, recordValid648FinNo);
1710
+ assert.deepEqual(result, {
1711
+ message: ["Field 648 has unwanted ending punctuation '.'", "Field 648 requires ending punctuation, ends in 'a'"],
1712
+ fix: ["Field 648 - Removed punctuation from $a", "Field 648 - Added punctuation to $a"],
1713
+ valid: false
1714
+ });
1715
+ });
1716
+ it("Repairs the invalid record - 648 Fast, removes punc $a", async () => {
1717
+ const validator = await validatorFactory();
1718
+ const result = await validator.fix(recordInvalid648FastYes);
1719
+ assert.equal(recordInvalid648FastYes.equalsTo(recordValid648FastNo), true);
1720
+ assert.deepEqual(result, {
1721
+ message: ["Field 648 has unwanted ending punctuation '.'"],
1722
+ fix: ["Field 648 - Removed punctuation from $a"],
1723
+ valid: false
1724
+ });
1725
+ });
1726
+ it("Repairs the invalid record - 650 Finnish, removes punc $x", async () => {
1727
+ const validator = await validatorFactory();
1728
+ const result = await validator.fix(recordInvalid650FinYes);
1729
+ assert.equal(recordInvalid650FinYes.equalsTo(recordValid650FinNo), true);
1730
+ assert.deepEqual(result, {
1731
+ message: [invalidField650Message, invalidField650Message],
1732
+ fix: ["Field 650 - Removed punctuation from $x", "Field 650 - Removed punctuation from $a"],
1733
+ valid: false
1734
+ });
1735
+ });
1736
+ it("Repairs the invalid record - 650 !Finnish, add punc $v (no control)", async () => {
1737
+ const validator = await validatorFactory();
1738
+ const result = await validator.fix(recordInvalid650EngNoControl);
1739
+ assert.equal(recordInvalid650EngNoControl.equalsTo(recordValid650EngNoControl), true);
1740
+ assert.deepEqual(result, {
1741
+ message: ["Field 650 requires ending punctuation, ends in 's'"],
1742
+ fix: ["Field 650 - Added punctuation to $v"],
1743
+ valid: false
1744
+ });
1745
+ });
1746
+ it("Repairs the invalid record - 650 !Finnish, add punc $a", async () => {
1747
+ const validator = await validatorFactory();
1748
+ const result = await validator.fix(recordInvalid650EngControl);
1749
+ assert.equal(recordInvalid650EngControl.equalsTo(recordValid650EngControl), true);
1750
+ assert.deepEqual(result, {
1751
+ message: ["Field 650 requires ending punctuation, ends in 'n'"],
1752
+ fix: ["Field 650 - Added punctuation to $a"],
1753
+ valid: false
1754
+ });
1755
+ });
1756
+ });
1757
+ describe("#654-662 TRUE - If Finnish, else TRUE", () => {
1758
+ const recordValid655FinNo = new MarcRecord({
1759
+ leader: "",
1760
+ fields: [
1761
+ {
1762
+ tag: "655",
1763
+ ind1: " ",
1764
+ ind2: "7",
1765
+ subfields: [
1766
+ { code: "a", value: "kausijulkaisut" },
1767
+ { code: "2", value: "yso/eng" }
1768
+ ]
1769
+ }
1770
+ ]
1771
+ });
1772
+ const recordValid655FinNo2 = new MarcRecord({
1773
+ leader: "",
1774
+ fields: [
1775
+ {
1776
+ tag: "655",
1777
+ ind1: " ",
1778
+ ind2: "7",
1779
+ subfields: [
1780
+ { code: "a", value: "vironkielinen kirjallisuus" },
1781
+ { code: "2", value: "local" }
1782
+ ]
1783
+ }
1784
+ ]
1785
+ });
1786
+ const recordValid655EngYes = new MarcRecord({
1787
+ leader: "",
1788
+ fields: [
1789
+ {
1790
+ tag: "655",
1791
+ ind1: " ",
1792
+ ind2: "7",
1793
+ subfields: [
1794
+ { code: "a", value: "Bird's-eye views" },
1795
+ { code: "y", value: "1874." },
1796
+ { code: "2", value: "gmgpc" }
1797
+ ]
1798
+ }
1799
+ ]
1800
+ });
1801
+ const recordValid655EngYesNoControl = new MarcRecord({
1802
+ leader: "",
1803
+ fields: [
1804
+ {
1805
+ tag: "655",
1806
+ ind1: " ",
1807
+ ind2: " ",
1808
+ subfields: [{ code: "a", value: "Diaries." }]
1809
+ }
1810
+ ]
1811
+ });
1812
+ const recordValid656FinNo = new MarcRecord({
1813
+ leader: "",
1814
+ fields: [
1815
+ {
1816
+ tag: "656",
1817
+ ind1: " ",
1818
+ ind2: "7",
1819
+ subfields: [
1820
+ { code: "a", value: "kuvaamataidonopettajat" },
1821
+ { code: "2", value: "slm/eng" }
1822
+ ]
1823
+ }
1824
+ ]
1825
+ });
1826
+ const recordValid657EngYes = new MarcRecord({
1827
+ leader: "",
1828
+ fields: [
1829
+ {
1830
+ tag: "657",
1831
+ ind1: " ",
1832
+ ind2: "7",
1833
+ subfields: [
1834
+ { code: "a", value: "Personnel benefits management" },
1835
+ { code: "x", value: "Vital statistics" },
1836
+ { code: "z", value: "Love Canal, New York." },
1837
+ { code: "2", value: "New York State Management Functions Index" }
1838
+ ]
1839
+ }
1840
+ ]
1841
+ });
1842
+ const recordValid658EngYes = new MarcRecord({
1843
+ leader: "",
1844
+ fields: [
1845
+ {
1846
+ tag: "658",
1847
+ ind1: " ",
1848
+ ind2: " ",
1849
+ subfields: [
1850
+ { code: "a", value: "Math manipulatives" },
1851
+ { code: "d", value: "highly correlated." },
1852
+ { code: "2", value: "[source code]" }
1853
+ ]
1854
+ }
1855
+ ]
1856
+ });
1857
+ const recordValid662EngYes = new MarcRecord({
1858
+ leader: "",
1859
+ fields: [
1860
+ {
1861
+ tag: "662",
1862
+ ind1: " ",
1863
+ ind2: " ",
1864
+ subfields: [
1865
+ { code: "a", value: "Antarctica." },
1866
+ { code: "2", value: "lcsh/naf" }
1867
+ ]
1868
+ }
1869
+ ]
1870
+ });
1871
+ it("Finds record valid - 655 Finnish, no punc $a", async () => {
1872
+ const validator = await validatorFactory();
1873
+ const result = await validator.validate(recordValid655FinNo);
1874
+ assert.equal(result.valid, true);
1875
+ });
1876
+ it("Finds record valid - 655 Finnish, without punc", async () => {
1877
+ const validator = await validatorFactory();
1878
+ const result = await validator.validate(recordValid655FinNo2);
1879
+ assert.equal(result.valid, true);
1880
+ });
1881
+ it("Finds record valid - 655 English, with punc $y", async () => {
1882
+ const validator = await validatorFactory();
1883
+ const result = await validator.validate(recordValid655EngYes);
1884
+ assert.equal(result.valid, true);
1885
+ });
1886
+ it("Finds record valid - 655 English, with punc $a (no control)", async () => {
1887
+ const validator = await validatorFactory();
1888
+ const result = await validator.validate(recordValid655EngYesNoControl);
1889
+ assert.equal(result.valid, true);
1890
+ });
1891
+ it("Finds record valid - 656 Finnish, without punc $a", async () => {
1892
+ const validator = await validatorFactory();
1893
+ const result = await validator.validate(recordValid656FinNo);
1894
+ assert.equal(result.valid, true);
1895
+ });
1896
+ it("Finds record valid - 657 English, with punc $z", async () => {
1897
+ const validator = await validatorFactory();
1898
+ const result = await validator.validate(recordValid657EngYes);
1899
+ assert.equal(result.valid, true);
1900
+ });
1901
+ it("Finds record valid - 658 English, with punc $d", async () => {
1902
+ const validator = await validatorFactory();
1903
+ const result = await validator.validate(recordValid658EngYes);
1904
+ assert.equal(result.valid, true);
1905
+ });
1906
+ it("Finds record valid - 662 English, with punc $a", async () => {
1907
+ const validator = await validatorFactory();
1908
+ const result = await validator.validate(recordValid662EngYes);
1909
+ assert.equal(result.valid, true);
1910
+ });
1911
+ const recordInvalid655FinYes = new MarcRecord({
1912
+ leader: "",
1913
+ fields: [
1914
+ {
1915
+ tag: "655",
1916
+ ind1: " ",
1917
+ ind2: "7",
1918
+ subfields: [
1919
+ { code: "a", value: "kausijulkaisut." },
1920
+ { code: "2", value: "yso/eng" }
1921
+ ]
1922
+ }
1923
+ ]
1924
+ });
1925
+ const recordInvalid655FinYes2 = new MarcRecord({
1926
+ leader: "",
1927
+ fields: [
1928
+ {
1929
+ tag: "655",
1930
+ ind1: " ",
1931
+ ind2: "7",
1932
+ subfields: [
1933
+ { code: "a", value: "vironkielinen kirjallisuus." },
1934
+ { code: "2", value: "local" }
1935
+ ]
1936
+ }
1937
+ ]
1938
+ });
1939
+ const recordInvalid655EngNo = new MarcRecord({
1940
+ leader: "",
1941
+ fields: [
1942
+ {
1943
+ tag: "655",
1944
+ ind1: " ",
1945
+ ind2: "7",
1946
+ subfields: [
1947
+ { code: "a", value: "Bird's-eye views" },
1948
+ { code: "y", value: "1874" },
1949
+ { code: "2", value: "gmgpc" }
1950
+ ]
1951
+ }
1952
+ ]
1953
+ });
1954
+ const recordInvalid655EngNoNoControl = new MarcRecord({
1955
+ leader: "",
1956
+ fields: [
1957
+ {
1958
+ tag: "655",
1959
+ ind1: " ",
1960
+ ind2: " ",
1961
+ subfields: [{ code: "a", value: "Diaries" }]
1962
+ }
1963
+ ]
1964
+ });
1965
+ const recordInvalid656FinYes = new MarcRecord({
1966
+ leader: "",
1967
+ fields: [
1968
+ {
1969
+ tag: "656",
1970
+ ind1: " ",
1971
+ ind2: "7",
1972
+ subfields: [
1973
+ { code: "a", value: "kuvaamataidonopettajat." },
1974
+ { code: "2", value: "slm/eng" }
1975
+ ]
1976
+ }
1977
+ ]
1978
+ });
1979
+ const recordInvalid657EngNo = new MarcRecord({
1980
+ leader: "",
1981
+ fields: [
1982
+ {
1983
+ tag: "657",
1984
+ ind1: " ",
1985
+ ind2: "7",
1986
+ subfields: [
1987
+ { code: "a", value: "Personnel benefits management" },
1988
+ { code: "x", value: "Vital statistics" },
1989
+ { code: "z", value: "Love Canal, New York" },
1990
+ { code: "2", value: "New York State Management Functions Index" }
1991
+ ]
1992
+ }
1993
+ ]
1994
+ });
1995
+ const recordInvalid658EngNo = new MarcRecord({
1996
+ leader: "",
1997
+ fields: [
1998
+ {
1999
+ tag: "658",
2000
+ ind1: " ",
2001
+ ind2: " ",
2002
+ subfields: [
2003
+ { code: "a", value: "Math manipulatives" },
2004
+ { code: "d", value: "highly correlated" },
2005
+ { code: "2", value: "[source code]" }
2006
+ ]
2007
+ }
2008
+ ]
2009
+ });
2010
+ const recordInvalid662EngNo = new MarcRecord({
2011
+ leader: "",
2012
+ fields: [
2013
+ {
2014
+ tag: "662",
2015
+ ind1: " ",
2016
+ ind2: " ",
2017
+ subfields: [
2018
+ { code: "a", value: "Antarctica" },
2019
+ { code: "2", value: "lcsh/naf" }
2020
+ ]
2021
+ }
2022
+ ]
2023
+ });
2024
+ it("Finds record invalid - 655 Finnish, punc $a", async () => {
2025
+ const validator = await validatorFactory();
2026
+ const result = await validator.validate(recordInvalid655FinYes);
2027
+ assert.deepEqual(result, {
2028
+ message: ["Field 655 has unwanted ending punctuation '.'"],
2029
+ valid: false
2030
+ });
2031
+ });
2032
+ it("Finds record invalid - 655 Finnish, with punc", async () => {
2033
+ const validator = await validatorFactory();
2034
+ const result = await validator.validate(recordInvalid655FinYes2);
2035
+ assert.deepEqual(result, {
2036
+ message: ["Field 655 has unwanted ending punctuation '.'"],
2037
+ valid: false
2038
+ });
2039
+ });
2040
+ it("Finds record invalid - 655 !Finnish, without punc $y", async () => {
2041
+ const validator = await validatorFactory();
2042
+ const result = await validator.validate(recordInvalid655EngNo);
2043
+ assert.deepEqual(result, {
2044
+ message: ["Field 655 requires ending punctuation, ends in '4'"],
2045
+ valid: false
2046
+ });
2047
+ });
2048
+ it("Finds record invalid - 655 !Finnish, without punc $a (no control)", async () => {
2049
+ const validator = await validatorFactory();
2050
+ const result = await validator.validate(recordInvalid655EngNoNoControl);
2051
+ assert.deepEqual(result, {
2052
+ message: ["Field 655 requires ending punctuation, ends in 's'"],
2053
+ valid: false
2054
+ });
2055
+ });
2056
+ it("Finds record invalid - 656 Finnish, with punc $a", async () => {
2057
+ const validator = await validatorFactory();
2058
+ const result = await validator.validate(recordInvalid656FinYes);
2059
+ assert.deepEqual(result, {
2060
+ message: ["Field 656 has unwanted ending punctuation '.'"],
2061
+ valid: false
2062
+ });
2063
+ });
2064
+ it("Finds record invalid - 657 !Finnish, without punc $z", async () => {
2065
+ const validator = await validatorFactory();
2066
+ const result = await validator.validate(recordInvalid657EngNo);
2067
+ assert.deepEqual(result, {
2068
+ message: ["Field 657 requires ending punctuation, ends in 'k'"],
2069
+ valid: false
2070
+ });
2071
+ });
2072
+ it("Finds record invalid - 658 !Finnish, without punc $d", async () => {
2073
+ const validator = await validatorFactory();
2074
+ const result = await validator.validate(recordInvalid658EngNo);
2075
+ assert.deepEqual(result, {
2076
+ message: ["Field 658 requires ending punctuation, ends in 'd'"],
2077
+ valid: false
2078
+ });
2079
+ });
2080
+ it("Finds record invalid - 662 !Finnish, without punc $a", async () => {
2081
+ const validator = await validatorFactory();
2082
+ const result = await validator.validate(recordInvalid662EngNo);
2083
+ assert.deepEqual(result, {
2084
+ message: ["Field 662 requires ending punctuation, ends in 'a'"],
2085
+ valid: false
2086
+ });
2087
+ });
2088
+ it("Repairs the invalid record - 655 Finnish, remove punc $a", async () => {
2089
+ const validator = await validatorFactory();
2090
+ const result = await validator.fix(recordInvalid655FinYes);
2091
+ assert.equal(recordInvalid655FinYes.equalsTo(recordValid655FinNo), true);
2092
+ assert.deepEqual(result, {
2093
+ message: ["Field 655 has unwanted ending punctuation '.'"],
2094
+ fix: ["Field 655 - Removed punctuation from $a"],
2095
+ valid: false
2096
+ });
2097
+ });
2098
+ it("Repairs the invalid record - 655 Finnish, removes punc $a 2", async () => {
2099
+ const validator = await validatorFactory();
2100
+ const result = await validator.fix(recordInvalid655FinYes2);
2101
+ assert.equal(recordInvalid655FinYes2.equalsTo(recordValid655FinNo2), true);
2102
+ assert.deepEqual(result, {
2103
+ message: ["Field 655 has unwanted ending punctuation '.'"],
2104
+ fix: ["Field 655 - Removed punctuation from $a"],
2105
+ valid: false
2106
+ });
2107
+ });
2108
+ it("Repairs the invalid record - 655 !Finnish, add punc $y", async () => {
2109
+ const validator = await validatorFactory();
2110
+ const result = await validator.fix(recordInvalid655EngNo);
2111
+ assert.equal(recordInvalid655EngNo.equalsTo(recordValid655EngYes), true);
2112
+ assert.deepEqual(result, {
2113
+ message: ["Field 655 requires ending punctuation, ends in '4'"],
2114
+ fix: ["Field 655 - Added punctuation to $y"],
2115
+ valid: false
2116
+ });
2117
+ });
2118
+ it("Repairs the invalid record - 655 !Finnish, add punc $a (no control)", async () => {
2119
+ const validator = await validatorFactory();
2120
+ const result = await validator.fix(recordInvalid655EngNoNoControl);
2121
+ assert.equal(recordInvalid655EngNoNoControl.equalsTo(recordValid655EngYesNoControl), true);
2122
+ assert.deepEqual(result, {
2123
+ message: ["Field 655 requires ending punctuation, ends in 's'"],
2124
+ fix: ["Field 655 - Added punctuation to $a"],
2125
+ valid: false
2126
+ });
2127
+ });
2128
+ it("Repairs the invalid record - 656 Finnish, remove punc $a", async () => {
2129
+ const validator = await validatorFactory();
2130
+ const result = await validator.fix(recordInvalid656FinYes);
2131
+ assert.equal(recordInvalid656FinYes.equalsTo(recordValid656FinNo), true);
2132
+ assert.deepEqual(result, {
2133
+ message: ["Field 656 has unwanted ending punctuation '.'"],
2134
+ fix: ["Field 656 - Removed punctuation from $a"],
2135
+ valid: false
2136
+ });
2137
+ });
2138
+ it("Repairs the invalid record - 657 !Finnish, add punc $z", async () => {
2139
+ const validator = await validatorFactory();
2140
+ const result = await validator.fix(recordInvalid657EngNo);
2141
+ assert.equal(recordInvalid657EngNo.equalsTo(recordValid657EngYes), true);
2142
+ assert.deepEqual(result, {
2143
+ message: ["Field 657 requires ending punctuation, ends in 'k'"],
2144
+ fix: ["Field 657 - Added punctuation to $z"],
2145
+ valid: false
2146
+ });
2147
+ });
2148
+ it("Repairs the invalid record - 658 !Finnish, add punc $d", async () => {
2149
+ const validator = await validatorFactory();
2150
+ const result = await validator.fix(recordInvalid658EngNo);
2151
+ assert.equal(recordInvalid658EngNo.equalsTo(recordValid658EngYes), true);
2152
+ assert.deepEqual(result, {
2153
+ message: ["Field 658 requires ending punctuation, ends in 'd'"],
2154
+ fix: ["Field 658 - Added punctuation to $d"],
2155
+ valid: false
2156
+ });
2157
+ });
2158
+ it("Repairs the invalid record - 662 !Finnish, add punc $a", async () => {
2159
+ const validator = await validatorFactory();
2160
+ const result = await validator.fix(recordInvalid662EngNo);
2161
+ assert.equal(recordInvalid662EngNo.equalsTo(recordValid662EngYes), true);
2162
+ assert.deepEqual(result, {
2163
+ message: ["Field 662 requires ending punctuation, ends in 'a'"],
2164
+ fix: ["Field 662 - Added punctuation to $a"],
2165
+ valid: false
2166
+ });
2167
+ });
2168
+ });
2169
+ describe("#760-787 TRUE - After subfield $a, FALSE after others", () => {
2170
+ const recordValid = new MarcRecord({
2171
+ leader: "",
2172
+ fields: [
2173
+ {
2174
+ tag: "760",
2175
+ ind1: " ",
2176
+ ind2: " ",
2177
+ subfields: [
2178
+ { code: "a", value: "Mellor, Alec." },
2179
+ { code: "t", value: "Strange masonic stories" },
2180
+ { code: "e", value: "eng" }
2181
+ ]
2182
+ }
2183
+ ]
2184
+ });
2185
+ const recordValidOnlyA = new MarcRecord({
2186
+ leader: "",
2187
+ fields: [
2188
+ {
2189
+ tag: "760",
2190
+ ind1: " ",
2191
+ ind2: " ",
2192
+ subfields: [{ code: "a", value: "Mellor, Alec." }]
2193
+ }
2194
+ ]
2195
+ });
2196
+ it("Finds record valid - Punc $a, but following fields, $e no punc (last)", async () => {
2197
+ const validator = await validatorFactory();
2198
+ const result = await validator.validate(recordValid);
2199
+ assert.equal(result.valid, true);
2200
+ });
2201
+ it("Finds record valid - Punc $a (only)", async () => {
2202
+ const validator = await validatorFactory();
2203
+ const result = await validator.validate(recordValidOnlyA);
2204
+ assert.equal(result.valid, true);
2205
+ });
2206
+ const recordInvalid = new MarcRecord({
2207
+ leader: "",
2208
+ fields: [
2209
+ {
2210
+ tag: "760",
2211
+ ind1: " ",
2212
+ ind2: " ",
2213
+ subfields: [
2214
+ { code: "a", value: "Mellor, Alec." },
2215
+ { code: "t", value: "Strange masonic stories" },
2216
+ { code: "e", value: "eng." }
2217
+ ]
2218
+ }
2219
+ ]
2220
+ });
2221
+ const recordInvalidOnlyA = new MarcRecord({
2222
+ leader: "",
2223
+ fields: [
2224
+ {
2225
+ tag: "760",
2226
+ ind1: " ",
2227
+ ind2: " ",
2228
+ subfields: [{ code: "a", value: "Mellor, Alec" }]
2229
+ }
2230
+ ]
2231
+ });
2232
+ it("Finds record invalid - Punc $e (language field, strict)", async () => {
2233
+ const validator = await validatorFactory();
2234
+ const result = await validator.validate(recordInvalid);
2235
+ assert.deepEqual(result, {
2236
+ message: ["Field 760 has unwanted ending punctuation '.'"],
2237
+ valid: false
2238
+ });
2239
+ });
2240
+ it("Finds record invalid - No punc $a (only)", async () => {
2241
+ const validator = await validatorFactory();
2242
+ const result = await validator.validate(recordInvalidOnlyA);
2243
+ assert.deepEqual(result, {
2244
+ message: ["Field 760 requires ending punctuation, ends in 'c'"],
2245
+ valid: false
2246
+ });
2247
+ });
2248
+ it("Repairs the invalid record - Remove punc $e (language field, strict)", async () => {
2249
+ const validator = await validatorFactory();
2250
+ const result = await validator.fix(recordInvalid);
2251
+ assert.equal(recordInvalid.equalsTo(recordValid), true);
2252
+ assert.deepEqual(result, {
2253
+ message: ["Field 760 has unwanted ending punctuation '.'"],
2254
+ fix: ["Field 760 - Removed punctuation from $e"],
2255
+ valid: false
2256
+ });
2257
+ });
2258
+ it("Repairs the invalid record - Add punc $a (only)", async () => {
2259
+ const validator = await validatorFactory();
2260
+ const result = await validator.fix(recordInvalidOnlyA);
2261
+ assert.equal(recordInvalidOnlyA.equalsTo(recordValidOnlyA), true);
2262
+ assert.deepEqual(result, {
2263
+ message: ["Field 760 requires ending punctuation, ends in 'c'"],
2264
+ fix: ["Field 760 - Added punctuation to $a"],
2265
+ valid: false
2266
+ });
2267
+ });
2268
+ });
2269
+ describe("#880 - Like linked fields", () => {
2270
+ const recordValidSimple = new MarcRecord({
2271
+ leader: "",
2272
+ fields: [
2273
+ {
2274
+ tag: "880",
2275
+ ind1: " ",
2276
+ ind2: " ",
2277
+ subfields: [
2278
+ { code: "a", value: "\u5E73\u7530 \u7BE4\u80E4" },
2279
+ { code: "b", value: "1776-1843." },
2280
+ { code: "6", value: "100-01/$1" }
2281
+ // Tag 100 has value TRUE -> last data subfield should have punc
2282
+ ]
2283
+ }
2284
+ ]
2285
+ });
2286
+ const recordValidComplex = new MarcRecord({
2287
+ leader: "",
2288
+ fields: [
2289
+ {
2290
+ tag: "880",
2291
+ ind1: " ",
2292
+ ind2: " ",
2293
+ subfields: [
2294
+ { code: "b", value: "\u05D9\u05D3\u05D9\u05E2\u05D5\u05EA \u05D0\u05D7\u05E8\u05D5\u05E0\u05D5\u05EA" },
2295
+ { code: "b", value: "\u05E1\u05E4\u05E8\u05D9 \u05D7\u05DE\u05D3" },
2296
+ { code: "c", value: "2006." },
2297
+ { code: "6", value: "260-02/(2/r \u2021a \u05EA\u05DC-\u05D0\u05D1\u05D9\u05D1" }
2298
+ // Tag 260 has value TRUE -> last data subfield should have punc
2299
+ ]
2300
+ }
2301
+ ]
2302
+ });
2303
+ it("Finds record valid - Punc $b", async () => {
2304
+ const validator = await validatorFactory();
2305
+ const result = await validator.validate(recordValidSimple);
2306
+ assert.equal(result.valid, true);
2307
+ });
2308
+ it("Finds record valid - Punc $c", async () => {
2309
+ const validator = await validatorFactory();
2310
+ const result = await validator.validate(recordValidComplex);
2311
+ assert.equal(result.valid, true);
2312
+ });
2313
+ const recordInvalidSimple = new MarcRecord({
2314
+ leader: "",
2315
+ fields: [
2316
+ {
2317
+ tag: "880",
2318
+ ind1: " ",
2319
+ ind2: " ",
2320
+ subfields: [
2321
+ { code: "a", value: "\u5E73\u7530 \u7BE4\u80E4" },
2322
+ { code: "b", value: "1776-1843" },
2323
+ { code: "6", value: "100-01/$1" }
2324
+ // Tag 100 has value TRUE -> last data subfield should have punc
2325
+ ]
2326
+ }
2327
+ ]
2328
+ });
2329
+ const recordInvalidComplex = new MarcRecord({
2330
+ leader: "",
2331
+ fields: [
2332
+ {
2333
+ tag: "880",
2334
+ ind1: " ",
2335
+ ind2: " ",
2336
+ subfields: [
2337
+ { code: "b", value: "\u05D9\u05D3\u05D9\u05E2\u05D5\u05EA \u05D0\u05D7\u05E8\u05D5\u05E0\u05D5\u05EA" },
2338
+ { code: "b", value: "\u05E1\u05E4\u05E8\u05D9 \u05D7\u05DE\u05D3" },
2339
+ { code: "c", value: "2006" },
2340
+ { code: "6", value: "260-02/(2/r \u2021a \u05EA\u05DC-\u05D0\u05D1\u05D9\u05D1" }
2341
+ // Tag 260 has value TRUE -> last data subfield should have punc
2342
+ ]
2343
+ }
2344
+ ]
2345
+ });
2346
+ it("Finds record invalid - No punc $b", async () => {
2347
+ const validator = await validatorFactory();
2348
+ const result = await validator.validate(recordInvalidSimple);
2349
+ assert.deepEqual(result, {
2350
+ message: ["Field 880 requires ending punctuation, ends in '3'"],
2351
+ valid: false
2352
+ });
2353
+ });
2354
+ it("Finds record invalid - No punc $c", async () => {
2355
+ const validator = await validatorFactory();
2356
+ const result = await validator.validate(recordInvalidComplex);
2357
+ assert.deepEqual(result, {
2358
+ message: ["Field 880 requires ending punctuation, ends in '6'"],
2359
+ valid: false
2360
+ });
2361
+ });
2362
+ it("Repairs the invalid record - Add punc $b", async () => {
2363
+ const validator = await validatorFactory();
2364
+ const result = await validator.fix(recordInvalidSimple);
2365
+ assert.equal(recordInvalidSimple.equalsTo(recordValidSimple), true);
2366
+ assert.deepEqual(result, {
2367
+ message: ["Field 880 requires ending punctuation, ends in '3'"],
2368
+ fix: ["Field 880 - Added punctuation to $b"],
2369
+ valid: false
2370
+ });
2371
+ });
2372
+ it("Repairs the invalid record - Add punc $c", async () => {
2373
+ const validator = await validatorFactory();
2374
+ const result = await validator.fix(recordInvalidComplex);
2375
+ assert.equal(recordInvalidComplex.equalsTo(recordValidComplex), true);
2376
+ assert.deepEqual(result, {
2377
+ message: ["Field 880 requires ending punctuation, ends in '6'"],
2378
+ fix: ["Field 880 - Added punctuation to $c"],
2379
+ valid: false
2380
+ });
2381
+ });
2382
+ });
2383
+ });
2384
+ });
2385
+ //# sourceMappingURL=ending-punctuation.test.js.map