bolognese 2.3.7 → 2.3.9
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.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/README.md +1 -1
- data/bolognese.gemspec +1 -2
- data/lib/bolognese/datacite_utils.rb +10 -3
- data/lib/bolognese/readers/datacite_reader.rb +5 -9
- data/lib/bolognese/utils.rb +4 -2
- data/lib/bolognese/version.rb +1 -1
- metadata +2 -545
- data/spec/array_spec.rb +0 -22
- data/spec/author_utils_spec.rb +0 -259
- data/spec/cli_spec.rb +0 -226
- data/spec/datacite_utils_spec.rb +0 -357
- data/spec/doi_utils_spec.rb +0 -314
- data/spec/find_from_format_spec.rb +0 -114
- data/spec/fixtures/aida.json +0 -82
- data/spec/fixtures/cgimp_package.json +0 -18
- data/spec/fixtures/cit_package.json +0 -19
- data/spec/fixtures/citeproc-no-author.json +0 -26
- data/spec/fixtures/citeproc-no-categories.json +0 -21
- data/spec/fixtures/citeproc.json +0 -36
- data/spec/fixtures/codemeta.json +0 -86
- data/spec/fixtures/codemeta_v2.json +0 -86
- data/spec/fixtures/crosscite.json +0 -63
- data/spec/fixtures/crossref.bib +0 -14
- data/spec/fixtures/crossref.ris +0 -15
- data/spec/fixtures/crossref.xml +0 -606
- data/spec/fixtures/crossref_schema_4.6_values.xml +0 -183
- data/spec/fixtures/datacite-by-nd-4.0.xml +0 -51
- data/spec/fixtures/datacite-empty-sizes.xml +0 -57
- data/spec/fixtures/datacite-example-ROR-nameIdentifiers.xml +0 -125
- data/spec/fixtures/datacite-example-affiliation.xml +0 -114
- data/spec/fixtures/datacite-example-ancientdates-v4.3.xml +0 -29
- data/spec/fixtures/datacite-example-complicated-tba.xml +0 -56
- data/spec/fixtures/datacite-example-complicated-v3.0.xml +0 -48
- data/spec/fixtures/datacite-example-complicated-v4.0.xml +0 -54
- data/spec/fixtures/datacite-example-complicated-v4.1.xml +0 -57
- data/spec/fixtures/datacite-example-dissertation-v4.4.xml +0 -56
- data/spec/fixtures/datacite-example-escaped-text.xml +0 -56
- data/spec/fixtures/datacite-example-full-v4.4.xml +0 -114
- data/spec/fixtures/datacite-example-full-v4.5.xml +0 -255
- data/spec/fixtures/datacite-example-full-v4.6.xml +0 -114
- data/spec/fixtures/datacite-example-geolocation-2.xml +0 -141
- data/spec/fixtures/datacite-example-geolocation.xml +0 -66
- data/spec/fixtures/datacite-example-nameIdentifier-with-schemeURI.xml +0 -94
- data/spec/fixtures/datacite-example-polygon-v4.1.xml +0 -163
- data/spec/fixtures/datacite-example-relateditems-with-attributes.xml +0 -61
- data/spec/fixtures/datacite-example-relateditems.xml +0 -61
- data/spec/fixtures/datacite-example-xs-string.xml +0 -28
- data/spec/fixtures/datacite-formats-with-xs.xml +0 -22
- data/spec/fixtures/datacite-funderIdentifier.xml +0 -98
- data/spec/fixtures/datacite-geolocation-empty.xml +0 -159
- data/spec/fixtures/datacite-geolocationpolygons-multiple.xml +0 -76
- data/spec/fixtures/datacite-metadata-sample-complicated-v2.2.xml +0 -52
- data/spec/fixtures/datacite-multiple-language.xml +0 -38
- data/spec/fixtures/datacite-multiple-rights.xml +0 -59
- data/spec/fixtures/datacite-schema-2.2.xml +0 -80
- data/spec/fixtures/datacite-seriesinformation.xml +0 -46
- data/spec/fixtures/datacite-space-in-sizes.xml +0 -52
- data/spec/fixtures/datacite-xml-lang.xml +0 -51
- data/spec/fixtures/datacite.json +0 -89
- data/spec/fixtures/datacite.xml +0 -40
- data/spec/fixtures/datacite_blank_name_identifier.xml +0 -22
- data/spec/fixtures/datacite_blank_publisher.xml +0 -18
- data/spec/fixtures/datacite_dataset.xml +0 -58
- data/spec/fixtures/datacite_journal_article.xml +0 -64
- data/spec/fixtures/datacite_malformed_creator.xml +0 -52
- data/spec/fixtures/datacite_missing_creator.xml +0 -33
- data/spec/fixtures/datacite_schema_3.xml +0 -58
- data/spec/fixtures/datacite_software.json +0 -21
- data/spec/fixtures/datacite_software_missing_comma.json +0 -18
- data/spec/fixtures/datacite_software_overlapping_keys.json +0 -18
- data/spec/fixtures/datacite_software_version.json +0 -74
- data/spec/fixtures/edam_package.json +0 -12
- data/spec/fixtures/funding_reference.xml +0 -53
- data/spec/fixtures/gtex.xml +0 -71
- data/spec/fixtures/maremma/codemeta.json +0 -36
- data/spec/fixtures/nist.xml +0 -35
- data/spec/fixtures/ns0.xml +0 -2
- data/spec/fixtures/pure.bib +0 -14
- data/spec/fixtures/pure.ris +0 -15
- data/spec/fixtures/pure.xml +0 -188
- data/spec/fixtures/ris_bug.ris +0 -9
- data/spec/fixtures/schema_4.0.xml +0 -140
- data/spec/fixtures/schema_org.json +0 -50
- data/spec/fixtures/schema_org_4.6_attributes.json +0 -108
- data/spec/fixtures/schema_org_geolocation.json +0 -82
- data/spec/fixtures/schema_org_geoshape.json +0 -550
- data/spec/fixtures/schema_org_gtex.json +0 -75
- data/spec/fixtures/schema_org_list.json +0 -12623
- data/spec/fixtures/schema_org_tdl_iodp_invalid_authors.json +0 -25
- data/spec/fixtures/schema_org_topmed.json +0 -53
- data/spec/fixtures/schema_org_type_as_array.json +0 -41
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/default.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_bibtex.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_citation.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_crossref.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_datacite.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_jats.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/crossref/to_schema_org.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/default.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_bibtex.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_citation.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_datacite.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_datacite_json.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_jats.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/datacite/to_schema_org.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/schema_org/default.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/schema_org/to_datacite.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/convert_from_id/schema_org/to_schema_org.yml +0 -115
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/crossref.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/datacite.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/jalc.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/kisti.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/medra.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_CLI/find_from_format_by_id/op.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/author.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/no_author.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/single_author.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/authors_as_string/with_organization.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_datacite_metadata/change_state.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_datacite_metadata/change_title.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_description.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_identifiers.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_license.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_license_name.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_license_url.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/change_state.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/validates_against_schema.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/change_metadata_as_datacite_xml/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/doi_with_protocol.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/dx_doi_org_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/force_test_resolver.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/https_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/test_resolver.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_api_url/test_resolver_http.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_from_url/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_from_url/doi_with_special_characters.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_from_url/not_a_doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_from_url/sandbox_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_from_url/url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/crossref.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/datacite.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/jalc.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/kisti.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/medra.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/not_a_valid_prefix.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/not_found.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_registration_agency/op.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/doi_with_protocol.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/dx_doi_org_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/force_stage_resolver.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/https_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/stage_resolver.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/doi_resolver/stage_resolver_http.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/crossref.yml +0 -157
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/crossref_doi_not_url.yml +0 -157
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/datacite.yml +0 -157
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/datacite_doi_http.yml +0 -157
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/github.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/orcid.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/schema_org.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_by_ID/unknown_DOI_registration_agency.yml +0 -157
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/bibtex.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/citeproc.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/codemeta.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/crosscite.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/crossref.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/datacite.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/datacite_json.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/ris.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_file/schema_org.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/find_from_format_from_string/crosscite.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/hsh_to_fos_for_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/hsh_to_fos_for_with_schemeUri_in_hash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/hsh_to_fos_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/hsh_to_fos_no_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/name_to_fos_for_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/name_to_fos_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/fos/name_to_fos_no_match.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/from_schema_org/with_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/from_schema_org_creators/with_affiliation.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/from_schema_org_creators/without_affiliation.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_codemeta_metadata/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_codemeta_metadata/metadata_reports.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/DOI_with_ORCID_ID.yml +0 -103
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/DOI_with_SICI_DOI.yml +0 -102
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/DOI_with_data_citation.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/JaLC.yml +0 -137
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/KISTI.yml +0 -158
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/OP.yml +0 -100
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/affiliation_is_space.yml +0 -101
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/another_book.yml +0 -98
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/another_book_chapter.yml +0 -100
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/article_id_as_page_number.yml +0 -101
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/author_literal.yml +0 -108
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/book.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/book_chapter.yml +0 -170
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/book_chapter_with_RDF_for_container.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/book_oup.yml +0 -98
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/component.yml +0 -120
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/dataset.yml +0 -130
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/dataset_usda.yml +0 -143
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/date_in_future.yml +0 -101
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/dissertation.yml +0 -129
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/empty_given_name.yml +0 -101
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/invalid_date.yml +0 -101
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_article.yml +0 -100
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_article_original_language_title.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_article_with.yml +0 -104
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_article_with_RDF_for_container.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_article_with_funding.yml +0 -100
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/journal_issue.yml +0 -127
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/mEDRA.yml +0 -98
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/markup.yml +0 -105
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/missing_creator.yml +0 -100
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/multiple_issn.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/multiple_titles.yml +0 -98
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/multiple_titles_with_missing.yml +0 -450
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/not_found_error.yml +0 -97
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/peer_review.yml +0 -103
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/posted_content.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/posted_content_copernicus.yml +0 -102
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/report_osti.yml +0 -144
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/vor_with_url.yml +0 -102
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/yet_another_book.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_crossref_metadata/yet_another_book_chapter.yml +0 -99
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_json_metadata/metadata_from_api.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/BlogPosting.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/DOI_in_staging_system.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/DOI_in_staging_system_schema_3.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/DOI_in_with_related_id_system.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/DOI_not_found.yml +0 -102
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Dataset.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Funding.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Funding_empty_awardTitle.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Funding_schema_version_4.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Referee_report_in_staging_system.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/Schema_org_type.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/author_only_full_name.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/author_with_scheme.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/author_with_wrong_orcid_scheme.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/cc-by_3_0_us.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/content_url.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/date.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/dissertation.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/doi_with_sign.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/empty_subject.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/even_more_subject_scheme_FOR.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/funding_references.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/funding_schema_version_3.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/is_identical_to.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/keywords_with_attributes.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/leading_and_trailing_whitespace.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/more_subject_scheme_FOR.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/multiple_author_names_in_one_creatorsName.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/multiple_licenses.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/series-information.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/subject_scheme.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datacite_metadata/subject_scheme_FOR.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date/publication_date.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_date_parts/date.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_date_parts/year-month.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_date_parts/year.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_parts/date.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_parts/year-month.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_from_parts/year.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_parts/date.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_parts/year-month.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_date_parts/year.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datetime_from_time/future.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datetime_from_time/invalid.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datetime_from_time/nil.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datetime_from_time/past.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_datetime_from_time/present.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/has_familyName.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/has_name_in_Thai.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/has_name_in_display-order.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/has_name_in_display-order_with_ORCID.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/has_name_in_sort-order.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/hyper-authorship.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/is_organization.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/multiple_author_names_in_one_field.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/multiple_name_identifier.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/name_with_affiliation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/name_with_affiliation_and_country.yml +0 -114
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/name_with_role.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_one_author/only_familyName_and_givenName.yml +0 -57
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_schema_org_metadata/BlogPosting.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_schema_org_metadata/BlogPosting_with_new_DOI.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_schema_org_metadata/harvard_dataverse.yml +0 -40
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_schema_org_metadata/pangaea.yml +0 -57
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_schema_org_metadata/zenodo.yml +0 -62
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_series_information/only_title.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_series_information/title_and_pages.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_series_information/title_volume_and_pages.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/get_series_information/title_volume_issue_and_pages.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/github/github_as_codemeta_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/github/github_from_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/github/github_from_url_file.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/handle_input/DOI_RA_not_Crossref_or_DataCite.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/handle_input/unknown_DOI_prefix.yml +0 -54
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_contributors/none.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_contributors_Translator/supports_Translator_contributorType.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_creators/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_dates/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_dates_with_Coverage/inserts_date_with_dateType_Coverage.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_descriptions/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_identifier/doi.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_language/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_person/creator_only_name.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_publication_year/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_publisher/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_identifiers/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_identifiers/related_identifier.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_identifiers_CSTR/supports_CSTR_relatedIdentifierType.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_identifiers_HasTranslation/supports_HasTranslation_relationType.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_identifiers_RRID/supports_RRID_relatedIdentifierType.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_related_items/insert.yml +0 -73
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_resource_type/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_resource_type_with_Award/supports_Award_as_resourceTypeGeneral.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_resource_type_with_Project/supports_Project_as_resourceTypeGeneral.yml +0 -71
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_rights_list/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_sizes/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_subjects/insert.yml +0 -73
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_titles/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/insert_version/insert.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_comma.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_family_name.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_known_given_name.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_no_info.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_orcid_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/is_personal_name_/has_type_organization.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/jsonlint/missing_comma.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/jsonlint/nil.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/jsonlint/overlapping_keys.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/jsonlint/valid.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_cc_url/not_found.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_cc_url/with_trailing_slash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_cc_url/with_trailing_slash_and_to_https.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/SICI_doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_force_datacite_sandbox.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_from_datacite_sandbox.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_from_url_without_doi_proxy.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_prefix_too_long.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_prefix_with_string.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/doi_with_protocol.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/dx_doi_org_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/https_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/not_valid_doi_prefix.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_doi/url_with_one_slash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/doi_as_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/ftp.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/invalid_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/sandbox_via_options.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/sandbox_via_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/string.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_id/url_with_utf-8.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_ids/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_ids/url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_issn/from_array.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_issn/from_empty_array.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_issn/from_hash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_issn/from_string.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_url/uri.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_url/with_trailing_slash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/normalize_url/with_trailing_slash_and_to_https.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/array.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/array_of_strings.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/first.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/hash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/nil.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/parse_attributes/string.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/sanitize/should_only_keep_specific_tags.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/sanitize/should_remove_a_tags.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/spdx/hsh_to_spdx_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/spdx/hsh_to_spdx_not_found.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/spdx/hsh_to_spdx_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/spdx/name_to_spdx_exists.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/spdx/name_to_spdx_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/to_schema_org/with_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/to_schema_org_identifiers/with_identifiers.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_doi/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_10.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_11.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_12.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_13.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_14.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_4.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_5.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_6.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_7.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_8.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/1_7_9.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/funder_doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/funder_doi_without_prefix.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_funder_doi/non-funder_doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_https.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_sandbox.yml +0 -65
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_sandbox_https.yml +0 -65
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_with_spaces.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_wrong_id.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid/validate_orcid_www.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid_scheme/validate_orcid_scheme.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid_scheme/validate_orcid_scheme_https.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid_scheme/validate_orcid_scheme_trailing_slash.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_orcid_scheme/validate_orcid_scheme_www.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_prefix/doi.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_prefix/doi_as_url.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_prefix/doi_with_protocol.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_prefix/only_prefix.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_url/DOI.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_url/ISSN.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_url/URL.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/validate_url/string.yml +0 -48
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/BlogPosting.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/Dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/authors_with_affiliations.yml +0 -114
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/climate_data.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/from_schema_org.yml +0 -115
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/keywords_subject_scheme.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/text.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_bibtex/with_pages.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/Dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/Journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/Journal_article_vancouver_style.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/Missing_author.yml +0 -49
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/interactive_resource_without_dates.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citation/software_w/version.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/Another_dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/BlogPosting.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/BlogPosting_schema_org.yml +0 -115
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/Dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/container_title.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/interactive_resource_without_dates.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/keywords_subject_scheme.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/missing_creator.yml +0 -49
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/multiple_abstracts.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/organization_author.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/software.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/software_w/version.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/with_only_first_page.yml +0 -50
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_citeproc/with_pages.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_codemeta/SoftwareSourceCode_DataCite.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_codemeta/SoftwareSourceCode_DataCite_check_codemeta_v2.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crosscite/datacite_database_attributes.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crosscite/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crosscite/with_ORCID_ID.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crosscite/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crosscite/with_data_citation_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_crossref/from_DataCite.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_csv/climate_data.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_csv/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_csv/text.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_csv/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_csv/with_pages.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_json/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_json/with_ORCID_ID.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_json/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_json/with_data_citation_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/DOI_not_found.yml +0 -51
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/Dataset_in_schema_4_0.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/Text_pass-thru.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/Text_pass-thru_with_doi_in_options.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/with_ORCID_ID.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/with_data_citation_schema_org.yml +0 -115
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/with_editor.yml +0 -49
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_datacite_xml/with_version.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/Dataset_in_schema_4_0.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/Text_pass-thru.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/book_chapter.yml +0 -88
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/interactive_resource_without_dates.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/with_ORCID_ID.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/with_data_citation.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/with_data_citation_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_jats_xml/with_editor.yml +0 -49
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_rdf_xml/BlogPosting.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_rdf_xml/BlogPosting_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_rdf_xml/journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_rdf_xml/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_rdf_xml/with_pages.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/BlogPosting.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/BlogPosting_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/Dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/alternate_name.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/keywords_with_subject_scheme.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/maremma.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_ris/with_pages.yml +0 -52
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Funding.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Funding_OpenAIRE.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Schema_org_JSON.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Schema_org_JSON_Cyark.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Schema_org_JSON_IsSupplementTo.yml +0 -106
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/Schema_org_JSON_isReferencedBy.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/alternate_identifiers.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/data_catalog.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/geo_location_box.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/interactive_resource_without_dates.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/maremma_schema_org_JSON.yml +0 -75
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/series_information.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/subject_scheme.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_schema_org/subject_scheme_multiple_keywords.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_turtle/BlogPosting.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_turtle/BlogPosting_schema_org.yml +0 -117
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_turtle/Dataset.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_turtle/journal_article.yml +0 -55
- data/spec/fixtures/vcr_cassettes/Bolognese_Metadata/write_metadata_as_turtle/with_pages.yml +0 -52
- data/spec/fixtures/vivli.xml +0 -1
- data/spec/metadata_spec.rb +0 -165
- data/spec/readers/bibtex_reader_spec.rb +0 -65
- data/spec/readers/citeproc_reader_spec.rb +0 -65
- data/spec/readers/codemeta_reader_spec.rb +0 -138
- data/spec/readers/crosscite_reader_spec.rb +0 -43
- data/spec/readers/crossref_reader_spec.rb +0 -1133
- data/spec/readers/datacite_json_reader_spec.rb +0 -82
- data/spec/readers/datacite_reader_spec.rb +0 -1865
- data/spec/readers/npm_reader_spec.rb +0 -68
- data/spec/readers/ris_reader_spec.rb +0 -78
- data/spec/readers/schema_org_reader_spec.rb +0 -371
- data/spec/spec_helper.rb +0 -95
- data/spec/utils_spec.rb +0 -666
- data/spec/writers/bibtex_writer_spec.rb +0 -195
- data/spec/writers/citation_writer_spec.rb +0 -61
- data/spec/writers/citeproc_writer_spec.rb +0 -299
- data/spec/writers/codemeta_writer_spec.rb +0 -45
- data/spec/writers/crosscite_writer_spec.rb +0 -129
- data/spec/writers/crossref_writer_spec.rb +0 -21
- data/spec/writers/csv_writer_spec.rb +0 -94
- data/spec/writers/datacite_json_writer_spec.rb +0 -112
- data/spec/writers/datacite_writer_spec.rb +0 -578
- data/spec/writers/jats_writer_spec.rb +0 -208
- data/spec/writers/rdf_xml_writer_spec.rb +0 -93
- data/spec/writers/ris_writer_spec.rb +0 -207
- data/spec/writers/schema_org_writer_spec.rb +0 -426
- data/spec/writers/turtle_writer_spec.rb +0 -102
| @@ -1,426 +0,0 @@ | |
| 1 | 
            -
            # frozen_string_literal: true
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            require 'spec_helper'
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            describe Bolognese::Metadata, vcr: true do
         | 
