@natlibfi/marc-record-validators-melinda 11.6.7-alpha.1 → 12.0.0-alpha.1
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.
- package/.github/workflows/melinda-node-tests.yml +1 -1
- package/dist/access-rights.js +63 -91
- package/dist/access-rights.js.map +7 -1
- package/dist/access-rights.test.js +137 -0
- package/dist/access-rights.test.js.map +7 -0
- package/dist/addMissingField041.js +21 -53
- package/dist/addMissingField041.js.map +7 -1
- package/dist/addMissingField041.test.js +39 -0
- package/dist/addMissingField041.test.js.map +7 -0
- package/dist/addMissingField336.js +99 -191
- package/dist/addMissingField336.js.map +7 -1
- package/dist/addMissingField336.test.js +39 -0
- package/dist/addMissingField336.test.js.map +7 -0
- package/dist/addMissingField337.js +63 -132
- package/dist/addMissingField337.js.map +7 -1
- package/dist/addMissingField337.test.js +39 -0
- package/dist/addMissingField337.test.js.map +7 -0
- package/dist/addMissingField338.js +147 -253
- package/dist/addMissingField338.js.map +7 -1
- package/dist/addMissingField338.test.js +39 -0
- package/dist/addMissingField338.test.js.map +7 -0
- package/dist/cyrillux-usemarcon-replacement.js +119 -272
- package/dist/cyrillux-usemarcon-replacement.js.map +7 -1
- package/dist/cyrillux-usemarcon-replacement.test.js +46 -0
- package/dist/cyrillux-usemarcon-replacement.test.js.map +7 -0
- package/dist/cyrillux.js +119 -223
- package/dist/cyrillux.js.map +7 -1
- package/dist/cyrillux.test.js +39 -0
- package/dist/cyrillux.test.js.map +7 -0
- package/dist/disambiguateSeriesStatements.js +40 -81
- package/dist/disambiguateSeriesStatements.js.map +7 -1
- package/dist/disambiguateSeriesStatements.test.js +44 -0
- package/dist/disambiguateSeriesStatements.test.js.map +7 -0
- package/dist/double-commas.js +7 -14
- package/dist/double-commas.js.map +7 -1
- package/dist/double-commas.test.js +48 -0
- package/dist/double-commas.test.js.map +7 -0
- package/dist/duplicates-ind1.js +10 -31
- package/dist/duplicates-ind1.js.map +7 -1
- package/dist/duplicates-ind1.test.js +40 -0
- package/dist/duplicates-ind1.test.js.map +7 -0
- package/dist/empty-fields.js +10 -22
- package/dist/empty-fields.js.map +7 -1
- package/dist/empty-fields.test.js +129 -0
- package/dist/empty-fields.test.js.map +7 -0
- package/dist/ending-punctuation-conf.js +871 -769
- package/dist/ending-punctuation-conf.js.map +7 -1
- package/dist/ending-punctuation.js +84 -167
- package/dist/ending-punctuation.js.map +7 -1
- package/dist/ending-punctuation.test.js +2290 -0
- package/dist/ending-punctuation.test.js.map +7 -0
- package/dist/ending-whitespace.js +10 -35
- package/dist/ending-whitespace.js.map +7 -1
- package/dist/ending-whitespace.test.js +38 -0
- package/dist/ending-whitespace.test.js.map +7 -0
- package/dist/field-008-18-34-character-groups.js +40 -125
- package/dist/field-008-18-34-character-groups.js.map +7 -1
- package/dist/field-008-18-34-character-groups.test.js +45 -0
- package/dist/field-008-18-34-character-groups.test.js.map +7 -0
- package/dist/field-505-separators.js +19 -39
- package/dist/field-505-separators.js.map +7 -1
- package/dist/field-505-separators.test.js +45 -0
- package/dist/field-505-separators.test.js.map +7 -0
- package/dist/field-521-fix.js +19 -47
- package/dist/field-521-fix.js.map +7 -1
- package/dist/field-521-fix.test.js +44 -0
- package/dist/field-521-fix.test.js.map +7 -0
- package/dist/field-exclusion.js +37 -91
- package/dist/field-exclusion.js.map +7 -1
- package/dist/field-exclusion.test.js +821 -0
- package/dist/field-exclusion.test.js.map +7 -0
- package/dist/field-structure.js +52 -104
- package/dist/field-structure.js.map +7 -1
- package/dist/field-structure.test.js +587 -0
- package/dist/field-structure.test.js.map +7 -0
- package/dist/field33XUtils.js +119 -503
- package/dist/field33XUtils.js.map +7 -1
- package/dist/fields-present.js +11 -23
- package/dist/fields-present.js.map +7 -1
- package/dist/fields-present.test.js +95 -0
- package/dist/fields-present.test.js.map +7 -0
- package/dist/fix-33X.js +393 -431
- package/dist/fix-33X.js.map +7 -1
- package/dist/fix-33X.test.js +39 -0
- package/dist/fix-33X.test.js.map +7 -0
- package/dist/fix-country-codes.js +20 -50
- package/dist/fix-country-codes.js.map +7 -1
- package/dist/fix-country-codes.test.js +44 -0
- package/dist/fix-country-codes.test.js.map +7 -0
- package/dist/fix-language-codes.js +23 -53
- package/dist/fix-language-codes.js.map +7 -1
- package/dist/fix-language-codes.test.js +38 -0
- package/dist/fix-language-codes.test.js.map +7 -0
- package/dist/fixRelatorTerms.js +82 -209
- package/dist/fixRelatorTerms.js.map +7 -1
- package/dist/fixRelatorTerms.test.js +44 -0
- package/dist/fixRelatorTerms.test.js.map +7 -0
- package/dist/fixed-fields.js +21 -30
- package/dist/fixed-fields.js.map +7 -1
- package/dist/fixed-fields.test.js +87 -0
- package/dist/fixed-fields.test.js.map +7 -0
- package/dist/identical-fields.js +8 -24
- package/dist/identical-fields.js.map +7 -1
- package/dist/identical-fields.test.js +119 -0
- package/dist/identical-fields.test.js.map +7 -0
- package/dist/index.js +119 -413
- package/dist/index.js.map +7 -1
- package/dist/indicator-fixes.js +57 -95
- package/dist/indicator-fixes.js.map +7 -1
- package/dist/indicator-fixes.test.js +42 -0
- package/dist/indicator-fixes.test.js.map +7 -0
- package/dist/isbn-issn.js +66 -126
- package/dist/isbn-issn.js.map +7 -1
- package/dist/isbn-issn.test.js +398 -0
- package/dist/isbn-issn.test.js.map +7 -0
- package/dist/item-language.js +32 -65
- package/dist/item-language.js.map +7 -1
- package/dist/item-language.test.js +322 -0
- package/dist/item-language.test.js.map +7 -0
- package/dist/melindaCustomMergeFields.js +5182 -11233
- package/dist/melindaCustomMergeFields.js.map +7 -1
- package/dist/merge-fields/controlSubfields.js +75 -142
- package/dist/merge-fields/controlSubfields.js.map +7 -1
- package/dist/merge-fields/counterpartField.js +182 -379
- package/dist/merge-fields/counterpartField.js.map +7 -1
- package/dist/merge-fields/index.js +15 -49
- package/dist/merge-fields/index.js.map +7 -1
- package/dist/merge-fields/mergableIndicator.js +18 -51
- package/dist/merge-fields/mergableIndicator.js.map +7 -1
- package/dist/merge-fields/mergableTag.js +78 -30
- package/dist/merge-fields/mergableTag.js.map +7 -1
- package/dist/merge-fields/mergeConfig.js +66 -171
- package/dist/merge-fields/mergeConfig.js.map +7 -1
- package/dist/merge-fields/mergeConstraints.js +323 -1214
- package/dist/merge-fields/mergeConstraints.js.map +7 -1
- package/dist/merge-fields/mergeField.js +47 -111
- package/dist/merge-fields/mergeField.js.map +7 -1
- package/dist/merge-fields/mergeIndicator.js +64 -118
- package/dist/merge-fields/mergeIndicator.js.map +7 -1
- package/dist/merge-fields/mergeOrAddPostprocess.js +14 -38
- package/dist/merge-fields/mergeOrAddPostprocess.js.map +7 -1
- package/dist/merge-fields/mergeOrAddSubfield.js +62 -104
- package/dist/merge-fields/mergeOrAddSubfield.js.map +7 -1
- package/dist/merge-fields/mergeSubfield.js +47 -95
- package/dist/merge-fields/mergeSubfield.js.map +7 -1
- package/dist/merge-fields/removeDuplicateSubfields.js +18 -31
- package/dist/merge-fields/removeDuplicateSubfields.js.map +7 -1
- package/dist/merge-fields/worldKnowledge.js +15 -40
- package/dist/merge-fields/worldKnowledge.js.map +7 -1
- package/dist/merge-fields.test.js +44 -0
- package/dist/merge-fields.test.js.map +7 -0
- package/dist/mergeField500Lisapainokset.js +28 -57
- package/dist/mergeField500Lisapainokset.js.map +7 -1
- package/dist/mergeField500Lisapainokset.test.js +44 -0
- package/dist/mergeField500Lisapainokset.test.js.map +7 -0
- package/dist/mergeRelatorTermFields.js +33 -69
- package/dist/mergeRelatorTermFields.js.map +7 -1
- package/dist/mergeRelatorTermFields.test.js +44 -0
- package/dist/mergeRelatorTermFields.test.js.map +7 -0
- package/dist/modernize-502.js +23 -55
- package/dist/modernize-502.js.map +7 -1
- package/dist/modernize-502.test.js +38 -0
- package/dist/modernize-502.test.js.map +7 -0
- package/dist/multiple-subfield-0.js +23 -48
- package/dist/multiple-subfield-0.js.map +7 -1
- package/dist/multiple-subfield-0.test.js +44 -0
- package/dist/multiple-subfield-0.test.js.map +7 -0
- package/dist/non-breaking-space.js +11 -32
- package/dist/non-breaking-space.js.map +7 -1
- package/dist/non-breaking-space.test.js +38 -0
- package/dist/non-breaking-space.test.js.map +7 -0
- package/dist/normalize-dashes.js +18 -37
- package/dist/normalize-dashes.js.map +7 -1
- package/dist/normalize-dashes.test.js +44 -0
- package/dist/normalize-dashes.test.js.map +7 -0
- package/dist/normalize-identifiers.js +54 -140
- package/dist/normalize-identifiers.js.map +7 -1
- package/dist/normalize-identifiers.test.js +44 -0
- package/dist/normalize-identifiers.test.js.map +7 -0
- package/dist/normalize-qualifying-information.js +23 -48
- package/dist/normalize-qualifying-information.js.map +7 -1
- package/dist/normalize-qualifying-information.test.js +44 -0
- package/dist/normalize-qualifying-information.test.js.map +7 -0
- package/dist/normalize-utf8-diacritics.js +19 -105
- package/dist/normalize-utf8-diacritics.js.map +7 -1
- package/dist/normalize-utf8-diacritics.test.js +44 -0
- package/dist/normalize-utf8-diacritics.test.js.map +7 -0
- package/dist/normalizeFieldForComparison.js +67 -158
- package/dist/normalizeFieldForComparison.js.map +7 -1
- package/dist/normalizeSubfieldValueForComparison.js +37 -77
- package/dist/normalizeSubfieldValueForComparison.js.map +7 -1
- package/dist/prepublicationUtils.js +58 -111
- package/dist/prepublicationUtils.js.map +7 -1
- package/dist/punctuation/index.js +56 -72
- package/dist/punctuation/index.js.map +7 -1
- package/dist/punctuation/rules/aut.js +372 -331
- package/dist/punctuation/rules/aut.js.map +7 -1
- package/dist/punctuation/rules/bib.js +420 -373
- package/dist/punctuation/rules/bib.js.map +7 -1
- package/dist/punctuation/rules/index.js +7 -21
- package/dist/punctuation/rules/index.js.map +7 -1
- package/dist/punctuation.test.js +44 -0
- package/dist/punctuation.test.js.map +7 -0
- package/dist/punctuation2.js +251 -800
- package/dist/punctuation2.js.map +7 -1
- package/dist/punctuation2.test.js +44 -0
- package/dist/punctuation2.test.js.map +7 -0
- package/dist/reindexSubfield6OccurenceNumbers.js +61 -96
- package/dist/reindexSubfield6OccurenceNumbers.js.map +7 -1
- package/dist/reindexSubfield6OccurenceNumbers.test.js +44 -0
- package/dist/reindexSubfield6OccurenceNumbers.test.js.map +7 -0
- package/dist/removeDuplicateDataFields.js +102 -202
- package/dist/removeDuplicateDataFields.js.map +7 -1
- package/dist/removeDuplicateDataFields.test.js +44 -0
- package/dist/removeDuplicateDataFields.test.js.map +7 -0
- package/dist/removeInferiorDataFields.js +103 -227
- package/dist/removeInferiorDataFields.js.map +7 -1
- package/dist/removeInferiorDataFields.test.js +44 -0
- package/dist/removeInferiorDataFields.test.js.map +7 -0
- package/dist/resolvable-ext-references-melinda.js +25 -60
- package/dist/resolvable-ext-references-melinda.js.map +7 -1
- package/dist/resolvable-ext-references-melinda.test.js +160 -0
- package/dist/resolvable-ext-references-melinda.test.js.map +7 -0
- package/dist/resolveOrphanedSubfield6s.js +33 -64
- package/dist/resolveOrphanedSubfield6s.js.map +7 -1
- package/dist/resolveOrphanedSubfield6s.test.js +44 -0
- package/dist/resolveOrphanedSubfield6s.test.js.map +7 -0
- package/dist/sanitize-vocabulary-source-codes.js +27 -55
- package/dist/sanitize-vocabulary-source-codes.js.map +7 -1
- package/dist/sanitize-vocabulary-source-codes.test.js +45 -0
- package/dist/sanitize-vocabulary-source-codes.test.js.map +7 -0
- package/dist/sort-tags.js +13 -25
- package/dist/sort-tags.js.map +7 -1
- package/dist/sort-tags.test.js +261 -0
- package/dist/sort-tags.test.js.map +7 -0
- package/dist/sortFields.js +152 -222
- package/dist/sortFields.js.map +7 -1
- package/dist/sortFields.test.js +44 -0
- package/dist/sortFields.test.js.map +7 -0
- package/dist/sortRelatorTerms.js +30 -68
- package/dist/sortRelatorTerms.js.map +7 -1
- package/dist/sortRelatorTerms.test.js +44 -0
- package/dist/sortRelatorTerms.test.js.map +7 -0
- package/dist/sortSubfields.js +102 -255
- package/dist/sortSubfields.js.map +7 -1
- package/dist/sortSubfields.test.js +44 -0
- package/dist/sortSubfields.test.js.map +7 -0
- package/dist/stripPunctuation.js +13 -36
- package/dist/stripPunctuation.js.map +7 -1
- package/dist/stripPunctuation.test.js +44 -0
- package/dist/stripPunctuation.test.js.map +7 -0
- package/dist/subfield-exclusion.js +28 -75
- package/dist/subfield-exclusion.js.map +7 -1
- package/dist/subfield-exclusion.test.js +471 -0
- package/dist/subfield-exclusion.test.js.map +7 -0
- package/dist/subfield6Utils.js +107 -269
- package/dist/subfield6Utils.js.map +7 -1
- package/dist/subfield8Utils.js +26 -50
- package/dist/subfield8Utils.js.map +7 -1
- package/dist/subfieldValueNormalizations.js +40 -74
- package/dist/subfieldValueNormalizations.js.map +7 -1
- package/dist/subfieldValueNormalizations.test.js +45 -0
- package/dist/subfieldValueNormalizations.test.js.map +7 -0
- package/dist/sync-007-and-300.js +22 -53
- package/dist/sync-007-and-300.js.map +7 -1
- package/dist/sync-007-and-300.test.js +44 -0
- package/dist/sync-007-and-300.test.js.map +7 -0
- package/dist/translate-terms.js +67 -155
- package/dist/translate-terms.js.map +7 -1
- package/dist/translate-terms.test.js +44 -0
- package/dist/translate-terms.test.js.map +7 -0
- package/dist/typeOfDate-008.js +10 -25
- package/dist/typeOfDate-008.js.map +7 -1
- package/dist/typeOfDate-008.test.js +40 -0
- package/dist/typeOfDate-008.test.js.map +7 -0
- package/dist/unicode-decomposition.js +94 -107
- package/dist/unicode-decomposition.js.map +7 -1
- package/dist/unicode-decomposition.test.js +94 -0
- package/dist/unicode-decomposition.test.js.map +7 -0
- package/dist/update-field-540.js +30 -75
- package/dist/update-field-540.js.map +7 -1
- package/dist/update-field-540.test.js +44 -0
- package/dist/update-field-540.test.js.map +7 -0
- package/dist/urn.js +55 -128
- package/dist/urn.js.map +7 -1
- package/dist/urn.test.js +44 -0
- package/dist/urn.test.js.map +7 -0
- package/dist/utils.js +72 -126
- package/dist/utils.js.map +7 -1
- package/eslint.config.mjs +1 -2
- package/package.json +21 -93
- package/src/access-rights.js +1 -1
- package/src/{access-rights.spec.js → access-rights.test.js} +9 -10
- package/src/addMissingField041.js +1 -1
- package/src/{addMissingField336.spec.js → addMissingField041.test.js} +13 -14
- package/src/addMissingField336.js +3 -3
- package/src/{addMissingField041.spec.js → addMissingField336.test.js} +13 -14
- package/src/addMissingField337.js +2 -2
- package/src/{addMissingField337.spec.js → addMissingField337.test.js} +13 -14
- package/src/addMissingField338.js +2 -2
- package/src/{addMissingField338.spec.js → addMissingField338.test.js} +13 -14
- package/src/cyrillux-usemarcon-replacement.js +18 -18
- package/src/cyrillux-usemarcon-replacement.test.js +55 -0
- package/src/cyrillux.js +19 -12
- package/src/{cyrillux.spec.js → cyrillux.test.js} +13 -14
- package/src/disambiguateSeriesStatements.js +2 -2
- package/src/{disambiguateSeriesStatements.spec.js → disambiguateSeriesStatements.test.js} +12 -13
- package/src/double-commas.js +1 -1
- package/src/{double-commas.spec.js → double-commas.test.js} +9 -11
- package/src/duplicates-ind1.js +1 -1
- package/src/{duplicates-ind1.spec.js → duplicates-ind1.test.js} +12 -13
- package/src/{empty-fields.spec.js → empty-fields.test.js} +11 -13
- package/src/ending-punctuation.js +1 -1
- package/src/{ending-punctuation.spec.js → ending-punctuation.test.js} +172 -173
- package/src/{ending-whitespace.spec.js → ending-whitespace.test.js} +12 -13
- package/src/field-008-18-34-character-groups.js +2 -2
- package/src/{field-008-18-34-character-groups.spec.js → field-008-18-34-character-groups.test.js} +13 -13
- package/src/field-505-separators.js +3 -3
- package/src/{field-505-separators.spec.js → field-505-separators.test.js} +16 -14
- package/src/field-521-fix.js +2 -2
- package/src/{field-521-fix.spec.js → field-521-fix.test.js} +12 -13
- package/src/field-exclusion.js +1 -1
- package/src/{field-exclusion.spec.js → field-exclusion.test.js} +60 -57
- package/src/{field-structure.spec.js → field-structure.test.js} +29 -29
- package/src/{fields-present.spec.js → fields-present.test.js} +12 -15
- package/src/fix-33X.js +4 -4
- package/src/{fix-33X.spec.js → fix-33X.test.js} +13 -14
- package/src/fix-country-codes.js +1 -1
- package/src/{fix-country-codes.spec.js → fix-country-codes.test.js} +12 -13
- package/src/fix-language-codes.js +5 -5
- package/src/{fix-language-codes.spec.js → fix-language-codes.test.js} +12 -13
- package/src/fixRelatorTerms.js +5 -5
- package/src/{fixRelatorTerms.spec.js → fixRelatorTerms.test.js} +13 -13
- package/src/{fixed-fields.spec.js → fixed-fields.test.js} +11 -14
- package/src/identical-fields.js +1 -1
- package/src/{identical-fields.spec.js → identical-fields.test.js} +9 -11
- package/src/indicator-fixes.js +3 -3
- package/src/{indicator-fixes.spec.js → indicator-fixes.test.js} +9 -12
- package/src/isbn-issn.js +1 -1
- package/src/{isbn-issn.spec.js → isbn-issn.test.js} +20 -22
- package/src/{item-language.spec.js → item-language.test.js} +21 -22
- package/src/merge-fields/controlSubfields.js +1 -1
- package/src/merge-fields/counterpartField.js +8 -9
- package/src/merge-fields/index.js +1 -1
- package/src/merge-fields/mergableIndicator.js +1 -1
- package/src/merge-fields/mergeField.js +6 -6
- package/src/merge-fields/mergeIndicator.js +1 -1
- package/src/merge-fields/mergeOrAddPostprocess.js +4 -4
- package/src/merge-fields/mergeOrAddSubfield.js +2 -2
- package/src/merge-fields/mergeSubfield.js +4 -4
- package/src/merge-fields/removeDuplicateSubfields.js +2 -2
- package/src/{merge-fields.spec.js → merge-fields.test.js} +12 -13
- package/src/{mergeField500Lisapainokset.spec.js → mergeField500Lisapainokset.test.js} +12 -13
- package/src/mergeRelatorTermFields.js +5 -7
- package/src/{mergeRelatorTermFields.spec.js → mergeRelatorTermFields.test.js} +12 -13
- package/src/modernize-502.js +1 -1
- package/src/{modernize-502.spec.js → modernize-502.test.js} +12 -13
- package/src/multiple-subfield-0.js +3 -3
- package/src/{multiple-subfield-0.spec.js → multiple-subfield-0.test.js} +13 -13
- package/src/{non-breaking-space.spec.js → non-breaking-space.test.js} +12 -13
- package/src/normalize-dashes.js +2 -2
- package/src/{normalize-dashes.spec.js → normalize-dashes.test.js} +12 -13
- package/src/normalize-identifiers.js +1 -1
- package/src/{normalize-identifiers.spec.js → normalize-identifiers.test.js} +12 -13
- package/src/normalize-qualifying-information.js +2 -2
- package/src/{normalize-qualifying-information.spec.js → normalize-qualifying-information.test.js} +12 -13
- package/src/normalize-utf8-diacritics.js +2 -2
- package/src/{normalize-utf8-diacritics.spec.js → normalize-utf8-diacritics.test.js} +13 -13
- package/src/normalizeFieldForComparison.js +6 -6
- package/src/normalizeSubfieldValueForComparison.js +1 -1
- package/src/prepublicationUtils.js +4 -4
- package/src/punctuation/index.js +1 -1
- package/src/punctuation/rules/index.js +2 -2
- package/src/{punctuation.spec.js → punctuation.test.js} +12 -13
- package/src/punctuation2.js +4 -4
- package/src/{punctuation2.spec.js → punctuation2.test.js} +12 -13
- package/src/reindexSubfield6OccurenceNumbers.js +5 -7
- package/src/{reindexSubfield6OccurenceNumbers.spec.js → reindexSubfield6OccurenceNumbers.test.js} +12 -13
- package/src/removeDuplicateDataFields.js +11 -19
- package/src/{removeDuplicateDataFields.spec.js → removeDuplicateDataFields.test.js} +12 -13
- package/src/removeInferiorDataFields.js +11 -11
- package/src/{removeInferiorDataFields.spec.js → removeInferiorDataFields.test.js} +13 -13
- package/src/resolvable-ext-references-melinda.js +1 -1
- package/src/{resolvable-ext-references-melinda.spec.js → resolvable-ext-references-melinda.test.js} +42 -27
- package/src/resolveOrphanedSubfield6s.js +5 -5
- package/src/{resolveOrphanedSubfield6s.spec.js → resolveOrphanedSubfield6s.test.js} +13 -13
- package/src/sanitize-vocabulary-source-codes.js +4 -4
- package/src/{sanitize-vocabulary-source-codes.spec.js → sanitize-vocabulary-source-codes.test.js} +16 -14
- package/src/{sort-tags.spec.js → sort-tags.test.js} +9 -11
- package/src/sortFields.js +4 -4
- package/src/{sortFields.spec.js → sortFields.test.js} +12 -13
- package/src/sortRelatorTerms.js +3 -3
- package/src/{sortRelatorTerms.spec.js → sortRelatorTerms.test.js} +13 -13
- package/src/sortSubfields.js +1 -1
- package/src/{sortSubfields.spec.js → sortSubfields.test.js} +13 -13
- package/src/stripPunctuation.js +3 -3
- package/src/{stripPunctuation.spec.js → stripPunctuation.test.js} +13 -13
- package/src/subfield-exclusion.js +1 -1
- package/src/{subfield-exclusion.spec.js → subfield-exclusion.test.js} +45 -36
- package/src/subfield6Utils.js +6 -10
- package/src/subfield8Utils.js +4 -4
- package/src/subfieldValueNormalizations.js +3 -3
- package/src/{subfieldValueNormalizations.spec.js → subfieldValueNormalizations.test.js} +18 -14
- package/src/sync-007-and-300.js +2 -2
- package/src/{sync-007-and-300.spec.js → sync-007-and-300.test.js} +13 -13
- package/src/translate-terms.js +3 -3
- package/src/{translate-terms.spec.js → translate-terms.test.js} +13 -13
- package/src/{typeOfDate-008.spec.js → typeOfDate-008.test.js} +12 -13
- package/src/{unicode-decomposition.spec.js → unicode-decomposition.test.js} +10 -16
- package/src/update-field-540.js +2 -2
- package/src/{update-field-540.spec.js → update-field-540.test.js} +13 -10
- package/src/urn.js +2 -2
- package/src/{urn.spec.js → urn.test.js} +12 -13
- package/src/utils.js +3 -3
- package/test-fixtures/field-505-separators/03/expectedResult.json +3 -1
- package/test-fixtures/field-505-separators/03/record.json +3 -0
- package/test-fixtures/normalize-subfield-value/01/metadata.json +4 -1
- package/test-fixtures/normalize-subfield-value/01/record.json +3 -0
- package/test-fixtures/normalize-subfield-value/02/expectedResult.json +3 -1
- package/test-fixtures/normalize-subfield-value/02/metadata.json +2 -1
- package/test-fixtures/normalize-subfield-value/02/record.json +3 -0
- package/test-fixtures/sanitize-vocabulary-source-codes/f03/expectedResult.json +3 -1
- package/test-fixtures/sanitize-vocabulary-source-codes/f04/expectedResult.json +3 -1
- package/test-fixtures/sanitize-vocabulary-source-codes/v04/metadata.json +1 -4
- package/test-fixtures/sanitize-vocabulary-source-codes/v04/record.json +1 -1
- package/dist/access-rights.spec.js +0 -195
- package/dist/access-rights.spec.js.map +0 -1
- package/dist/addMissingField041.spec.js +0 -45
- package/dist/addMissingField041.spec.js.map +0 -1
- package/dist/addMissingField336.spec.js +0 -45
- package/dist/addMissingField336.spec.js.map +0 -1
- package/dist/addMissingField337.spec.js +0 -43
- package/dist/addMissingField337.spec.js.map +0 -1
- package/dist/addMissingField338.spec.js +0 -45
- package/dist/addMissingField338.spec.js.map +0 -1
- package/dist/cyrillux-usemarcon-replacement.spec.js +0 -45
- package/dist/cyrillux-usemarcon-replacement.spec.js.map +0 -1
- package/dist/cyrillux.spec.js +0 -46
- package/dist/cyrillux.spec.js.map +0 -1
- package/dist/disambiguateSeriesStatements.spec.js +0 -51
- package/dist/disambiguateSeriesStatements.spec.js.map +0 -1
- package/dist/double-commas.spec.js +0 -73
- package/dist/double-commas.spec.js.map +0 -1
- package/dist/duplicates-ind1.spec.js +0 -45
- package/dist/duplicates-ind1.spec.js.map +0 -1
- package/dist/empty-fields.spec.js +0 -118
- package/dist/empty-fields.spec.js.map +0 -1
- package/dist/ending-punctuation.spec.js +0 -2654
- package/dist/ending-punctuation.spec.js.map +0 -1
- package/dist/ending-whitespace.spec.js +0 -42
- package/dist/ending-whitespace.spec.js.map +0 -1
- package/dist/field-008-18-34-character-groups.spec.js +0 -51
- package/dist/field-008-18-34-character-groups.spec.js.map +0 -1
- package/dist/field-505-separators.spec.js +0 -51
- package/dist/field-505-separators.spec.js.map +0 -1
- package/dist/field-521-fix.spec.js +0 -51
- package/dist/field-521-fix.spec.js.map +0 -1
- package/dist/field-exclusion.spec.js +0 -1054
- package/dist/field-exclusion.spec.js.map +0 -1
- package/dist/field-structure.spec.js +0 -535
- package/dist/field-structure.spec.js.map +0 -1
- package/dist/fields-present.spec.js +0 -121
- package/dist/fields-present.spec.js.map +0 -1
- package/dist/fix-33X.spec.js +0 -45
- package/dist/fix-33X.spec.js.map +0 -1
- package/dist/fix-country-codes.spec.js +0 -51
- package/dist/fix-country-codes.spec.js.map +0 -1
- package/dist/fix-language-codes.spec.js +0 -44
- package/dist/fix-language-codes.spec.js.map +0 -1
- package/dist/fixRelatorTerms.spec.js +0 -51
- package/dist/fixRelatorTerms.spec.js.map +0 -1
- package/dist/fixed-fields.spec.js +0 -140
- package/dist/fixed-fields.spec.js.map +0 -1
- package/dist/identical-fields.spec.js +0 -99
- package/dist/identical-fields.spec.js.map +0 -1
- package/dist/indicator-fixes.spec.js +0 -51
- package/dist/indicator-fixes.spec.js.map +0 -1
- package/dist/isbn-issn.spec.js +0 -595
- package/dist/isbn-issn.spec.js.map +0 -1
- package/dist/item-language.spec.js +0 -306
- package/dist/item-language.spec.js.map +0 -1
- package/dist/melindaCustomMergeFields.json +0 -5120
- package/dist/merge-fields.spec.js +0 -51
- package/dist/merge-fields.spec.js.map +0 -1
- package/dist/mergeField500Lisapainokset.spec.js +0 -51
- package/dist/mergeField500Lisapainokset.spec.js.map +0 -1
- package/dist/mergeRelatorTermFields.spec.js +0 -51
- package/dist/mergeRelatorTermFields.spec.js.map +0 -1
- package/dist/modernize-502.spec.js +0 -49
- package/dist/modernize-502.spec.js.map +0 -1
- package/dist/multiple-subfield-0.spec.js +0 -51
- package/dist/multiple-subfield-0.spec.js.map +0 -1
- package/dist/non-breaking-space.spec.js +0 -42
- package/dist/non-breaking-space.spec.js.map +0 -1
- package/dist/normalize-dashes.spec.js +0 -51
- package/dist/normalize-dashes.spec.js.map +0 -1
- package/dist/normalize-identifiers.spec.js +0 -51
- package/dist/normalize-identifiers.spec.js.map +0 -1
- package/dist/normalize-qualifying-information.spec.js +0 -51
- package/dist/normalize-qualifying-information.spec.js.map +0 -1
- package/dist/normalize-utf8-diacritics.spec.js +0 -51
- package/dist/normalize-utf8-diacritics.spec.js.map +0 -1
- package/dist/punctuation.spec.js +0 -51
- package/dist/punctuation.spec.js.map +0 -1
- package/dist/punctuation2.spec.js +0 -51
- package/dist/punctuation2.spec.js.map +0 -1
- package/dist/reindexSubfield6OccurenceNumbers.spec.js +0 -51
- package/dist/reindexSubfield6OccurenceNumbers.spec.js.map +0 -1
- package/dist/removeDuplicateDataFields.spec.js +0 -51
- package/dist/removeDuplicateDataFields.spec.js.map +0 -1
- package/dist/removeInferiorDataFields.spec.js +0 -51
- package/dist/removeInferiorDataFields.spec.js.map +0 -1
- package/dist/resolvable-ext-references-melinda.spec.js +0 -166
- package/dist/resolvable-ext-references-melinda.spec.js.map +0 -1
- package/dist/resolveOrphanedSubfield6s.spec.js +0 -51
- package/dist/resolveOrphanedSubfield6s.spec.js.map +0 -1
- package/dist/sanitize-vocabulary-source-codes.spec.js +0 -51
- package/dist/sanitize-vocabulary-source-codes.spec.js.map +0 -1
- package/dist/sort-tags.spec.js +0 -207
- package/dist/sort-tags.spec.js.map +0 -1
- package/dist/sortFields.spec.js +0 -51
- package/dist/sortFields.spec.js.map +0 -1
- package/dist/sortRelatorTerms.spec.js +0 -51
- package/dist/sortRelatorTerms.spec.js.map +0 -1
- package/dist/sortSubfields.spec.js +0 -52
- package/dist/sortSubfields.spec.js.map +0 -1
- package/dist/stripPunctuation.spec.js +0 -51
- package/dist/stripPunctuation.spec.js.map +0 -1
- package/dist/subfield-exclusion.spec.js +0 -523
- package/dist/subfield-exclusion.spec.js.map +0 -1
- package/dist/subfieldValueNormalizations.spec.js +0 -51
- package/dist/subfieldValueNormalizations.spec.js.map +0 -1
- package/dist/sync-007-and-300.spec.js +0 -51
- package/dist/sync-007-and-300.spec.js.map +0 -1
- package/dist/translate-terms.spec.js +0 -51
- package/dist/translate-terms.spec.js.map +0 -1
- package/dist/typeOfDate-008.spec.js +0 -47
- package/dist/typeOfDate-008.spec.js.map +0 -1
- package/dist/unicode-decomposition.spec.js +0 -91
- package/dist/unicode-decomposition.spec.js.map +0 -1
- package/dist/update-field-540.spec.js +0 -51
- package/dist/update-field-540.spec.js.map +0 -1
- package/dist/urn.spec.js +0 -52
- package/dist/urn.spec.js.map +0 -1
- package/src/cyrillux-usemarcon-replacement.spec.js +0 -47
|
@@ -1,17 +1,15 @@
|
|
|
1
|
-
import
|
|
1
|
+
import assert from 'node:assert';
|
|
2
2
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
-
import validatorFactory from '../src/isbn-issn';
|
|
3
|
+
import validatorFactory from '../src/isbn-issn.js';
|
|
4
|
+
import {describe, it} from 'node:test';
|
|
4
5
|
|
|
5
6
|
describe('isbn-issn', () => {
|
|
6
7
|
it('Creates a validator', async () => {
|
|
7
8
|
const validator = await validatorFactory();
|
|
8
9
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
expect(validator.description).to.be.a('string');
|
|
14
|
-
expect(validator.validate).to.be.a('function');
|
|
10
|
+
assert.equal(typeof validator, 'object');
|
|
11
|
+
assert.equal(typeof validator.description, 'string');
|
|
12
|
+
assert.equal(typeof validator.validate, 'function');
|
|
15
13
|
});
|
|
16
14
|
|
|
17
15
|
describe('#validate', () => {
|
|
@@ -42,7 +40,7 @@ describe('isbn-issn', () => {
|
|
|
42
40
|
});
|
|
43
41
|
const result = await validator.validate(record);
|
|
44
42
|
|
|
45
|
-
|
|
43
|
+
assert.deepEqual(result, {valid: true});
|
|
46
44
|
});
|
|
47
45
|
|
|
48
46
|
it('Finds the record invalid', async () => {
|
|
@@ -71,7 +69,7 @@ describe('isbn-issn', () => {
|
|
|
71
69
|
});
|
|
72
70
|
const result = await validator.validate(record);
|
|
73
71
|
|
|
74
|
-
|
|
72
|
+
assert.deepEqual(result, {
|
|
75
73
|
valid: false, messages: [
|
|
76
74
|
'ISBN (foo) is not valid',
|
|
77
75
|
'ISSN (bar) is not valid'
|
|
@@ -93,7 +91,7 @@ describe('isbn-issn', () => {
|
|
|
93
91
|
});
|
|
94
92
|
const result = await validator.validate(record);
|
|
95
93
|
|
|
96
|
-
|
|
94
|
+
assert.deepEqual(result, {
|
|
97
95
|
valid: true
|
|
98
96
|
});
|
|
99
97
|
});
|
|
@@ -112,7 +110,7 @@ describe('isbn-issn', () => {
|
|
|
112
110
|
});
|
|
113
111
|
const result = await validator.validate(record);
|
|
114
112
|
|
|
115
|
-
|
|
113
|
+
assert.deepEqual(result, {
|
|
116
114
|
valid: false, messages: ['ISSN (undefined) is not valid']
|
|
117
115
|
});
|
|
118
116
|
});
|
|
@@ -131,7 +129,7 @@ describe('isbn-issn', () => {
|
|
|
131
129
|
});
|
|
132
130
|
const result = await validator.validate(record);
|
|
133
131
|
|
|
134
|
-
|
|
132
|
+
assert.deepEqual(result, {valid: false, messages: ['ISBN (978-600-377-017-1 (nid.)) is not valid']});
|
|
135
133
|
});
|
|
136
134
|
|
|
137
135
|
it('Finds the record invalid (ISSN in \'l\'-subfield)', async () => {
|
|
@@ -154,7 +152,7 @@ describe('isbn-issn', () => {
|
|
|
154
152
|
});
|
|
155
153
|
const result = await validator.validate(record);
|
|
156
154
|
|
|
157
|
-
|
|
155
|
+
assert.deepEqual(result, {
|
|
158
156
|
valid: false, messages: [
|
|
159
157
|
'ISBN (foo) is not valid',
|
|
160
158
|
'ISSN (bar) is not valid'
|
|
@@ -188,7 +186,7 @@ describe('isbn-issn', () => {
|
|
|
188
186
|
});
|
|
189
187
|
const result = await validator.validate(record);
|
|
190
188
|
|
|
191
|
-
|
|
189
|
+
assert.deepEqual(result, {valid: false, messages: [
|
|
192
190
|
'ISBN (9789519155470) is not valid',
|
|
193
191
|
'ISBN (9068-31-372-X) is not valid',
|
|
194
192
|
'ISBN (386006004X) is not valid'
|
|
@@ -220,7 +218,7 @@ describe('isbn-issn', () => {
|
|
|
220
218
|
|
|
221
219
|
await validator.fix(record);
|
|
222
220
|
|
|
223
|
-
|
|
221
|
+
assert.deepEqual(record.fields, [
|
|
224
222
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'z', value: 'foo'}]},
|
|
225
223
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'z', value: 'crappy val'}]},
|
|
226
224
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'z', value: '97895234216609'}]},
|
|
@@ -241,7 +239,7 @@ describe('isbn-issn', () => {
|
|
|
241
239
|
|
|
242
240
|
await validator.fix(record);
|
|
243
241
|
|
|
244
|
-
|
|
242
|
+
assert.deepEqual(record.fields, [
|
|
245
243
|
{
|
|
246
244
|
tag: '022', ind1: ' ', ind2: ' ', subfields: [{code: 'y', value: 'foo'}]
|
|
247
245
|
}
|
|
@@ -261,7 +259,7 @@ describe('isbn-issn', () => {
|
|
|
261
259
|
|
|
262
260
|
await validator.fix(record);
|
|
263
261
|
|
|
264
|
-
|
|
262
|
+
assert.deepEqual(record.fields, [
|
|
265
263
|
{
|
|
266
264
|
tag: '022', ind1: ' ', ind2: ' ', subfields: [{code: 'y', value: 'foo'}]
|
|
267
265
|
}
|
|
@@ -288,7 +286,7 @@ describe('isbn-issn', () => {
|
|
|
288
286
|
});
|
|
289
287
|
await validator.fix(record);
|
|
290
288
|
|
|
291
|
-
|
|
289
|
+
assert.deepEqual(record.fields, [
|
|
292
290
|
// NB! Initial space does not need to be removed. It's crap, but not this fixer's crap.
|
|
293
291
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: ' 9786003770171'}]},
|
|
294
292
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: '9786003770171'}, {code: 'q', value: '(nidottu)'}]}
|
|
@@ -313,7 +311,7 @@ describe('isbn-issn', () => {
|
|
|
313
311
|
});
|
|
314
312
|
await validator.fix(record);
|
|
315
313
|
|
|
316
|
-
|
|
314
|
+
assert.deepEqual(record.fields, [
|
|
317
315
|
{
|
|
318
316
|
tag: '020',
|
|
319
317
|
ind1: ' ',
|
|
@@ -353,7 +351,7 @@ describe('isbn-issn', () => {
|
|
|
353
351
|
});
|
|
354
352
|
await validator.fix(record);
|
|
355
353
|
|
|
356
|
-
|
|
354
|
+
assert.deepEqual(record.fields, [
|
|
357
355
|
{tag: '005', value: 'whatever'},
|
|
358
356
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'q', value: 'sidottu'}]},
|
|
359
357
|
{tag: '024', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: ' 9786003770171'}]}
|
|
@@ -392,7 +390,7 @@ describe('isbn-issn', () => {
|
|
|
392
390
|
|
|
393
391
|
await validator.fix(record);
|
|
394
392
|
|
|
395
|
-
|
|
393
|
+
assert.deepEqual(record.fields, [
|
|
396
394
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: '978-9916-605-32-5'}]},
|
|
397
395
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: '91-7153-086-X'}]},
|
|
398
396
|
{tag: '020', ind1: ' ', ind2: ' ', subfields: [{code: 'a', value: '90-6831-372-X'}]}, // corrected hyphens
|
|
@@ -1,25 +1,24 @@
|
|
|
1
|
-
import
|
|
2
|
-
import chaiAsPromised from 'chai-as-promised';
|
|
1
|
+
import assert from 'node:assert';
|
|
3
2
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
4
|
-
import validatorFactory from '../src/item-language';
|
|
5
|
-
|
|
6
|
-
const {expect} = chai;
|
|
7
|
-
chai.use(chaiAsPromised);
|
|
3
|
+
import validatorFactory from '../src/item-language.js';
|
|
4
|
+
import {describe, it} from 'node:test';
|
|
8
5
|
|
|
9
6
|
describe('item-language', () => {
|
|
10
7
|
it('Creates a validator', async () => {
|
|
11
8
|
const validator = await validatorFactory(/^520$/u);
|
|
12
9
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
expect(validator.description).to.be.a('string');
|
|
18
|
-
expect(validator.validate).to.be.a('function');
|
|
10
|
+
assert.equal(typeof validator, 'object');
|
|
11
|
+
assert.equal(typeof validator.description, 'string');
|
|
12
|
+
assert.equal(typeof validator.validate, 'function');
|
|
19
13
|
});
|
|
20
14
|
|
|
21
15
|
it('Throws an error when tagPattern is not provided', async () => {
|
|
22
|
-
await
|
|
16
|
+
await assert.rejects(validatorFactory(), (err) => {
|
|
17
|
+
assert.equal(err instanceof Error, true);
|
|
18
|
+
assert.equal(err.message, 'No tagPattern provided');
|
|
19
|
+
return true;
|
|
20
|
+
});
|
|
21
|
+
//await assert(validatorFactory()).to.be.rejectedWith(Error, 'No tagPattern provided');
|
|
23
22
|
});
|
|
24
23
|
|
|
25
24
|
describe('#validate', () => {
|
|
@@ -48,7 +47,7 @@ describe('item-language', () => {
|
|
|
48
47
|
});
|
|
49
48
|
const result = await validator.validate(record);
|
|
50
49
|
|
|
51
|
-
|
|
50
|
+
assert.deepEqual(result, {valid: true});
|
|
52
51
|
});
|
|
53
52
|
|
|
54
53
|
it('Finds the record invalid (Language code is missing and detection failed', async () => {
|
|
@@ -70,7 +69,7 @@ describe('item-language', () => {
|
|
|
70
69
|
});
|
|
71
70
|
const result = await validator.validate(record);
|
|
72
71
|
|
|
73
|
-
|
|
72
|
+
assert.deepEqual(result, {valid: false, messages: ['Language detection failed']});
|
|
74
73
|
});
|
|
75
74
|
|
|
76
75
|
it('Finds the record invalid (Detected language differs)', async () => {
|
|
@@ -102,7 +101,7 @@ describe('item-language', () => {
|
|
|
102
101
|
});
|
|
103
102
|
const result = await validator.validate(record);
|
|
104
103
|
|
|
105
|
-
|
|
104
|
+
assert.deepEqual(result, {valid: false, messages: ['Item language code is invalid. Correct language code: eng']});
|
|
106
105
|
});
|
|
107
106
|
|
|
108
107
|
it('Finds the record invalid (Probability doesn\'t meet treshold)', async () => {
|
|
@@ -134,7 +133,7 @@ describe('item-language', () => {
|
|
|
134
133
|
});
|
|
135
134
|
const result = await validator.validate(record);
|
|
136
135
|
|
|
137
|
-
|
|
136
|
+
assert.deepEqual(result, {valid: true, messages: ['Item language code is invalid. Current code: fin, suggestions: eng']});
|
|
138
137
|
});
|
|
139
138
|
|
|
140
139
|
it('Finds the record invalid (No detectable text)', async () => {
|
|
@@ -155,7 +154,7 @@ describe('item-language', () => {
|
|
|
155
154
|
});
|
|
156
155
|
const result = await validator.validate(record);
|
|
157
156
|
|
|
158
|
-
|
|
157
|
+
assert.deepEqual(result, {valid: true, messages: ['Language detection failed']});
|
|
159
158
|
});
|
|
160
159
|
});
|
|
161
160
|
|
|
@@ -189,7 +188,7 @@ describe('item-language', () => {
|
|
|
189
188
|
});
|
|
190
189
|
await validator.fix(record);
|
|
191
190
|
|
|
192
|
-
|
|
191
|
+
assert.deepEqual(record.fields, [
|
|
193
192
|
{
|
|
194
193
|
tag: '008',
|
|
195
194
|
value: '151118t20162016fi^a|||^^^^^^^|0|^0|eng|^'
|
|
@@ -237,7 +236,7 @@ describe('item-language', () => {
|
|
|
237
236
|
});
|
|
238
237
|
await validator.fix(record);
|
|
239
238
|
|
|
240
|
-
|
|
239
|
+
assert.deepEqual(record.fields, [
|
|
241
240
|
{
|
|
242
241
|
tag: '008',
|
|
243
242
|
value: '151118t20162016fi^a|||^^^^^^^|0|^0|eng|^'
|
|
@@ -291,7 +290,7 @@ describe('item-language', () => {
|
|
|
291
290
|
});
|
|
292
291
|
await validator.fix(record);
|
|
293
292
|
|
|
294
|
-
|
|
293
|
+
assert.deepEqual(record.fields, [
|
|
295
294
|
{
|
|
296
295
|
tag: '008',
|
|
297
296
|
value: '151118t20162016fi^a|||^^^^^^^|0|^0|eng|^'
|
|
@@ -337,7 +336,7 @@ describe('item-language', () => {
|
|
|
337
336
|
try {
|
|
338
337
|
await validator.fix(record);
|
|
339
338
|
} catch (err) {
|
|
340
|
-
|
|
339
|
+
assert.equal(err.message, 'Language code is missing and detection failed');
|
|
341
340
|
}
|
|
342
341
|
});
|
|
343
342
|
});
|
|
@@ -3,7 +3,7 @@ import createDebugLogger from 'debug';
|
|
|
3
3
|
import {fieldHasSubfield, fieldToString, nvdebug, nvdebugSubfieldArray, subfieldIsRepeatable, subfieldsAreIdentical} from '../utils.js';
|
|
4
4
|
|
|
5
5
|
//import {normalizeControlSubfieldValue} from './normalizeIdentifier';
|
|
6
|
-
import {normalizeControlSubfieldValue} from '../normalize-identifiers';
|
|
6
|
+
import {normalizeControlSubfieldValue} from '../normalize-identifiers.js';
|
|
7
7
|
|
|
8
8
|
const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda:merge-fields:controlSubfields');
|
|
9
9
|
//const debugData = debug.extend('data');
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
// For each incoming field that
|
|
2
2
|
|
|
3
3
|
import createDebugLogger from 'debug';
|
|
4
|
-
import {fieldHasSubfield, fieldHasNSubfields, fieldHasMultipleSubfields, fieldToString, nvdebug, removeCopyright} from '../utils';
|
|
5
|
-
import {cloneAndNormalizeFieldForComparison, cloneAndRemovePunctuation} from '../normalizeFieldForComparison';
|
|
4
|
+
import {fieldHasSubfield, fieldHasNSubfields, fieldHasMultipleSubfields, fieldToString, nvdebug, removeCopyright} from '../utils.js';
|
|
5
|
+
import {cloneAndNormalizeFieldForComparison, cloneAndRemovePunctuation} from '../normalizeFieldForComparison.js';
|
|
6
6
|
// This should be done via our own normalizer:
|
|
7
|
-
import {normalizeControlSubfieldValue} from '../normalize-identifiers';
|
|
7
|
+
import {normalizeControlSubfieldValue} from '../normalize-identifiers.js';
|
|
8
8
|
|
|
9
|
-
import {getMergeConstraintsForTag} from './mergeConstraints';
|
|
10
|
-
import {controlSubfieldsPermitMerge} from './controlSubfields';
|
|
11
|
-
import {mergableIndicator1, mergableIndicator2} from './mergableIndicator';
|
|
12
|
-
import {partsAgree} from '../normalizeSubfieldValueForComparison';
|
|
13
|
-
import {normalizeForSamenessCheck, valueCarriesMeaning} from './worldKnowledge';
|
|
9
|
+
import {getMergeConstraintsForTag} from './mergeConstraints.js';
|
|
10
|
+
import {controlSubfieldsPermitMerge} from './controlSubfields.js';
|
|
11
|
+
import {mergableIndicator1, mergableIndicator2} from './mergableIndicator.js';
|
|
12
|
+
import {partsAgree} from '../normalizeSubfieldValueForComparison.js';
|
|
13
|
+
import {normalizeForSamenessCheck, valueCarriesMeaning} from './worldKnowledge.js';
|
|
14
14
|
|
|
15
15
|
const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda:mergeField:counterpart');
|
|
16
16
|
//const debugData = debug.extend('data');
|
|
@@ -201,7 +201,6 @@ function counterpartExtraNormalize(tag, subfieldCode, value) {
|
|
|
201
201
|
value = value.replace(/http:\/\//ug, 'https://'); // MET-501: http vs https
|
|
202
202
|
value = normalizeForSamenessCheck(tag, subfieldCode, value);
|
|
203
203
|
|
|
204
|
-
/* eslint-enable */
|
|
205
204
|
return value;
|
|
206
205
|
}
|
|
207
206
|
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
//import createDebugLogger from 'debug';
|
|
9
9
|
//import fs from 'fs';
|
|
10
10
|
//import path from 'path';
|
|
11
|
-
import {mergeField} from './mergeField';
|
|
11
|
+
import {mergeField} from './mergeField.js';
|
|
12
12
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
13
13
|
import {postprocessRecords} from './mergeOrAddPostprocess.js';
|
|
14
14
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import createDebugLogger from 'debug';
|
|
2
|
-
import {marc21GetTagsLegalInd1Value, marc21GetTagsLegalInd2Value, nvdebug} from '../utils';
|
|
2
|
+
import {marc21GetTagsLegalInd1Value, marc21GetTagsLegalInd2Value, nvdebug} from '../utils.js';
|
|
3
3
|
|
|
4
4
|
// Specs: https://workgroups.helsinki.fi/x/K1ohCw (though we occasionally differ from them)...
|
|
5
5
|
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
//import {MarcRecord} from '@natlibfi/marc-record';
|
|
2
2
|
import createDebugLogger from 'debug';
|
|
3
|
-
import {fieldToString, fieldsToString, fieldsAreIdentical, nvdebug, hasCopyright, removeCopyright, subfieldToString} from '../utils';
|
|
3
|
+
import {fieldToString, fieldsToString, fieldsAreIdentical, nvdebug, hasCopyright, removeCopyright, subfieldToString} from '../utils.js';
|
|
4
4
|
import {fieldGetOccurrenceNumberPairs} from '../subfield6Utils.js';
|
|
5
|
-
import {cloneAndNormalizeFieldForComparison, cloneAndRemovePunctuation, isEnnakkotietoSubfieldG} from '../normalizeFieldForComparison';
|
|
6
|
-
import {mergeOrAddSubfield} from './mergeOrAddSubfield';
|
|
7
|
-
import {mergeIndicators} from './mergeIndicator';
|
|
8
|
-
import {mergableTag} from './mergableTag';
|
|
9
|
-
import {getCounterpart} from './counterpartField';
|
|
5
|
+
import {cloneAndNormalizeFieldForComparison, cloneAndRemovePunctuation, isEnnakkotietoSubfieldG} from '../normalizeFieldForComparison.js';
|
|
6
|
+
import {mergeOrAddSubfield} from './mergeOrAddSubfield.js';
|
|
7
|
+
import {mergeIndicators} from './mergeIndicator.js';
|
|
8
|
+
import {mergableTag} from './mergableTag.js';
|
|
9
|
+
import {getCounterpart} from './counterpartField.js';
|
|
10
10
|
//import {default as normalizeEncoding} from '@natlibfi/marc-record-validators-melinda/dist/normalize-utf8-diacritics';
|
|
11
11
|
//import {postprocessRecords} from './mergeOrAddPostprocess.js';
|
|
12
12
|
//import {preprocessBeforeAdd} from './processFilter.js';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import createDebugLogger from 'debug';
|
|
2
|
-
import {fieldToString, marc21GetTagsLegalInd1Value, marc21GetTagsLegalInd2Value, nvdebug} from '../utils';
|
|
2
|
+
import {fieldToString, marc21GetTagsLegalInd1Value, marc21GetTagsLegalInd2Value, nvdebug} from '../utils.js';
|
|
3
3
|
|
|
4
4
|
// Specs: https://workgroups.helsinki.fi/x/K1ohCw (though we occasionally differ from them)...
|
|
5
5
|
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
// This field should be renamed, as it is called also from outside megre.
|
|
2
2
|
|
|
3
3
|
//import {MarcRecord} from '@natlibfi/marc-record';
|
|
4
|
-
import {fieldFixPunctuation} from '../punctuation2';
|
|
5
|
-
import {fieldRemoveDuplicateSubfields} from './removeDuplicateSubfields';
|
|
6
|
-
import {sortAdjacentSubfields} from '../sortSubfields';
|
|
7
|
-
import {sortAdjacentRelatorTerms} from '../sortRelatorTerms';
|
|
4
|
+
import {fieldFixPunctuation} from '../punctuation2.js';
|
|
5
|
+
import {fieldRemoveDuplicateSubfields} from './removeDuplicateSubfields.js';
|
|
6
|
+
import {sortAdjacentSubfields} from '../sortSubfields.js';
|
|
7
|
+
import {sortAdjacentRelatorTerms} from '../sortRelatorTerms.js';
|
|
8
8
|
|
|
9
9
|
function postprocessBaseRecord(base) {
|
|
10
10
|
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import createDebugLogger from 'debug';
|
|
2
2
|
import {cloneAndNormalizeFieldForComparison, isEnnakkotietoSubfieldG} from '../normalizeFieldForComparison.js';
|
|
3
|
-
import {normalizeAs, normalizeControlSubfieldValue} from '../normalize-identifiers';
|
|
3
|
+
import {normalizeAs, normalizeControlSubfieldValue} from '../normalize-identifiers.js';
|
|
4
4
|
import {fieldHasSubfield, fieldToString, isControlSubfieldCode, nvdebug, subfieldIsRepeatable, subfieldToString} from '../utils.js';
|
|
5
5
|
import {mergeSubfield} from './mergeSubfield.js';
|
|
6
|
-
import {sortAdjacentSubfields} from '../sortSubfields
|
|
6
|
+
import {sortAdjacentSubfields} from '../sortSubfields.js';
|
|
7
7
|
|
|
8
8
|
import {valueCarriesMeaning} from './worldKnowledge.js';
|
|
9
9
|
import {resetSubfield6Tag} from '../subfield6Utils.js';
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import createDebugLogger from 'debug';
|
|
2
|
-
import {partsAgree, subfieldContainsPartData} from '../normalizeSubfieldValueForComparison';
|
|
3
|
-
import {valueCarriesMeaning} from './worldKnowledge';
|
|
4
|
-
import {nvdebug} from '../utils';
|
|
2
|
+
import {partsAgree, subfieldContainsPartData} from '../normalizeSubfieldValueForComparison.js';
|
|
3
|
+
import {valueCarriesMeaning} from './worldKnowledge.js';
|
|
4
|
+
import {nvdebug} from '../utils.js';
|
|
5
5
|
import {tagAndSubfieldCodeReferToIsbn} from '../normalizeFieldForComparison.js';
|
|
6
|
-
import {canContainOptionalQualifier, splitToNameAndQualifier} from './counterpartField';
|
|
6
|
+
import {canContainOptionalQualifier, splitToNameAndQualifier} from './counterpartField.js';
|
|
7
7
|
|
|
8
8
|
const debug = createDebugLogger('@natlibfi/melinda-marc-record-merge-reducers:mergeSubfield');
|
|
9
9
|
//const debugData = debug.extend('data');
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
import {nvdebug, subfieldToString} from '../utils.js';
|
|
3
3
|
import createDebugLogger from 'debug';
|
|
4
4
|
import {cloneAndRemovePunctuation} from '../normalizeFieldForComparison.js';
|
|
5
|
-
import {sortAdjacentSubfields} from '../sortSubfields';
|
|
6
|
-
import {fieldFixPunctuation} from '../punctuation2';
|
|
5
|
+
import {sortAdjacentSubfields} from '../sortSubfields.js';
|
|
6
|
+
import {fieldFixPunctuation} from '../punctuation2.js';
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
// NB This should be moved and converted to a validator/fixer as well...
|
|
@@ -1,20 +1,22 @@
|
|
|
1
|
-
import
|
|
1
|
+
import assert from 'node:assert';
|
|
2
2
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
-
import validatorFactory from './merge-fields/';
|
|
3
|
+
import validatorFactory from './merge-fields/index.js';
|
|
4
4
|
import {READERS} from '@natlibfi/fixura';
|
|
5
5
|
import generateTests from '@natlibfi/fixugen';
|
|
6
6
|
import createDebugLogger from 'debug';
|
|
7
7
|
|
|
8
8
|
generateTests({
|
|
9
9
|
callback,
|
|
10
|
-
path: [
|
|
10
|
+
path: [import.meta.dirname, '..', 'test-fixtures', 'merge-fields'],
|
|
11
11
|
useMetadataFile: true,
|
|
12
12
|
recurse: false,
|
|
13
13
|
fixura: {
|
|
14
14
|
reader: READERS.JSON
|
|
15
15
|
},
|
|
16
|
-
|
|
17
|
-
before: () =>
|
|
16
|
+
hooks: {
|
|
17
|
+
before: async () => {
|
|
18
|
+
testValidatorFactory();
|
|
19
|
+
}
|
|
18
20
|
}
|
|
19
21
|
});
|
|
20
22
|
const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/merge-fields:test');
|
|
@@ -22,12 +24,9 @@ const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/merge-
|
|
|
22
24
|
async function testValidatorFactory() {
|
|
23
25
|
const validator = await validatorFactory();
|
|
24
26
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
expect(validator.description).to.be.a('string');
|
|
30
|
-
expect(validator.validate).to.be.a('function');
|
|
27
|
+
assert.equal(typeof validator, 'object');
|
|
28
|
+
assert.equal(typeof validator.description, 'string');
|
|
29
|
+
assert.equal(typeof validator.validate, 'function');
|
|
31
30
|
}
|
|
32
31
|
|
|
33
32
|
async function callback({getFixture, enabled = true, fix = false}) {
|
|
@@ -43,10 +42,10 @@ async function callback({getFixture, enabled = true, fix = false}) {
|
|
|
43
42
|
|
|
44
43
|
if (!fix) {
|
|
45
44
|
const result = await validator.validate(record);
|
|
46
|
-
|
|
45
|
+
assert.deepEqual(result, expectedResult);
|
|
47
46
|
return;
|
|
48
47
|
}
|
|
49
48
|
|
|
50
49
|
await validator.fix(record);
|
|
51
|
-
|
|
50
|
+
assert.deepEqual(record, expectedResult);
|
|
52
51
|
}
|
|
@@ -1,20 +1,22 @@
|
|
|
1
|
-
import
|
|
1
|
+
import assert from 'node:assert';
|
|
2
2
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
-
import validatorFactory from './mergeField500Lisapainokset';
|
|
3
|
+
import validatorFactory from './mergeField500Lisapainokset.js';
|
|
4
4
|
import {READERS} from '@natlibfi/fixura';
|
|
5
5
|
import generateTests from '@natlibfi/fixugen';
|
|
6
6
|
import createDebugLogger from 'debug';
|
|
7
7
|
|
|
8
8
|
generateTests({
|
|
9
9
|
callback,
|
|
10
|
-
path: [
|
|
10
|
+
path: [import.meta.dirname, '..', 'test-fixtures', 'lisapainokset'],
|
|
11
11
|
useMetadataFile: true,
|
|
12
12
|
recurse: true,
|
|
13
13
|
fixura: {
|
|
14
14
|
reader: READERS.JSON
|
|
15
15
|
},
|
|
16
|
-
|
|
17
|
-
before: () =>
|
|
16
|
+
hooks: {
|
|
17
|
+
before: async () => {
|
|
18
|
+
testValidatorFactory();
|
|
19
|
+
}
|
|
18
20
|
}
|
|
19
21
|
});
|
|
20
22
|
const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/mergeField500Lisapainokset:test');
|
|
@@ -22,12 +24,9 @@ const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/mergeF
|
|
|
22
24
|
async function testValidatorFactory() {
|
|
23
25
|
const validator = await validatorFactory();
|
|
24
26
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
expect(validator.description).to.be.a('string');
|
|
30
|
-
expect(validator.validate).to.be.a('function');
|
|
27
|
+
assert.equal(typeof validator, 'object');
|
|
28
|
+
assert.equal(typeof validator.description, 'string');
|
|
29
|
+
assert.equal(typeof validator.validate, 'function');
|
|
31
30
|
}
|
|
32
31
|
|
|
33
32
|
async function callback({getFixture, enabled = true, fix = false}) {
|
|
@@ -43,10 +42,10 @@ async function callback({getFixture, enabled = true, fix = false}) {
|
|
|
43
42
|
|
|
44
43
|
if (!fix) {
|
|
45
44
|
const result = await validator.validate(record);
|
|
46
|
-
|
|
45
|
+
assert.deepEqual(result, expectedResult);
|
|
47
46
|
return;
|
|
48
47
|
}
|
|
49
48
|
|
|
50
49
|
await validator.fix(record);
|
|
51
|
-
|
|
50
|
+
assert.deepEqual(record, expectedResult);
|
|
52
51
|
}
|
|
@@ -7,10 +7,10 @@
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
import clone from 'clone';
|
|
10
|
-
import {fieldFixPunctuation, fieldStripPunctuation} from './punctuation2';
|
|
11
|
-
import {fieldToString, nvdebug} from './utils';
|
|
12
|
-
import {sortAdjacentSubfields} from './sortSubfields';
|
|
13
|
-
import {sortAdjacentRelatorTerms, tagToRelatorTermSubfieldCode} from './sortRelatorTerms';
|
|
10
|
+
import {fieldFixPunctuation, fieldStripPunctuation} from './punctuation2.js';
|
|
11
|
+
import {fieldToString, nvdebug} from './utils.js';
|
|
12
|
+
import {sortAdjacentSubfields} from './sortSubfields.js';
|
|
13
|
+
import {sortAdjacentRelatorTerms, tagToRelatorTermSubfieldCode} from './sortRelatorTerms.js';
|
|
14
14
|
//import createDebugLogger from 'debug';
|
|
15
15
|
/*
|
|
16
16
|
//const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda:mergeRelatorTermFields');
|
|
@@ -74,12 +74,11 @@ function copyRelatorSubfields(fromField, toField) {
|
|
|
74
74
|
const relatorTermSubfieldCode = tagToRelatorTermSubfieldCode(fromField.tag);
|
|
75
75
|
const newRelatorTerms = extractAddableRelatorTerms(fromField, toField);
|
|
76
76
|
|
|
77
|
-
newRelatorTerms.forEach(term => toField.subfields.push({code: relatorTermSubfieldCode, value: term}));
|
|
77
|
+
newRelatorTerms.forEach(term => toField.subfields.push({code: relatorTermSubfieldCode, value: term}));
|
|
78
78
|
|
|
79
79
|
}
|
|
80
80
|
|
|
81
81
|
function mergeRelatorTermFields(record, fix = false) {
|
|
82
|
-
/* eslint-disable */
|
|
83
82
|
// NV: 111/711, 751 and 752 where so rare that I did not add them here. Can't remember why I skipped 6XX and 8XX...
|
|
84
83
|
let fields = record.get('(?:[17][01]0|720)');
|
|
85
84
|
let result = [];
|
|
@@ -128,6 +127,5 @@ function mergeRelatorTermFields(record, fix = false) {
|
|
|
128
127
|
}
|
|
129
128
|
|
|
130
129
|
record.fields = record.fields.filter(f => !f.deleted);
|
|
131
|
-
/* eslint-enable */
|
|
132
130
|
return result;
|
|
133
131
|
}
|
|
@@ -1,20 +1,22 @@
|
|
|
1
|
-
import
|
|
1
|
+
import assert from 'node:assert';
|
|
2
2
|
import {MarcRecord} from '@natlibfi/marc-record';
|
|
3
|
-
import validatorFactory from './mergeRelatorTermFields';
|
|
3
|
+
import validatorFactory from './mergeRelatorTermFields.js';
|
|
4
4
|
import {READERS} from '@natlibfi/fixura';
|
|
5
5
|
import generateTests from '@natlibfi/fixugen';
|
|
6
6
|
import createDebugLogger from 'debug';
|
|
7
7
|
|
|
8
8
|
generateTests({
|
|
9
9
|
callback,
|
|
10
|
-
path: [
|
|
10
|
+
path: [import.meta.dirname, '..', 'test-fixtures', 'mergeRelatorTermFields'],
|
|
11
11
|
useMetadataFile: true,
|
|
12
12
|
recurse: true,
|
|
13
13
|
fixura: {
|
|
14
14
|
reader: READERS.JSON
|
|
15
15
|
},
|
|
16
|
-
|
|
17
|
-
before: () =>
|
|
16
|
+
hooks: {
|
|
17
|
+
before: async () => {
|
|
18
|
+
testValidatorFactory();
|
|
19
|
+
}
|
|
18
20
|
}
|
|
19
21
|
});
|
|
20
22
|
const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/mergeRelatorTermFields:test');
|
|
@@ -22,12 +24,9 @@ const debug = createDebugLogger('@natlibfi/marc-record-validators-melinda/mergeR
|
|
|
22
24
|
async function testValidatorFactory() {
|
|
23
25
|
const validator = await validatorFactory();
|
|
24
26
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
expect(validator.description).to.be.a('string');
|
|
30
|
-
expect(validator.validate).to.be.a('function');
|
|
27
|
+
assert.equal(typeof validator, 'object');
|
|
28
|
+
assert.equal(typeof validator.description, 'string');
|
|
29
|
+
assert.equal(typeof validator.validate, 'function');
|
|
31
30
|
}
|
|
32
31
|
|
|
33
32
|
async function callback({getFixture, enabled = true, fix = false}) {
|
|
@@ -43,10 +42,10 @@ async function callback({getFixture, enabled = true, fix = false}) {
|
|
|
43
42
|
|
|
44
43
|
if (!fix) {
|
|
45
44
|
const result = await validator.validate(record);
|
|
46
|
-
|
|
45
|
+
assert.deepEqual(result, expectedResult);
|
|
47
46
|
return;
|
|
48
47
|
}
|
|
49
48
|
|
|
50
49
|
await validator.fix(record);
|
|
51
|
-
|
|
50
|
+
assert.deepEqual(record, expectedResult);
|
|
52
51
|
}
|
package/src/modernize-502.js
CHANGED