| 6 | 
            -
              context "write metadata as schema_org" do
         | 
| 7 | 
            -
                it "journal article" do
         | 
| 8 | 
            -
                  input = "10.7554/eLife.01567"
         | 
| 9 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "crossref")
         | 
| 10 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 11 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.7554/elife.01567")
         | 
| 12 | 
            -
                  expect(json["@type"]).to eq("ScholarlyArticle")
         | 
| 13 | 
            -
                  expect(json["isPartOf"]).to eq("@type"=>"Periodical", "issn"=>"2050-084X")
         | 
| 14 | 
            -
                  expect(json["periodical"]).to eq("@type"=>"Journal", "firstPage" => "e01567", "identifier"=>"2050-084X", "identifierType"=>"ISSN", "name"=>"eLife", "volume"=>"3")
         | 
| 15 | 
            -
                  expect(json["citation"].length).to eq(26)
         | 
| 16 | 
            -
                  expect(json["citation"].first).to eq("@id"=>"https://doi.org/10.1038/nature02100", "@type"=>"CreativeWork")
         | 
| 17 | 
            -
                  expect(json["funder"]).to eq([{"name"=>"SystemsX", "@type"=>"Organization"},
         | 
| 18 | 
            -
                                                 {"name"=>"EMBO",
         | 
| 19 | 
            -
                                                  "@type"=>"Organization",
         | 
| 20 | 
            -
                                                  "@id"=>"https://doi.org/10.13039/501100003043"},
         | 
| 21 | 
            -
                                                 {"name"=>"Swiss National Science Foundation",
         | 
| 22 | 
            -
                                                  "@type"=>"Organization",
         | 
| 23 | 
            -
                                                  "@id"=>"https://doi.org/10.13039/501100001711"},
         | 
| 24 | 
            -
                                                 {"name"=>"University of Lausanne",
         | 
| 25 | 
            -
                                                  "@type"=>"Organization",
         | 
| 26 | 
            -
                                                  "@id"=>"https://doi.org/10.13039/501100006390"}])
         | 
| 27 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/licenses/by/3.0/legalcode")
         | 
| 28 | 
            -
                end
         | 
| 29 | 
            -
             | 
| 30 | 
            -
                it "maremma schema.org JSON" do
         | 
| 31 | 
            -
                  input = "https://github.com/datacite/maremma"
         | 
| 32 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "codemeta")
         | 
| 33 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 34 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5438/qeg0-3gm3")
         | 
| 35 | 
            -
                  expect(json["@type"]).to eq("SoftwareSourceCode")
         | 
| 36 | 
            -
                  expect(json["name"]).to eq("Maremma: a Ruby library for simplified network calls")
         | 
| 37 | 
            -
                  expect(json["author"]).to eq("name"=>"Martin Fenner", "givenName"=>"Martin", "familyName"=>"Fenner", "@type"=>"Person", "@id"=>"https://orcid.org/0000-0003-0077-4738", "affiliation" => {"@type"=>"Organization", "name"=>"DataCite"})
         | 
| 38 | 
            -
                end
         | 
| 39 | 
            -
             | 
| 40 | 
            -
                it "Schema.org JSON" do
         | 
| 41 | 
            -
                  input = "https://doi.org/10.5281/ZENODO.48440"
         | 
| 42 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 43 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 44 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5281/zenodo.48440")
         | 
| 45 | 
            -
                  expect(json["@type"]).to eq("SoftwareSourceCode")
         | 
| 46 | 
            -
                  expect(json["name"]).to eq("Analysis Tools For Crossover Experiment Of Ui Using Choice Architecture")
         | 
| 47 | 
            -
                  expect(json["license"]).to eq(["https://creativecommons.org/licenses/by-nc-sa/4.0/legalcode", "info:eu-repo/semantics/openAccess"])
         | 
| 48 | 
            -
                end
         | 
| 49 | 
            -
             | 
| 50 | 
            -
                it "Schema.org JSON isReferencedBy" do
         | 
| 51 | 
            -
                  input = "https://doi.org/10.5061/DRYAD.8515"
         | 
| 52 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 53 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 54 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5061/dryad.8515")
         | 
| 55 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 56 | 
            -
                  expect(json["citation"]).to eq("@id"=>"https://doi.org/10.1371/journal.ppat.1000446", "@type"=>"CreativeWork")
         | 
| 57 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/publicdomain/zero/1.0/legalcode")
         | 
| 58 | 
            -
                  expect(json["keywords"]).to eq("Plasmodium, malaria, taxonomy, mitochondrial genome, Parasites")
         | 
| 59 | 
            -
                end
         | 
| 60 | 
            -
             | 
| 61 | 
            -
                it "Schema.org JSON IsSupplementTo" do
         | 
| 62 | 
            -
                  input = "https://doi.org/10.5517/CC8H01S"
         | 
| 63 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 64 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 65 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5517/cc8h01s")
         | 
| 66 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 67 | 
            -
                  expect(json["@reverse"]).to eq("isBasedOn"=>{"@id"=>"https://doi.org/10.1107/s1600536804021154", "@type"=>"ScholarlyArticle"})
         | 
| 68 | 
            -
                end
         | 
| 69 | 
            -
             | 
| 70 | 
            -
                it "Schema.org JSON Cyark" do
         | 
| 71 | 
            -
                  input = "https://doi.org/10.26301/jgf3-jm06"
         | 
| 72 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 73 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 74 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.26301/jgf3-jm06")
         | 
| 75 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 76 | 
            -
                end
         | 
| 77 | 
            -
             | 
| 78 | 
            -
                it "rdataone" do
         | 
| 79 | 
            -
                  input = fixture_path + 'codemeta.json'
         | 
| 80 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "codemeta")
         | 
| 81 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 82 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5063/f1m61h5x")
         | 
| 83 | 
            -
                  expect(json["@type"]).to eq("SoftwareSourceCode")
         | 
| 84 | 
            -
                  expect(json["name"]).to eq("R Interface to the DataONE REST API")
         | 
| 85 | 
            -
                  expect(json["author"]).to eq([{"name"=>"Matt Jones",
         | 
| 86 | 
            -
                                                 "givenName"=>"Matt",
         | 
| 87 | 
            -
                                                 "familyName"=>"Jones",
         | 
| 88 | 
            -
                                                 "@type"=>"Person",
         | 
| 89 | 
            -
                                                 "@id"=>"https://orcid.org/0000-0003-0077-4738",
         | 
| 90 | 
            -
                                                 "affiliation"=>{"@type"=>"Organization", "name"=>"NCEAS"}},
         | 
| 91 | 
            -
                                                {"name"=>"Peter Slaughter",
         | 
| 92 | 
            -
                                                 "givenName"=>"Peter",
         | 
| 93 | 
            -
                                                 "familyName"=>"Slaughter",
         | 
| 94 | 
            -
                                                 "@type"=>"Person",
         | 
| 95 | 
            -
                                                 "@id"=>"https://orcid.org/0000-0002-2192-403X",
         | 
| 96 | 
            -
                                                 "affiliation"=>{"@type"=>"Organization", "name"=>"NCEAS"}},
         | 
| 97 | 
            -
                                                {"name"=>"University of California, Santa Barbara", "@type"=>"Organization"}])
         | 
| 98 | 
            -
                  expect(json["version"]).to eq("2.0.0")
         | 
| 99 | 
            -
                  expect(json["keywords"]).to eq("data sharing, data repository, DataONE")
         | 
| 100 | 
            -
                end
         | 
| 101 | 
            -
             | 
| 102 | 
            -
                it "Funding" do
         | 
| 103 | 
            -
                  input = "https://doi.org/10.5438/6423"
         | 
| 104 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 105 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 106 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5438/6423")
         | 
| 107 | 
            -
                  expect(json["@type"]).to eq("Collection")
         | 
| 108 | 
            -
                  expect(json["hasPart"].length).to eq(25)
         | 
| 109 | 
            -
                  expect(json["hasPart"].first).to eq("@type"=>"CreativeWork", "@id"=>"https://doi.org/10.5281/zenodo.30799")
         | 
| 110 | 
            -
                  expect(json["funder"]).to eq("@id"=>"https://doi.org/10.13039/501100000780", "@type"=>"Organization", "name"=>"European Commission")
         | 
| 111 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/licenses/by/4.0/legalcode")
         | 
| 112 | 
            -
                end
         | 
| 113 | 
            -
             | 
| 114 | 
            -
                it "Funding OpenAIRE" do
         | 
| 115 | 
            -
                  input = "https://doi.org/10.5281/ZENODO.1239"
         | 
| 116 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 117 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 118 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5281/zenodo.1239")
         | 
| 119 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 120 | 
            -
                  expect(json["funder"]).to eq("@id"=>"https://doi.org/10.13039/501100000780", "@type"=>"Organization", "name"=>"European Commission")
         | 
| 121 | 
            -
                  expect(json["license"]).to eq(["https://creativecommons.org/publicdomain/zero/1.0/legalcode", "info:eu-repo/semantics/openAccess"])
         | 
| 122 | 
            -
                end
         | 
| 123 | 
            -
             | 
| 124 | 
            -
                it "subject scheme" do
         | 
| 125 | 
            -
                  input = "https://doi.org/10.4232/1.2745"
         | 
| 126 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 127 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 128 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.4232/1.2745")
         | 
| 129 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 130 | 
            -
                  expect(json["name"]).to eq("Flash Eurobarometer 54 (Madrid Summit)")
         | 
| 131 | 
            -
                  expect(json["keywords"]).to eq("KAT12 International Institutions, Relations, Conditions, Internationale Politik und Institutionen, Regierung, politische Systeme, Parteien und Verbände, Wirtschaftssysteme und wirtschaftliche Entwicklung, International politics and organisation, Government, political systems and organisation, Economic systems and development")
         | 
| 132 | 
            -
                end
         | 
| 133 | 
            -
             | 
| 134 | 
            -
                it "subject scheme multiple keywords" do
         | 
| 135 | 
            -
                  input = "https://doi.org/10.1594/pangaea.721193"
         | 
| 136 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 137 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 138 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.1594/pangaea.721193")
         | 
| 139 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 140 | 
            -
                  expect(json["name"]).to eq("Seawater carbonate chemistry and processes during experiments with Crassostrea gigas, 2007, supplement to: Kurihara, Haruko; Kato, Shoji; Ishimatsu, Atsushi (2007): Effects of increased seawater pCO2 on early development of the oyster Crassostrea gigas. Aquatic Biology, 1(1), 91-98")
         | 
| 141 | 
            -
                  expect(json["keywords"]).to include("Animalia, Bottles or small containers/Aquaria (<20 L)")
         | 
| 142 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/licenses/by/3.0/legalcode")
         | 
| 143 | 
            -
                end
         | 
| 144 | 
            -
             | 
| 145 | 
            -
                it "author is organization" do
         | 
| 146 | 
            -
                  input = fixture_path + 'gtex.xml'
         | 
| 147 | 
            -
                  url = "https://ors.datacite.org/doi:/10.25491/9hx8-ke93"
         | 
| 148 | 
            -
                  content_url = "https://storage.googleapis.com/gtex_analysis_v7/single_tissue_eqtl_data/GTEx_Analysis_v7_eQTL_expression_matrices.tar.gz"
         | 
| 149 | 
            -
                  subject = Bolognese::Metadata.new(input: input, url: url, content_url: content_url, from: "datacite")
         | 
| 150 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 151 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.25491/9hx8-ke93")
         | 
| 152 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 153 | 
            -
                  expect(json["author"]).to eq("@type"=>"Organization", "name"=>"The GTEx Consortium")
         | 
| 154 | 
            -
                  expect(json["url"]).to eq("https://ors.datacite.org/doi:/10.25491/9hx8-ke93")
         | 
| 155 | 
            -
                  expect(json["encodingFormat"]).to eq("application/tar")
         | 
| 156 | 
            -
                  expect(json["contentSize"]).to eq("15.7M")
         | 
| 157 | 
            -
                  expect(json["contentUrl"]).to eq("https://storage.googleapis.com/gtex_analysis_v7/single_tissue_eqtl_data/GTEx_Analysis_v7_eQTL_expression_matrices.tar.gz")
         | 
| 158 | 
            -
                  expect(json["includedInDataCatalog"]).to eq("@id"=>"https://www.ebi.ac.uk/miriam/main/datatypes/MIR:00000663", "@type"=>"DataCatalog", "name"=>"GTEx")
         | 
| 159 | 
            -
                  expect(json["@reverse"]).to eq("isBasedOn"=>{"@id"=>"https://doi.org/10.1038/nmeth.4407", "@type"=>"ScholarlyArticle"})
         | 
| 160 | 
            -
                end
         | 
| 161 | 
            -
             | 
| 162 | 
            -
                it "series information" do
         | 
| 163 | 
            -
                  input = "10.4229/23RDEUPVSEC2008-5CO.8.3"
         | 
| 164 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 165 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 166 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.4229/23rdeupvsec2008-5co.8.3")
         | 
| 167 | 
            -
                  expect(json["@type"]).to eq("ScholarlyArticle")
         | 
| 168 | 
            -
                  expect(json["name"]).to eq("Rural Electrification With Hybrid Power Systems Based on Renewables - Technical System Configurations From the Point of View of the European Industry")
         | 
| 169 | 
            -
                  expect(json["author"].count).to eq(3)
         | 
| 170 | 
            -
                  expect(json["author"].first).to eq("@type"=>"Person", "name"=>"P. Llamas", "givenName"=>"P.", "familyName"=>"Llamas")
         | 
| 171 | 
            -
                  expect(json["periodical"]).to eq("@type"=>"Series", "firstPage"=>"Spain; 3353", "lastPage"=>"3356", "name"=>"23rd European Photovoltaic Solar Energy Conference and Exhibition", "volume"=>"1-5 September 2008")
         | 
| 172 | 
            -
                end
         | 
| 173 | 
            -
             | 
| 174 | 
            -
                it "data catalog" do
         | 
| 175 | 
            -
                  input = "10.25491/8KMC-G314"
         | 
| 176 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 177 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 178 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.25491/8kmc-g314")
         | 
| 179 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 180 | 
            -
                  expect(json["name"]).to eq("Covariates used in eQTL analysis. Includes genotyping principal components and PEER factors")
         | 
| 181 | 
            -
                  expect(json["author"]).to eq("@type"=>"Organization", "name"=>"The GTEx Consortium")
         | 
| 182 | 
            -
                  expect(json["includedInDataCatalog"]).to eq("@type"=>"DataCatalog", "name"=>"GTEx")
         | 
| 183 | 
            -
                  expect(json["identifier"]).to eq("@type"=>"PropertyValue", "propertyID"=>"md5", "value"=>"c7c89fe7366d50cd75448aa603c9de58")
         | 
| 184 | 
            -
                  expect(json["contentUrl"]).to eq("https://storage.googleapis.com/gtex_analysis_v7/single_tissue_eqtl_data/GTEx_Analysis_v7_eQTL_covariates.tar.gz")
         | 
| 185 | 
            -
                end
         | 
| 186 | 
            -
             | 
| 187 | 
            -
                it "alternate identifiers" do
         | 
| 188 | 
            -
                  input = "10.23725/8na3-9s47"
         | 
| 189 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 190 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 191 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.23725/8na3-9s47")
         | 
| 192 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 193 | 
            -
                  expect(json["name"]).to eq("NWD165827.recab.cram")
         | 
| 194 | 
            -
                  expect(json["author"]).to eq("name"=>"TOPMed")
         | 
| 195 | 
            -
                  expect(json["includedInDataCatalog"]).to be_nil
         | 
| 196 | 
            -
                  expect(json["identifier"]).to eq(
         | 
| 197 | 
            -
                    [{"@type"=>"PropertyValue",
         | 
| 198 | 
            -
                      "propertyID"=>"minid",
         | 
| 199 | 
            -
                      "value"=>"ark:/99999/fk41CrU4eszeLUDe"},
         | 
| 200 | 
            -
                     {"@type"=>"PropertyValue",
         | 
| 201 | 
            -
                      "propertyID"=>"dataguid",
         | 
| 202 | 
            -
                      "value"=>"dg.4503/c3d66dc9-58da-411c-83c4-dd656aa3c4b7"},
         | 
| 203 | 
            -
                     {"@type"=>"PropertyValue",
         | 
| 204 | 
            -
                      "propertyID"=>"md5",
         | 
| 205 | 
            -
                      "value"=>"3b33f6b9338fccab0901b7d317577ea3"}]
         | 
| 206 | 
            -
                  )
         | 
| 207 | 
            -
                  expect(json["contentUrl"]).to include("s3://cgp-commons-public/topmed_open_access/197bc047-e917-55ed-852d-d563cdbc50e4/NWD165827.recab.cram", "gs://topmed-irc-share/public/NWD165827.recab.cram")
         | 
| 208 | 
            -
                end
         | 
| 209 | 
            -
             | 
| 210 | 
            -
                it "affiliation identifier" do
         | 
| 211 | 
            -
                  input = fixture_path + 'datacite-example-affiliation.xml'
         | 
| 212 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 213 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 214 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5072/example-full")
         | 
| 215 | 
            -
                  expect(json["@type"]).to eq("SoftwareSourceCode")
         | 
| 216 | 
            -
                  expect(json["name"]).to eq("Full DataCite XML Example")
         | 
| 217 | 
            -
                  expect(json["author"].length).to eq(3)
         | 
| 218 | 
            -
                  expect(json["author"].first).to eq("@id" => "https://orcid.org/0000-0001-5000-0007",
         | 
| 219 | 
            -
                    "@type" => "Person",
         | 
| 220 | 
            -
                    "affiliation" => {"@id"=>"https://ror.org/04wxnsj81", "@type"=>"Organization", "name"=>"DataCite"},
         | 
| 221 | 
            -
                    "familyName" => "Miller",
         | 
| 222 | 
            -
                    "givenName" => "Elizabeth",
         | 
| 223 | 
            -
                    "name" => "Elizabeth Miller")
         | 
| 224 | 
            -
                  expect(json["identifier"]).to eq(
         | 
| 225 | 
            -
                     {"@type"=>"PropertyValue",
         | 
| 226 | 
            -
                      "propertyID"=>"URL",
         | 
| 227 | 
            -
                      "value"=>"https://schema.datacite.org/meta/kernel-4.2/example/datacite-example-full-v4.2.xml"}
         | 
| 228 | 
            -
                  )
         | 
| 229 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/publicdomain/zero/1.0/legalcode")
         | 
| 230 | 
            -
                end
         | 
| 231 | 
            -
             | 
| 232 | 
            -
                it "geo_location_point" do
         | 
| 233 | 
            -
                  input = fixture_path + 'datacite-example-geolocation-2.xml'
         | 
| 234 | 
            -
                  doi = "10.6071/Z7WC73"
         | 
| 235 | 
            -
                  subject = Bolognese::Metadata.new(input: input, doi: doi)
         | 
| 236 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 237 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.6071/z7wc73")
         | 
| 238 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 239 | 
            -
                  expect(json["name"]).to eq("Southern Sierra Critical Zone Observatory (SSCZO), Providence Creek meteorological data, soil moisture and temperature, snow depth and air temperature")
         | 
| 240 | 
            -
                  expect(json["author"].length).to eq(6)
         | 
| 241 | 
            -
                  expect(json["author"][2]).to eq("@id"=>"https://orcid.org/0000-0002-8862-1404", "@type"=>"Person", "familyName"=>"Stacy", "givenName"=>"Erin", "name"=>"Erin Stacy", "affiliation" => {"@type"=>"Organization", "name"=>"UC Merced"})
         | 
| 242 | 
            -
                  expect(json["includedInDataCatalog"]).to be_nil
         | 
| 243 | 
            -
                  expect(json["spatialCoverage"]).to eq([{"@type"=>"Place",
         | 
| 244 | 
            -
                    "geo"=>
         | 
| 245 | 
            -
                    {"@type"=>"GeoCoordinates",
         | 
| 246 | 
            -
                     "address"=>"Providence Creek (Lower, Upper and P301)",
         | 
| 247 | 
            -
                     "latitude"=>"37.047756",
         | 
| 248 | 
            -
                     "longitude"=>"-119.221094"}},
         | 
| 249 | 
            -
                    {"@type"=>"Place",
         | 
| 250 | 
            -
                     "geo"=>
         | 
| 251 | 
            -
                    {"@type"=>"GeoShape",
         | 
| 252 | 
            -
                     "address"=>"Providence Creek (Lower, Upper and P301)",
         | 
| 253 | 
            -
                     "box"=>"37.046 -119.211 37.075 -119.182"}}])
         | 
| 254 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/licenses/by/4.0/legalcode")
         | 
| 255 | 
            -
                end
         | 
| 256 | 
            -
             | 
| 257 | 
            -
                it "geo_location_box" do
         | 
| 258 | 
            -
                  input = "10.1594/PANGAEA.842237"
         | 
| 259 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 260 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 261 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.1594/pangaea.842237")
         | 
| 262 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 263 | 
            -
                  expect(json["name"]).to eq("Registry of all stations from the Tara Oceans Expedition (2009-2013)")
         | 
| 264 | 
            -
                  expect(json["author"]).to eq([{"familyName"=>"Tara Oceans Consortium",
         | 
| 265 | 
            -
                    "givenName"=>"Coordinators",
         | 
| 266 | 
            -
                    "name"=>"Coordinators Tara Oceans Consortium"},
         | 
| 267 | 
            -
                   {"familyName"=>"Tara Oceans Expedition",
         | 
| 268 | 
            -
                    "givenName"=>"Participants",
         | 
| 269 | 
            -
                    "name"=>"Participants Tara Oceans Expedition"}])
         | 
| 270 | 
            -
                  expect(json["includedInDataCatalog"]).to be_nil
         | 
| 271 | 
            -
                  expect(json["spatialCoverage"]).to eq("@type"=>"Place", "geo"=>{"@type"=>"GeoShape", "box"=>"-64.3088 -168.5182 79.6753 174.9006"})
         | 
| 272 | 
            -
                  expect(json["license"]).to eq("https://creativecommons.org/licenses/by/3.0/legalcode")
         | 
| 273 | 
            -
                end
         | 
| 274 | 
            -
             | 
| 275 | 
            -
                it "geo_location_polygon" do
         | 
| 276 | 
            -
                  input = fixture_path + 'datacite-example-polygon-v4.1.xml'
         | 
| 277 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 278 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 279 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.5072/example-polygon")
         | 
| 280 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 281 | 
            -
                  expect(json["name"]).to eq("Meteo measurements at the Sand Motor")
         | 
| 282 | 
            -
                  expect(json["author"]).to eq("@type"=>"Person", "familyName"=>"den Heijer", "givenName"=>"C", "name"=>"C den Heijer")
         | 
| 283 | 
            -
                  expect(json["includedInDataCatalog"]).to be_nil
         | 
| 284 | 
            -
                  expect(json["spatialCoverage"].dig("geo", "polygon").length).to eq(34)
         | 
| 285 | 
            -
                  expect(json["spatialCoverage"].dig("geo", "polygon")[0].first).to eq(["4.1738852605822", "52.03913926329928"])
         | 
| 286 | 
            -
                end
         | 
| 287 | 
            -
             | 
| 288 | 
            -
                it "from schema_org gtex" do
         | 
| 289 | 
            -
                  input = fixture_path + 'schema_org_gtex.json'
         | 
| 290 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "schema_org")
         | 
| 291 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 292 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.25491/d50j-3083")
         | 
| 293 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 294 | 
            -
                  expect(json["identifier"]).to eq("@type"=>"PropertyValue", "propertyID"=>"md5", "value"=>"687610993")
         | 
| 295 | 
            -
                  expect(json["url"]).to eq("https://ors.datacite.org/doi:/10.25491/d50j-3083")
         | 
| 296 | 
            -
                  expect(json["additionalType"]).to eq("Gene expression matrices")
         | 
| 297 | 
            -
                  expect(json["name"]).to eq("Fully processed, filtered and normalized gene expression matrices (in BED format) for each tissue, which were used as input into FastQTL for eQTL discovery")
         | 
| 298 | 
            -
                  expect(json["version"]).to eq("v7")
         | 
| 299 | 
            -
                  expect(json["author"]).to eq("@type"=>"Organization", "name"=>"The GTEx Consortium")
         | 
| 300 | 
            -
                  expect(json["keywords"]).to eq("gtex, annotation, phenotype, gene regulation, transcriptomics")
         | 
| 301 | 
            -
                  expect(json["datePublished"]).to eq("2017")
         | 
| 302 | 
            -
                  expect(json["contentUrl"]).to eq("https://storage.googleapis.com/gtex_analysis_v7/single_tissue_eqtl_data/GTEx_Analysis_v7_eQTL_expression_matrices.tar.gz")
         | 
| 303 | 
            -
                  expect(json["schemaVersion"]).to eq("http://datacite.org/schema/kernel-4")
         | 
| 304 | 
            -
                  expect(json["includedInDataCatalog"]).to eq("@type"=>"DataCatalog", "name"=>"GTEx")
         | 
| 305 | 
            -
                  expect(json["publisher"]).to eq("@type"=>"Organization", "name"=>"GTEx")
         | 
| 306 | 
            -
                  expect(json["funder"]).to eq([{"@id"=>"https://doi.org/10.13039/100000052",
         | 
| 307 | 
            -
                    "name"=>"Common Fund of the Office of the Director of the NIH",
         | 
| 308 | 
            -
                    "@type"=>"Organization"},
         | 
| 309 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000054",
         | 
| 310 | 
            -
                    "name"=>"National Cancer Institute (NCI)",
         | 
| 311 | 
            -
                    "@type"=>"Organization"},
         | 
| 312 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000051",
         | 
| 313 | 
            -
                    "name"=>"National Human Genome Research Institute (NHGRI)",
         | 
| 314 | 
            -
                    "@type"=>"Organization"},
         | 
| 315 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000050",
         | 
| 316 | 
            -
                    "name"=>"National Heart, Lung, and Blood Institute (NHLBI)",
         | 
| 317 | 
            -
                    "@type"=>"Organization"},
         | 
| 318 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000026",
         | 
| 319 | 
            -
                    "name"=>"National Institute on Drug Abuse (NIDA)",
         | 
| 320 | 
            -
                    "@type"=>"Organization"},
         | 
| 321 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000025",
         | 
| 322 | 
            -
                    "name"=>"National Institute of Mental Health (NIMH)",
         | 
| 323 | 
            -
                    "@type"=>"Organization"},
         | 
| 324 | 
            -
                   {"@id"=>"https://doi.org/10.13039/100000065",
         | 
| 325 | 
            -
                    "name"=>"National Institute of Neurological Disorders and Stroke (NINDS)",
         | 
| 326 | 
            -
                    "@type"=>"Organization"}])
         | 
| 327 | 
            -
                  expect(json["provider"]).to eq("@type"=>"Organization", "name"=>"DataCite")
         | 
| 328 | 
            -
                end
         | 
| 329 | 
            -
             | 
| 330 | 
            -
                it "from schema_org topmed" do
         | 
| 331 | 
            -
                  input = fixture_path + 'schema_org_topmed.json'
         | 
| 332 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "schema_org")
         | 
| 333 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 334 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.23725/8na3-9s47")
         | 
| 335 | 
            -
                  expect(json["@type"]).to eq("Dataset")
         | 
| 336 | 
            -
                  expect(json["identifier"]).to eq(
         | 
| 337 | 
            -
                    [{"@type"=>"PropertyValue",
         | 
| 338 | 
            -
                      "propertyID"=>"md5",
         | 
| 339 | 
            -
                      "value"=>"3b33f6b9338fccab0901b7d317577ea3"},
         | 
| 340 | 
            -
                     {"@type"=>"PropertyValue",
         | 
| 341 | 
            -
                      "propertyID"=>"minid",
         | 
| 342 | 
            -
                      "value"=>"ark:/99999/fk41CrU4eszeLUDe"},
         | 
| 343 | 
            -
                     {"@type"=>"PropertyValue",
         | 
| 344 | 
            -
                      "propertyID"=>"dataguid",
         | 
| 345 | 
            -
                      "value"=>"dg.4503/c3d66dc9-58da-411c-83c4-dd656aa3c4b7"}])
         | 
| 346 | 
            -
                  expect(json["url"]).to eq("https://ors.datacite.org/doi:/10.23725/8na3-9s47")
         | 
| 347 | 
            -
                  expect(json["additionalType"]).to eq("CRAM file")
         | 
| 348 | 
            -
                  expect(json["name"]).to eq("NWD165827.recab.cram")
         | 
| 349 | 
            -
                  expect(json["author"]).to eq("@type"=>"Organization", "name"=>"TOPMed IRC")
         | 
| 350 | 
            -
                  expect(json["keywords"]).to eq("topmed, whole genome sequencing")
         | 
| 351 | 
            -
                  expect(json["datePublished"]).to eq("2017-11-30")
         | 
| 352 | 
            -
                  expect(json["contentUrl"]).to eq(["s3://cgp-commons-public/topmed_open_access/197bc047-e917-55ed-852d-d563cdbc50e4/NWD165827.recab.cram", "gs://topmed-irc-share/public/NWD165827.recab.cram"])
         | 
| 353 | 
            -
                  expect(json["schemaVersion"]).to eq("http://datacite.org/schema/kernel-4")
         | 
| 354 | 
            -
                  expect(json["publisher"]).to eq("@type"=>"Organization", "name"=>"TOPMed")
         | 
| 355 | 
            -
                  expect(json["citation"]).to eq("@id"=>"https://doi.org/10.23725/2g4s-qv04", "@type"=>"Dataset")
         | 
| 356 | 
            -
                  expect(json["funder"]).to eq("@id"=>"https://doi.org/10.13039/100000050", "@type"=>"Organization", "name"=>"National Heart, Lung, and Blood Institute (NHLBI)")
         | 
| 357 | 
            -
                  expect(json["provider"]).to eq("@type"=>"Organization", "name"=>"DataCite")
         | 
| 358 | 
            -
                end
         | 
| 359 | 
            -
             | 
| 360 | 
            -
                it "interactive resource without dates" do
         | 
| 361 | 
            -
                  input = "https://doi.org/10.34747/g6yb-3412"
         | 
| 362 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 363 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 364 | 
            -
                  expect(json["@id"]).to eq("https://doi.org/10.34747/g6yb-3412")
         | 
| 365 | 
            -
                  expect(json["@type"]).to eq("CreativeWork")
         | 
| 366 | 
            -
                  expect(json["datePublished"]).to eq("2019")
         | 
| 367 | 
            -
                end
         | 
| 368 | 
            -
             | 
| 369 | 
            -
                it "from Schema 4.5 with publisher attributes" do
         | 
| 370 | 
            -
                  input = fixture_path + 'datacite-example-full-v4.5.xml'
         | 
| 371 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 372 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 373 | 
            -
                  expect(json["publisher"]).to eq(
         | 
| 374 | 
            -
                     {
         | 
| 375 | 
            -
                      "@type" => "Organization",
         | 
| 376 | 
            -
                      "@id" => "https://ror.org/04z8jg394",
         | 
| 377 | 
            -
                      "name" => "Example Publisher"
         | 
| 378 | 
            -
                     }
         | 
| 379 | 
            -
                  )
         | 
| 380 | 
            -
                end
         | 
| 381 | 
            -
             | 
| 382 | 
            -
                it "from Schema 4.6 with Translator contributor, workTranslation, translationOfWork, and temporalCoverage" do
         | 
| 383 | 
            -
                  input = fixture_path + 'datacite-example-full-v4.6.xml'
         | 
| 384 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 385 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 386 | 
            -
             | 
| 387 | 
            -
                  expect(json["@type"]).to eq(
         | 
| 388 | 
            -
                    "Project"
         | 
| 389 | 
            -
                  )
         | 
| 390 | 
            -
                  expect(json["translator"]).to eq(
         | 
| 391 | 
            -
                    {
         | 
| 392 | 
            -
                      "name" => "Jane Doe",
         | 
| 393 | 
            -
                      "givenName" => "Jane",
         | 
| 394 | 
            -
                      "familyName" => "Doe",
         | 
| 395 | 
            -
                      "affiliation" => {
         | 
| 396 | 
            -
                        "@type" => "Organization",
         | 
| 397 | 
            -
                        "@id" => "https://ror.org/04wxnsj81",
         | 
| 398 | 
            -
                        "name" => "ExampleAffiliation"
         | 
| 399 | 
            -
                      },
         | 
| 400 | 
            -
                      "contributorType" => "Translator",
         | 
| 401 | 
            -
                      "@type" => "Person",
         | 
| 402 | 
            -
                      "@id" => "https://orcid.org/0000-0003-1419-2405"
         | 
| 403 | 
            -
                    }
         | 
| 404 | 
            -
                  )
         | 
| 405 | 
            -
                  expect(json["workTranslation"]).to eq(
         | 
| 406 | 
            -
                    "@id" => "https://doi.org/10.1234/translated-version",
         | 
| 407 | 
            -
                    "@type" => "CreativeWork"
         | 
| 408 | 
            -
                  )
         | 
| 409 | 
            -
                  expect(json["translationOfWork"]).to eq(
         | 
| 410 | 
            -
                    "@id" => "https://doi.org/10.1234/other-version",
         | 
| 411 | 
            -
                    "@type" => "CreativeWork"
         | 
| 412 | 
            -
                  )
         | 
| 413 | 
            -
                  expect(json["temporalCoverage"]).to eq(
         | 
| 414 | 
            -
                    "2020-01-01"
         | 
| 415 | 
            -
                  )      
         | 
| 416 | 
            -
                end
         | 
| 417 | 
            -
             | 
| 418 | 
            -
                it "when descriptions is a dictionary" do
         | 
| 419 | 
            -
                  input = fixture_path + 'datacite-example-full-v4.6.xml'
         | 
| 420 | 
            -
                  subject = Bolognese::Metadata.new(input: input)
         | 
| 421 | 
            -
                  subject.descriptions = { "descriptionType" => "Abstract", "description" => "This is an abstract as a dictionary." }
         | 
| 422 | 
            -
                  json = JSON.parse(subject.schema_org)
         | 
| 423 | 
            -
                  expect(json.fetch("description")).to eq("This is an abstract as a dictionary.")
         | 
| 424 | 
            -
                end
         | 
| 425 | 
            -
              end
         | 
| 426 | 
            -
            end
         | 
| @@ -1,102 +0,0 @@ | |
| 1 | 
            -
            # frozen_string_literal: true
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            require 'spec_helper'
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            describe Bolognese::Metadata, vcr: true do
         | 
| 6 | 
            -
              context "write metadata as turtle" do
         | 
| 7 | 
            -
                it "Crossref DOI" do
         | 
| 8 | 
            -
                  input = fixture_path + "crossref.bib"
         | 
| 9 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "bibtex")
         | 
| 10 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 11 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 12 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.7554/elife.01567> a schema:ScholarlyArticle;")
         | 
| 13 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 14 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"{eLife} Sciences Organisation, Ltd.\"")
         | 
| 15 | 
            -
                end
         | 
| 16 | 
            -
             | 
| 17 | 
            -
                it "Dataset" do
         | 
| 18 | 
            -
                  input = "https://doi.org/10.5061/DRYAD.8515"
         | 
| 19 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 20 | 
            -
                  expect(subject.valid?).to be true
         | 
| 21 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 22 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 23 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5061/dryad.8515> a schema:Dataset;")
         | 
| 24 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 25 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"Dryad\"")
         | 
| 26 | 
            -
                end
         | 
| 27 | 
            -
             | 
| 28 | 
            -
                it "BlogPosting" do
         | 
| 29 | 
            -
                  input= "https://doi.org/10.5438/4K3M-NYVG"
         | 
| 30 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite")
         | 
| 31 | 
            -
                  expect(subject.valid?).to be true
         | 
| 32 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 33 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 34 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5438/4k3m-nyvg> a schema:ScholarlyArticle;")
         | 
| 35 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 36 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"DataCite\"")
         | 
| 37 | 
            -
                end
         | 
| 38 | 
            -
             | 
| 39 | 
            -
                it "BlogPosting Citeproc JSON" do
         | 
| 40 | 
            -
                  input = fixture_path + "citeproc.json"
         | 
| 41 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "citeproc")
         | 
| 42 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 43 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 44 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5438/4k3m-nyvg> a schema:BlogPosting;")
         | 
| 45 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 46 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"DataCite\"")
         | 
| 47 | 
            -
                end
         | 
| 48 | 
            -
             | 
| 49 | 
            -
                it "BlogPosting DataCite JSON" do
         | 
| 50 | 
            -
                  input = fixture_path + "datacite.json"
         | 
| 51 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "datacite_json")
         | 
| 52 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 53 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 54 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5438/4k3m-nyvg> a schema:ScholarlyArticle;")
         | 
| 55 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 56 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"DataCite\"")
         | 
| 57 | 
            -
                end
         | 
| 58 | 
            -
             | 
| 59 | 
            -
                it "BlogPosting schema.org" do
         | 
| 60 | 
            -
                  input = "https://blog.datacite.org/eating-your-own-dog-food/"
         | 
| 61 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "schema_org")
         | 
| 62 | 
            -
                  expect(subject.valid?).to be true
         | 
| 63 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 64 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 65 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5438/4k3m-nyvg> a schema:BlogPosting;")
         | 
| 66 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 67 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"DataCite\"")
         | 
| 68 | 
            -
                end
         | 
| 69 | 
            -
             | 
| 70 | 
            -
                it "DataONE" do
         | 
| 71 | 
            -
                  input = fixture_path + 'codemeta.json'
         | 
| 72 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "codemeta")
         | 
| 73 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 74 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 75 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.5063/f1m61h5x> a schema:SoftwareSourceCode;")
         | 
| 76 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 77 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"https://cran.r-project.org\"")
         | 
| 78 | 
            -
                end
         | 
| 79 | 
            -
             | 
| 80 | 
            -
                it "journal article" do
         | 
| 81 | 
            -
                  input = "10.7554/eLife.01567"
         | 
| 82 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "crossref")
         | 
| 83 | 
            -
                  expect(subject.valid?).to be true
         | 
| 84 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 85 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 86 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.7554/elife.01567> a schema:ScholarlyArticle;")
         | 
| 87 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 88 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"eLife Sciences Publications, Ltd\"")
         | 
| 89 | 
            -
                end
         | 
| 90 | 
            -
             | 
| 91 | 
            -
                it "with pages" do
         | 
| 92 | 
            -
                  input = "https://doi.org/10.1155/2012/291294"
         | 
| 93 | 
            -
                  subject = Bolognese::Metadata.new(input: input, from: "crossref")
         | 
| 94 | 
            -
                  expect(subject.valid?).to be true
         | 
| 95 | 
            -
                  ttl = subject.turtle.split("\n")
         | 
| 96 | 
            -
                  expect(ttl[0]).to eq("@prefix schema: <http://schema.org/> .")
         | 
| 97 | 
            -
                  expect(ttl[2]).to eq("<https://doi.org/10.1155/2012/291294> a schema:ScholarlyArticle;")
         | 
| 98 | 
            -
                  publisher_line = ttl.find_index('  schema:publisher [') + 2
         | 
| 99 | 
            -
                  expect(ttl[publisher_line]).to eq("    schema:name \"Hindawi Limited\"")
         | 
| 100 | 
            -
                end
         | 
| 101 | 
            -
              end
         | 
| 102 | 
            -
            end
         |