cirneco 0.9.12 → 0.9.13
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +124 -49
- data/cirneco.gemspec +5 -4
- data/lib/cirneco/api.rb +8 -8
- data/lib/cirneco/base.rb +2 -2
- data/lib/cirneco/cli.rb +1 -1
- data/lib/cirneco/utils.rb +48 -95
- data/lib/cirneco/version.rb +1 -1
- data/lib/cirneco/work.rb +8 -203
- data/spec/api_spec.rb +16 -28
- data/spec/doi_spec.rb +9 -11
- data/spec/fixtures/cool-dois-minted/index.html +189 -234
- data/spec/fixtures/cool-dois-minted.html.md +1 -1
- data/spec/fixtures/cool-dois.html.md +2 -2
- data/spec/fixtures/index-minted.html +1 -1
- data/spec/fixtures/index.html +50 -1
- data/spec/fixtures/index.html.erb +2 -2
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/get/should_get_all_dois_by_prefix.yml +20 -18
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/jats/should_generate_jats_for_all_urls.yml +38 -0
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_all_urls.yml +20 -20
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_url.yml +19 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_metadata_for_work.yml +19 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_all_urls.yml +204 -108
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_url.yml +72 -64
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_all_urls.yml +17 -291
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_post_metadata_for_work.yml +47 -82
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_all_dois.yml +22 -18
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_doi.yml +19 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/put/should_put_doi.yml +20 -18
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/jats/writes_jats_for_list_of_urls.yml +38 -0
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_a_doi.yml +19 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_dois_for_list_of_urls.yml +81 -0
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_a_doi.yml +72 -64
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_dois_for_list_of_urls.yml +204 -108
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_dois_for_list_of_urls.yml +17 -291
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_all_dois.yml +140 -18
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi.yml +137 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi_not_found.yml +134 -16
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/username_missing.yml +121 -0
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/put/should_put_doi.yml +138 -18
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/get/should_get_media.yml +135 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/post/should_post_media.yml +137 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/delete/should_delete_metadata.yml +137 -17
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/get/should_get_metadata.yml +170 -27
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/post/should_post_metadata.yml +173 -28
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/media/includes_media.yml +121 -0
- data/spec/fixtures/vcr_cassettes/Cirneco_Work/schema/BlogPosting.yml +121 -0
- data/spec/spec_helper.rb +1 -1
- data/spec/utils_spec.rb +28 -41
- data/spec/work_spec.rb +33 -43
- metadata +43 -19
- data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_url.yml +0 -174
- data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_a_doi.yml +0 -174
@@ -0,0 +1,121 @@
|
|
1
|
+
---
|
2
|
+
http_interactions:
|
3
|
+
- request:
|
4
|
+
method: get
|
5
|
+
uri: https://blog.datacite.org/eating-your-own-dog-food
|
6
|
+
body:
|
7
|
+
encoding: US-ASCII
|
8
|
+
string: ''
|
9
|
+
headers:
|
10
|
+
User-Agent:
|
11
|
+
- Maremma - https://github.com/datacite/maremma
|
12
|
+
Accept:
|
13
|
+
- text/html,application/json,application/xml;q=0.9, text/plain;q=0.8,image/png,*/*;q=0.5
|
14
|
+
response:
|
15
|
+
status:
|
16
|
+
code: 302
|
17
|
+
message: Moved Temporarily
|
18
|
+
headers:
|
19
|
+
Access-Control-Allow-Methods:
|
20
|
+
- GET, POST, OPTIONS
|
21
|
+
Access-Control-Allow-Origin:
|
22
|
+
- "*"
|
23
|
+
Content-Type:
|
24
|
+
- text/html; charset=utf-8
|
25
|
+
Date:
|
26
|
+
- Sat, 22 Jul 2017 07:18:22 GMT
|
27
|
+
Location:
|
28
|
+
- "/eating-your-own-dog-food/"
|
29
|
+
Server:
|
30
|
+
- openresty/1.11.2.2
|
31
|
+
Via:
|
32
|
+
- kong/0.10.3
|
33
|
+
X-Amz-Error-Code:
|
34
|
+
- Found
|
35
|
+
X-Amz-Error-Message:
|
36
|
+
- Resource Found
|
37
|
+
X-Amz-Id-2:
|
38
|
+
- WJJcrkUGORQqdyeAW+bzhHz5g03XonrHC/FSybu16ZT58khMGF9YvSGME+RJpQpY/hzp6H0cGx4=
|
39
|
+
X-Amz-Request-Id:
|
40
|
+
- F96910132A510B39
|
41
|
+
X-Kong-Proxy-Latency:
|
42
|
+
- '0'
|
43
|
+
X-Kong-Upstream-Latency:
|
44
|
+
- '8'
|
45
|
+
Content-Length:
|
46
|
+
- '313'
|
47
|
+
Connection:
|
48
|
+
- keep-alive
|
49
|
+
body:
|
50
|
+
encoding: UTF-8
|
51
|
+
string: |
|
52
|
+
<html>
|
53
|
+
<head><title>302 Moved Temporarily</title></head>
|
54
|
+
<body>
|
55
|
+
<h1>302 Moved Temporarily</h1>
|
56
|
+
<ul>
|
57
|
+
<li>Code: Found</li>
|
58
|
+
<li>Message: Resource Found</li>
|
59
|
+
<li>RequestId: F96910132A510B39</li>
|
60
|
+
<li>HostId: WJJcrkUGORQqdyeAW+bzhHz5g03XonrHC/FSybu16ZT58khMGF9YvSGME+RJpQpY/hzp6H0cGx4=</li>
|
61
|
+
</ul>
|
62
|
+
<hr/>
|
63
|
+
</body>
|
64
|
+
</html>
|
65
|
+
http_version:
|
66
|
+
recorded_at: Sat, 22 Jul 2017 07:18:21 GMT
|
67
|
+
- request:
|
68
|
+
method: get
|
69
|
+
uri: https://blog.datacite.org/eating-your-own-dog-food/
|
70
|
+
body:
|
71
|
+
encoding: US-ASCII
|
72
|
+
string: ''
|
73
|
+
headers:
|
74
|
+
User-Agent:
|
75
|
+
- Maremma - https://github.com/datacite/maremma
|
76
|
+
Accept:
|
77
|
+
- text/html,application/json,application/xml;q=0.9, text/plain;q=0.8,image/png,*/*;q=0.5
|
78
|
+
response:
|
79
|
+
status:
|
80
|
+
code: 200
|
81
|
+
message: OK
|
82
|
+
headers:
|
83
|
+
Access-Control-Allow-Methods:
|
84
|
+
- GET, POST, OPTIONS
|
85
|
+
Access-Control-Allow-Origin:
|
86
|
+
- "*"
|
87
|
+
Cache-Control:
|
88
|
+
- max-age=31536000
|
89
|
+
Content-Type:
|
90
|
+
- text/html; charset=UTF-8
|
91
|
+
Date:
|
92
|
+
- Sat, 22 Jul 2017 07:18:22 GMT
|
93
|
+
Etag:
|
94
|
+
- '"6a6aa03cbec8a262c30666fec1970897"'
|
95
|
+
Last-Modified:
|
96
|
+
- Thu, 20 Jul 2017 11:39:32 GMT
|
97
|
+
Server:
|
98
|
+
- openresty/1.11.2.2
|
99
|
+
Via:
|
100
|
+
- kong/0.10.3
|
101
|
+
X-Amz-Id-2:
|
102
|
+
- gTINNf8lNV+G4ZCgO9QM+yvL3JhMascyiHEUcTssCbP3/1pOofnGczUfjNgdRbPebcaAwK4Ehw4=
|
103
|
+
X-Amz-Request-Id:
|
104
|
+
- 40A5ABB017903106
|
105
|
+
X-Amz-Version-Id:
|
106
|
+
- ZckgSKWJ.zIsvx_v6pKkZMyNt30kmwQi
|
107
|
+
X-Kong-Proxy-Latency:
|
108
|
+
- '0'
|
109
|
+
X-Kong-Upstream-Latency:
|
110
|
+
- '11'
|
111
|
+
Content-Length:
|
112
|
+
- '23992'
|
113
|
+
Connection:
|
114
|
+
- keep-alive
|
115
|
+
body:
|
116
|
+
encoding: ASCII-8BIT
|
117
|
+
string: !binary |-
|
118
|
+
<!DOCTYPE html>
  <html>
    <head>
    <meta charset="utf-8">
    <!-- (1) Optimize for mobile versions: http://goo.gl/EOpFl -->
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <!-- (1) force latest IE rendering engine: bit.ly/1c8EiC9 -->
    <meta http-equiv="X-UA-Compatible" content="IE=edge">


    <title>Eating your own Dog Food</title>
    <meta name="description" content="Eating your own dog food is a slang term to describe that an organization should itself use the products and services it provides. For DataCite this means that we should use DOIs with appropriate metadata and strategies for long-term preservation for..." />

    <meta name="HandheldFriendly" content="True" />
    <meta name="MobileOptimized" content="320" />
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">

    <!-- DublinCore Metadata -->
    <meta property="dc:title" content="Eating your own Dog Food" />
    <meta property="dc:format" content="text/html" />
    <meta property="dc:language" content="en" />
    <meta property="dc:rights" content="CC-BY" />
    <meta property="dc:source" content="DataCite Blog" />
    <meta property="dc:subject" content="Scholarly Communication" />
    <meta property="dc:type" content="website" />


    <meta property="og:site_name" content="Eating your own Dog Food" />
    <meta property="og:description" content="Eating your own dog food is a slang term to describe that an organization should itself use the products and services it provides. For DataCite this means that we should use DOIs with appropriate metadata and strategies for long-term preservation for..." />
    <meta property="og:image" content="https://blog.datacite.org/images/2016/12/230785.jpg" />
    <meta property="og:type" content="blog" />

    <link href="//fonts.googleapis.com/css?family=Libre+Baskerville:400,400i,700" rel="stylesheet">
    <link href='//fonts.googleapis.com/css?family=Raleway:400,600,400italic,600italic' rel='stylesheet' type='text/css'>
    <link href="//maxcdn.bootstrapcdn.com/font-awesome/4.6.1/css/font-awesome.min.css" rel="stylesheet" type='text/css'>
    <link href="https://assets.datacite.org/stylesheets/datacite.css" rel='stylesheet' type='text/css'>
    <link href="https://assets.datacite.org/images/favicon.ico" rel="icon" type="image/ico" />

      <script
        src="//d2wy8f7a9ursnm.cloudfront.net/bugsnag-2.min.js"
        data-apikey="c37a5861967091a9b42a1a77e235114a">
      </script>

    <script type="application/ld+json">
      {"@context":"http://schema.org","@type":"BlogPosting","@id":"https://doi.org/10.5438/4K3M-NYVG","name":"Eating your own Dog Food","alternateName":"MS-49-3632-5083","url":"https://blog.datacite.org/eating-your-own-dog-food/","author":[{"@type":"Person","@id":"http://orcid.org/0000-0003-1419-2405","givenName":"Martin","familyName":"Fenner","name":"Martin Fenner"}],"publisher":{"@type":"Organization","name":"DataCite"},"dateCreated":"2016-12-20","datePublished":"2016-12-20","dateModified":"2016-12-20","keywords":"datacite, doi, metadata, featured","version":"1.0","description":"Eating your own dog food is a slang term to describe that an organization should itself use the products and services it provides. For DataCite this means that we should use DOIs with appropriate metadata and strategies for long-term preservation for...","license":"https://creativecommons.org/licenses/by/4.0/","image":"https://blog.datacite.org/images/2016/12/230785.jpg","encoding":{"@type":"MediaObject","@id":"https://blog.datacite.org/eating-your-own-dog-food/eating-your-own-dog-food.xml","fileFormat":"application/xml"},"isPartOf":{"@type":"Blog","@id":"https://doi.org/10.5438/0000-00SS","name":"DataCite Blog"},"citation":[{"@type":"CreativeWork","@id":"https://doi.org/10.5438/0012"},{"@type":"CreativeWork","@id":"https://doi.org/10.5438/55E5-T5C0"}]}
    </script>
  </head>
  <body>
    <header class="header" id="navtop">
      <div class="navbar navbar-white" role="navigation">
        <div class="container-fluid">
          <div class="navbar-header"
            <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
              <span class="sr-only">Toggle navigation</span>
              <span class="icon-bar"></span>
              <span class="icon-bar"></span>
              <span class="icon-bar"></span>
            </button>
          </div>
          <a class="navbar-brand" href="/">DataCite Blog</a>
          <div class="navbar-collapse collapse">
            <ul class="nav navbar-nav navbar-right">
              <li><a href="https://support.datacite.org">Support</a></li>
              <li class="dropdown">
                <a href="#" class="dropdown-toggle" data-toggle="dropdown" id="sites"><i class='fa fa-th'></i> <span class="caret"></span></a>
                <ul class="dropdown-menu" role="menu">
                  <li><a href="https://www.datacite.org">
                    <i class='fa fa-globe fa-fw'></i>
                    Homepage</a>
                  </li>
                  <li><a href="https://blog.datacite.org">
                    <i class='fa fa-rss fa-fw'></i>
                    Blog</a>
                  </li>
                  <li class="divider"></li>
                  <li><a href="https://mds.datacite.org">
                    <i class='fa fa-database fa-fw'></i>
                    MDS</a>
                  </li>
                  <li><a href="https://schema.datacite.org">
                    <i class='fa fa-file-code-o fa-fw'></i>
                    Schema</a>
                  </li>
                  <li><a href="http://citation.crosscite.org">
                    <i class='fa fa-file-text-o fa-fw'></i>
                    Citation Formatter</a>
                  </li>
                  <li class="divider"></li>
                  <li><a href="https://search.datacite.org">
                    <i class='fa fa-search fa-fw'></i>
                    Search</a>
                  </li>
                  <li><a href="https://oai.datacite.org">
                    <i class='fa fa-table fa-fw'></i>
                    OAI-PMH</a>
                  </li>
                  <li><a href="https://stats.datacite.org">
                    <i class='fa fa-bar-chart fa-fw'></i>
                    Statistics</a>
                  </li>
                  <li><a href="https://api.datacite.org">
                    <i class='fa fa-cogs fa-fw'></i>
                    REST API</a>
                  </li>
                  <li><a href="http://www.re3data.org">
                    <i class='fa fa-cubes fa-fw'></i>
                    re3data</a>
                  </li>
                  <li class="divider"></li>
                  <li><a href="http://status.datacite.org">
                    <i class='fa fa-calendar-check-o fa-fw'></i>
                    Status</a>
                  </li>
                </ul>
              </li>
            </ul>
          </div>
        </div>
      </div>
    </header>
      <div class="wrapper">
    <div class="section section-white">
      <div class="container-fluid">
        <div class="row row-section">
          <div class="col-md-8 col-md-offset-2 post-content">
            <a name="topofpage"></a>
            <div class="post-meta">
              <h1>Eating your own Dog Food</h1>
              December 20, 2016 by Martin Fenner
              • <span class="post-reading-time"></span> read
                <p class="doi"><a href="https://doi.org/10.5438/4K3M-NYVG">https://doi.org/10.5438/4K3M-NYVG</a></p>
            </div>

            <p><a href="https://newrepublic.com/article/115349/dogfooding-tech-slang-working-out-glitches">Eating your own dog food</a> is a slang term to describe that an organization should itself use the products and services it provides. For DataCite this means that we should use DOIs with appropriate metadata and strategies for long-term preservation for the scholarly outputs we produce. For the most part this is not research data, but rather technical documents such as the DataCite Schema and its documentation <span class="citation">(<a href="#ref-https://doi.org/10.5438/0012">2016</a>)</span>.</p>
<p>These outputs also include the posts on this blog, where we discuss topics relevant for the DataCite community, but also of broader interest to anyone who cares about research data, persistent identifiers, and scholarly infrastructure. And starting today all blog posts on this blog will have a DOI, metadata and use a persistent storage mechanism.</p>
<div class="figure">
<img src="/images/2016/12/230785.jpg" alt="Photo by Bill Emrich. CC Zero." />
<p class="caption">Photo by <a href="https://www.pexels.com/photo/black-and-tan-yorkshire-terrier-puppy-230785/">Bill Emrich</a>. <a href="https://creativecommons.org/publicdomain/zero/1.0/">CC Zero</a>.</p>
</div>
<h3 id="technical-implementation">Technical Implementation</h3>
<p>This blog is powered by the static site generator <a href="https://middlemanapp.com/">Middleman</a>, with blog posts written in <a href="http://commonmark.org/">Markdown</a> and converted to HTML using <a href="http://pandoc.org/">Pandoc</a> and the <a href="https://travis-ci.org">Travis CI</a> continuous integration service. Static site generator means that there is no database or application server powering the site, making website adminstration simpler, cheaper and safer. In addition to the blog, the <a href="https://www.datacite.org">DataCite homepage</a> and <a href="https://schema.datacite.org">Metadata Schema subsite</a> are also generated using Middleman.</p>
<p>The simplicity is particularly important here, as registering the DOIs and metadata can be accomplished using a command line utility written by DataCite staff that doesn’t need to know much about the internals of Middleman, and thus can be easily adapted to other static site generators such as <a href="http://jekyllrb.com/">Jekyll</a>, <a href="http://gohugo.io/">Hugo</a> or <a href="https://hexo.io/">Hexo</a>. The command line utility is <a href="https://github.com/datacite/cirneco">Cirneco</a>, generating the metadata XML according to the DataCite Metadata Schema, and registering DOI and metadata with the DataCite MDS. Like all tools mentioned in this post Cirneco is open source software, please reach out to us if you are interested in implementing similar functionality for your blog.</p>
<h3 id="generating-dois">Generating DOIs</h3>
<p>The DOIs for this blog are generated automatically, using a modified base32 encoding algorithm that is provided by Cirneco, as discussed last week <span class="citation">(Fenner, <a href="#ref-https://doi.org/10.5438/55E5-T5C0">2016</a>)</span>. The DOI is generated and minted when a new post is pushed to <a href="https://blog.datacite.org" class="uri">https://blog.datacite.org</a>. This avoids two problems: a) DOI-like strings in the wild before publication and b) the randomly generated DOI exists already (we can simply generate a new one). All DOIs are short, without semantic infomation that might change over time, and with a checksum to minimize transcription errors, for example <strong>https://doi.org/10.5438/XCBJ-G7ZY</strong>. Going forward we encourage users to link to the DataCite Blog using the DOI, as these links will continue to work even if we ever move the blog to a different location.</p>
<h3 id="generating-metadata">Generating Metadata</h3>
<p>For the generation of metadata, we need to strike a balance between simple author provided metadata, but rich enough to aid discovery. We are doing this via three mechanisms:</p>
<ul>
<li>metadata provided by the author</li>
<li>default metadata for the blog</li>
<li>metadata automatically extracted from content</li>
</ul>
<p>The metadata provided by the author are the typical metadata for blog posts, provided via <a href="https://gohugo.io/content/front-matter/">YAML front matter</a> at the beginning of each post:</p>
<div class="sourceCode"><pre class="sourceCode yaml"><code class="sourceCode yaml"><span class="ot">---</span>
<span class="fu">layout:</span> post
<span class="fu">title:</span> Eating your own Dog Food
<span class="fu">author:</span> mfenner
<span class="fu">date:</span> 2016-12-19
<span class="fu">tags:</span>
<span class="kw">-</span> datacite
<span class="kw">-</span> doi
<span class="kw">-</span> metadata
<span class="ot">---</span></code></pre></div>
<p>We can reuse all these metadata when generating DataCite metadata, using the tags as <code>subjects</code>.</p>
<p>The default metadata are metadata that always stay the same for the blog, such as <code>publisher</code>, <code>HostingInstitution</code> and <code>rights</code>. We can store them in a site-wide configuration file. We can also assume reasonable defaults that can be overridden in the YAML front matter, e.g. <code>resourceType</code> (we use <a href="https://schema.org/BlogPosting">BlogPosting</a> with <code>resourceTypeGeneral</code> Text) and <code>version</code>. We store more information about authors outside the blog post, including <code>givenName</code>, <code>familyName</code> and <code>nameIdentifier</code> (we now show the ORCID ID of every blog author at the bottom of the post).</p>
<p>Finally, there are metadata that we can automatically extract from the blog post, and we are currently doing this for the <code>description</code> and <code>relatedIdentifier</code>. This blog uses Pandoc and BibTex to generate the references section at the end, and we can fetch this information and convert it into the format needed for <code>relatedIdentifier</code>.</p>
<p>Taken together we can provide all metadata that are <em>required</em> or <em>recommended</em> in the Metadata Schema documentation <span class="citation">(<a href="#ref-https://doi.org/10.5438/0012">2016</a>)</span>, and we can do this without any extra effort for the author. The full XML is avalailable <a href="https://data.datacite.org/content-resolver/application/x-datacite+xml/10.5438/4K3M-NYVG">here</a>.</p>
<p>Not all blog posts need to be cited formally with metadata in a <em>references</em> list formatted according to a specific citation style. But these metadata greatly help with discovery, a search in DataCite Search for <a href="http://search.datacite.org/works?query=eating+dog+food">eating dog food</a> will for example bring up this blog post as the first hit.</p>
<h3 id="persistent-storage">Persistent storage</h3>
<p>Using DOIs means that readers not only expect rich metadata that help with citation and discovery, but also that DataCite takes extra care to preserve the blog posts, thinking beyond the particular technical implementation or even the contiuing existence of this blog. This is an area where we do need to do more work, starting with a decision about the best archival format for a blog post (HTML, PDF, <a href="https://jats.nlm.nih.gov/">JATS</a>?). For now blog posts are hosted in multiple Git repositories (<a href="https://github.com/datacite/blog">one of them on Github</a>), and in two independent Amazon S3 buckets that each use <a href="http://docs.aws.amazon.com/AmazonS3/latest/dev/Versioning.html">versioning</a>. Multiple locations with versioning are a good start, but more work is clearly needed.</p>
<h3 id="references" class="unnumbered">References</h3>
<div id="refs" class="references">
<div id="ref-https://doi.org/10.5438/0012">
<p>DataCite Metadata Working Group. (2016). DataCite Metadata Schema for the Publication and Citation of Research Data v4.0. <em>DataCite</em>. <a href="https://doi.org/10.5438/0012" class="uri">https://doi.org/10.5438/0012</a></p>
</div>
<div id="ref-https://doi.org/10.5438/55E5-T5C0">
<p>Fenner, M. (2016). Cool DOI’s. <em>DataCite</em>. <a href="https://doi.org/10.5438/55E5-T5C0" class="uri">https://doi.org/10.5438/55E5-T5C0</a></p>
</div>
</div>

            <hr width="80%">
          </div>
        </div>
        <div class="row">
          <div class="col-md-5 col-md-offset-2 post-content">
            <div class="bottom-teaser cf">
  <div class="isLeft">
    <section class="author">
          <div class="author-image" style="background-image: url(https://www.gravatar.com/avatar/434592a097e91261792ebd6b492042bc?s=250&d=mm&r=x)">Blog Logo</div>
        <h4>Martin Fenner</h4>
        <p class="bio">DataCite Technical Director</p>
        <p class="orcid"><a href="http://orcid.org/0000-0003-1419-2405">http://orcid.org/0000-0003-1419-2405</a></p>
        <div class="clearfix"></div>
      <h4>Eating your own Dog Food</h4>
        <p class="published"><a href="https://doi.org/10.5438/4K3M-NYVG">https://doi.org/10.5438/4K3M-NYVG</a>
      <p class="published"><i class="fa fa-calendar"></i> <time datetime="2016-12-20 00:00">December 20, 2016</time></p>
      <p class="published"><i class="fa fa-history"></i> <a href="https://github.com/datacite/blog/commits/master/source/posts/eating-your-own-dog-food.html.md">History</a></p>
      <p class="published">© 2016 Martin Fenner. Distributed under the terms of the <a href="https://creativecommons.org/licenses/by/4.0/">Creative Commons Attribution license</a>.</p>
      <p class="published">
        <i class="fa fa-tags"></i>
        <a href="/index.html?tag=datacite">datacite</a>, <a href="/index.html?tag=doi">doi</a>, <a href="/index.html?tag=metadata">metadata</a>, <a href="/index.html?tag=featured">featured</a>
      </p>
    </section>
  </div>
</div>

          </div>
          <div class="col-md-2 col-md-offset-1">
             <div class="bottom-teaser cf">
  <div class="isLeft">
    <h5 class="index-headline featured"><span>Share on</span></h5>
      <a class="icon-twitter" href="http://twitter.com/share?text=On the @datacite blog: Eating your own Dog Food&amp;url=https://blog.datacite.org/eating-your-own-dog-food/"
        onclick="window.open(this.href, 'twitter-share', 'width=550,height=255');return false;">
        <i class="fa fa-twitter fa-2x"></i><span class="hidden">twitter</span>
      </a>
      <a class="icon-facebook" href="https://www.facebook.com/sharer.php?t=On the @datacite blog: Eating your own Dog Food&amp;u=https://blog.datacite.org/eating-your-own-dog-food/"
        onclick="window.open(this.href, 'facebook-share', 'width=550,height=255');return false;">
        <i class="fa fa-facebook fa-2x"></i><span class="hidden">facebook</span>
      </a>
  </div>
</div>

          </div>
        </div>
          <div class="row">
            <div class="col-md-8 col-md-offset-2 post-content">
              <div id="disqus_thread"></div>
<script>
    var disqus_config = function () {
        this.page.url = 'https://blog.datacite.org/eating-your-own-dog-food/';
        this.page.identifier = 'https://doi.org/10.5438/4K3M-NYVG';
    };
    (function() {
        var d = document, s = d.createElement('script');

        s.src = '//datacite.disqus.com/embed.js';  //

        s.setAttribute('data-timestamp', +new Date());
        (d.head || d.body).appendChild(s);
    })();
</script>
<noscript>Please enable JavaScript to view the <a href="https://disqus.com/?ref_noscript" rel="nofollow">comments powered by Disqus.</a></noscript>

            </div>
          </div>
      </div>
    </div>
  </div>
    <footer class='row footer'>
      <div class="container-fluid">
        <div class='col-md-3 col-sm-4'>
          <h4>About DataCite</h4>
          <ul>
            <li><a href="https://www.datacite.org/mission.html">What we do</a></li>
            <li><a href="https://www.datacite.org/board.html">Board</a></li>
            <li><a href="https://www.datacite.org/steering.html">Steering groups</a></li>
            <li><a href="https://www.datacite.org/staff.html">Staff</a></li>
            <li><a href="https://www.datacite.org/jobopportunities.html">Job opportunities</a></li>
          </ul>
        </div>
        <div class='col-md-3 col-sm-4'>
          <h4>Services</h4>
          <ul>
            <li><a href="https://www.datacite.org/dois.html">Assign DOIs</a></li>
            <li><a href="https://www.datacite.org/search.html">Metadata search</a></li>
            <li><a href="https://www.datacite.org/eventdata.html">Event data</a></li>
            <li><a href="https://www.datacite.org/profiles.html">Profiles</a></li>
            <li><a href="https://www.datacite.org/re3data.html">re3data</a></li>
            <li><a href="https://www.datacite.org/citation.html">Citation formatter</a></li>
            <li><a href="https://www.datacite.org/stats.html">Statistics</a></li>
            <li><a href="https://www.datacite.org/content.html">Content negotiation</a></li>
            <li><a href="https://www.datacite.org/oaipmh.html">OAI-PMH</a></li>
            <li><a href="https://www.datacite.org/test.html">Test environment</a></li>
          </ul>
        </div>
        <div class='col-md-3 col-sm-4'>
          <h4>Resources</h4>
          <ul>
            <li><a href="https://schema.datacite.org">Metadata schema</a></li>
            <li><a href="https://support.datacite.org">Support</a></li>
          </ul>
          <h4>Community</h4>
          <ul>
            <li><a href="https://www.datacite.org/members.html">Members</a></li>
            <li><a href="https://www.datacite.org/partners.html">Partners</a></li>
            <li><a href="https://www.datacite.org/steering.html">Steering groups</a></li>
            <li><a href="https://www.datacite.org/events.html">Events</a></li>
            <li><a href="https://www.datacite.org/roadmap.html">Roadmap</a></li>
            <li><a href="https://www.datacite.org/user-stories.html">User Stories</a></li>
          </ul>
        </div>
        <div class='col-md-3'>
          <h4 class="share">Contact us</h4>
          <a href='mailto:support@datacite.org' class="share">
            <i class='fa fa-at'></i>
          </a>
          <a href='https://blog.datacite.org/feed.xml' class="share">
            <i class='fa fa-rss'></i>
          </a>
          <a href='https://twitter.com/datacite' class="share">
            <i class='fa fa-twitter'></i>
          </a>
          <a href='https://github.com/datacite/datacite' class="share">
            <i class='fa fa-github'></i>
          </a>
          <a href='https://www.linkedin.com/company/datacite' class="share">
            <i class='fa fa-linkedin'></i>
          </a>
          <ul>
            <li><a href="https://www.datacite.org/terms.html">Terms and conditions</a></li>
            <li><a href="https://www.datacite.org/privacy.html">Privacy policy</a></li>
            <li><a href="https://www.datacite.org/acknowledgments.html">Acknowledgements</a></li>
          </ul>
          <a href="http://status.datacite.org" target="_blank">
            <span class="color-dot"></span>
            <span class="color-description"></span>
          </a>
        </div>
      </div>
    </footer>
    <script src="//code.jquery.com/jquery-2.1.4.min.js"></script>
    <script src="//maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
    <script src="//cdn.statuspage.io/se-v2.js"></script>
    <script src="https://assets.datacite.org/javascripts/default.js"></script>
    <script src="/javascripts/readingTime.min.js"></script>
    <script src="/javascripts/index.js"></script>
    <script src="/javascripts/search.js"></script>
    <script id="dsq-count-scr" src="//datacite.disqus.com/count.js" async></script>
    <script>
      (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
      (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
      m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
      })(window,document,'script','//www.google-analytics.com/analytics.js','ga');

      ga('create', 'UA-22806196-6', 'auto');
      ga('send', 'pageview');
    </script>
  </body>
</html>

|
119
|
+
http_version:
|
120
|
+
recorded_at: Sat, 22 Jul 2017 07:18:21 GMT
|
121
|
+
recorded_with: VCR 3.0.3
|
data/spec/spec_helper.rb
CHANGED
@@ -85,7 +85,7 @@ VCR.configure do |c|
|
|
85
85
|
c.cassette_library_dir = "spec/fixtures/vcr_cassettes"
|
86
86
|
c.hook_into :webmock
|
87
87
|
c.ignore_localhost = true
|
88
|
-
c.ignore_hosts 'codeclimate.com'
|
88
|
+
c.ignore_hosts 'codeclimate.com', 'mds.test.datacite.org'
|
89
89
|
c.filter_sensitive_data("<MDS_TOKEN>") { mds_token }
|
90
90
|
c.configure_rspec_metadata!
|
91
91
|
end
|
data/spec/utils_spec.rb
CHANGED
@@ -20,14 +20,14 @@ describe Cirneco::DataCenter, vcr: true, :order => :defined do
|
|
20
20
|
it 'should get all dois by prefix' do
|
21
21
|
response = subject.get_dois_by_prefix(prefix, options)
|
22
22
|
dois = response.body["data"]
|
23
|
-
expect(dois.length).to eq(
|
24
|
-
expect(dois.first).to eq("10.
|
23
|
+
expect(dois.length).to eq(437)
|
24
|
+
expect(dois.first).to eq("10.5438/0000-00SS")
|
25
25
|
end
|
26
26
|
end
|
27
27
|
|
28
28
|
context "base32" do
|
29
29
|
it 'should decode doi' do
|
30
|
-
doi = "10.
|
30
|
+
doi = "10.5438/0000-03WD"
|
31
31
|
expect(subject.decode_doi(doi)).to eq(124)
|
32
32
|
end
|
33
33
|
|
@@ -38,16 +38,16 @@ describe Cirneco::DataCenter, vcr: true, :order => :defined do
|
|
38
38
|
|
39
39
|
it 'should encode doi' do
|
40
40
|
number = 123
|
41
|
-
expect(subject.encode_doi(prefix, number: number)).to eq("10.
|
41
|
+
expect(subject.encode_doi(prefix, number: number)).to eq("10.5438/0000-03VC")
|
42
42
|
end
|
43
43
|
|
44
44
|
it 'should encode doi number with other characters' do
|
45
45
|
number = "MS-123"
|
46
|
-
expect(subject.encode_doi(prefix, number: number)).to eq("10.
|
46
|
+
expect(subject.encode_doi(prefix, number: number)).to eq("10.5438/0000-03VC")
|
47
47
|
end
|
48
48
|
|
49
49
|
it 'should encode doi random number' do
|
50
|
-
expect(subject.encode_doi(prefix)).to start_with("10.
|
50
|
+
expect(subject.encode_doi(prefix)).to start_with("10.5438")
|
51
51
|
end
|
52
52
|
end
|
53
53
|
|
@@ -120,78 +120,65 @@ describe Cirneco::DataCenter, vcr: true, :order => :defined do
|
|
120
120
|
it 'should mint for url' do
|
121
121
|
filepath = fixture_path + 'cool-dois/index.html'
|
122
122
|
response = subject.mint_doi_for_url(filepath, options)
|
123
|
-
expect(response).to eq("DOI 10.
|
123
|
+
expect(response).to eq("DOI 10.5438/0000-03VC minted for cool-dois.html.md")
|
124
124
|
end
|
125
125
|
|
126
126
|
it 'should hide for url' do
|
127
|
-
filepath = fixture_path + 'cool-dois-minted.html'
|
127
|
+
filepath = fixture_path + 'cool-dois-minted/index.html'
|
128
128
|
response = subject.hide_doi_for_url(filepath, options)
|
129
|
-
expect(response).to eq("DOI 10.
|
129
|
+
expect(response).to eq("DOI 10.5438/55E5-T5C0 hidden for cool-dois-minted.html.md")
|
130
130
|
end
|
131
131
|
|
132
132
|
it 'should mint and hide for url' do
|
133
133
|
filepath = fixture_path + 'cool-dois/index.html'
|
134
134
|
response = subject.mint_and_hide_doi_for_url(filepath, options)
|
135
|
-
expect(response).to eq("DOI 10.
|
135
|
+
expect(response).to eq("DOI 10.5438/0000-03VC minted and hidden for cool-dois.html.md")
|
136
136
|
end
|
137
137
|
|
138
138
|
it 'should mint for all urls' do
|
139
139
|
filepath = fixture_path + 'index.html'
|
140
140
|
response = subject.mint_dois_for_all_urls(filepath, options)
|
141
|
-
expect(response).to eq("DOI 10.
|
141
|
+
expect(response).to eq("DOI 10.5438/0000-03VC minted for cool-dois.html.md\nDOI 10.5438/0000-00SS minted for index.html.erb")
|
142
142
|
end
|
143
143
|
|
144
144
|
it 'should hide for all urls' do
|
145
145
|
filepath = fixture_path + 'index-minted.html'
|
146
146
|
response = subject.hide_dois_for_all_urls(filepath, options)
|
147
|
-
expect(response).to eq("No DOI for cool-dois.html.md\nErrors for DOI 10.
|
147
|
+
expect(response).to eq("No DOI for cool-dois.html.md\nErrors for DOI 10.5438/0000-NW90: Not found\n")
|
148
148
|
end
|
149
149
|
|
150
150
|
it 'should mint and hide for all urls' do
|
151
151
|
filepath = fixture_path + 'index.html'
|
152
152
|
response = subject.mint_and_hide_dois_for_all_urls(filepath, options)
|
153
|
-
expect(response).to eq("DOI 10.
|
153
|
+
expect(response).to eq("DOI 10.5438/0000-03VC minted and hidden for cool-dois.html.md\nDOI 10.5438/0000-00SS minted and hidden for index.html.erb")
|
154
154
|
end
|
155
155
|
|
156
|
-
it 'should
|
156
|
+
it 'should get_json_ld_from_work' do
|
157
157
|
filepath = fixture_path + 'cool-dois/index.html'
|
158
|
-
|
158
|
+
json = subject.get_json_ld_from_work(filepath)
|
159
|
+
metadata = JSON.parse(json)
|
159
160
|
expect(metadata["url"]).to eq("https://blog.datacite.org/cool-dois/")
|
160
|
-
expect(metadata["
|
161
|
-
expect(metadata["
|
162
|
-
expect(metadata["
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
:relation_type=>"References" },
|
168
|
-
{ :value=>"https://blog.datacite.org/",
|
169
|
-
:related_identifier_type=>"URL",
|
170
|
-
:relation_type=>"IsPartOf"}])
|
171
|
-
end
|
172
|
-
|
173
|
-
it 'should generate metadata for work no JSON-LD' do
|
174
|
-
filepath = fixture_path + 'cool-dois-no-json-ld/index.html'
|
175
|
-
expect(subject.generate_metadata_for_work(filepath)).to eq("error"=>"Error: no schema.org metadata found")
|
176
|
-
end
|
177
|
-
|
178
|
-
it 'should generate metadata for work missing required metadata' do
|
179
|
-
filepath = fixture_path + 'cool-dois-missing-metadata/index.html'
|
180
|
-
expect(subject.generate_metadata_for_work(filepath)).to eq("error"=>"Error: required metadata missing")
|
161
|
+
expect(metadata["author"]).to eq([{"@type"=>"Person", "@id"=>"http://orcid.org/0000-0003-1419-2405", "givenName"=>"Martin", "familyName"=>"Fenner", "name"=>"Martin Fenner"}])
|
162
|
+
expect(metadata["description"]).to eq("In 1998 Tim Berners-Lee coined the term cool URIs (1998), that is URIs that don’t change. We know that URLs referenced in the scholarly literature are often not cool, leading to link rot (Klein et al., 2014) and making it hard or impossible to find...")
|
163
|
+
expect(metadata["citation"]).to eq([{"@type"=>"CreativeWork",
|
164
|
+
"@id"=>"https://www.w3.org/Provider/Style/URI"},
|
165
|
+
{"@type"=>"CreativeWork",
|
166
|
+
"@id"=>"https://doi.org/10.1371/journal.pone.0115253"}])
|
167
|
+
expect(metadata["isPartOf"]).to eq("@type"=>"Blog", "@id"=>"https://blog.datacite.org", "name"=>"DataCite Blog")
|
181
168
|
end
|
182
169
|
|
183
170
|
it 'should post_metadata_for_work' do
|
184
171
|
filepath = fixture_path + 'cool-dois/index.html'
|
185
|
-
|
186
|
-
response = subject.post_metadata_for_work(
|
172
|
+
json = subject.get_json_ld_from_work(filepath)
|
173
|
+
response = subject.post_metadata_for_work(json, options)
|
187
174
|
expect(response.body["data"]).to eq("OK")
|
188
|
-
expect(response.status).to eq(
|
175
|
+
expect(response.status).to eq(201)
|
189
176
|
end
|
190
177
|
|
191
178
|
it 'should hide_metadata_for_work' do
|
192
179
|
filepath = fixture_path + 'cool-dois/index.html'
|
193
|
-
|
194
|
-
response = subject.hide_metadata_for_work(
|
180
|
+
json = subject.get_json_ld_from_work(filepath)
|
181
|
+
response = subject.hide_metadata_for_work(json, options)
|
195
182
|
expect(response.body["data"]).to eq("OK")
|
196
183
|
expect(response.status).to eq(200)
|
197
184
|
end
|
data/spec/work_spec.rb
CHANGED
@@ -1,58 +1,48 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe Cirneco::Work, vcr: true do
|
4
|
-
let(:
|
5
|
-
let(:
|
6
|
-
let(:creators) { [{ given_name: "Elizabeth", family_name: "Miller", orcid: "0000-0001-5000-0007" }] }
|
7
|
-
let(:title) { "Full DataCite XML Example" }
|
8
|
-
let(:publisher) { "DataCite" }
|
9
|
-
let(:publication_year) { 2014 }
|
10
|
-
let(:resource_type) { { value: "XML", resource_type_general: "Software" } }
|
11
|
-
let(:subjects) { ["000 computer science"] }
|
12
|
-
let(:descriptions) { [{ value: "XML example of all DataCite Metadata Schema v4.0 properties.", description_type: "Abstract" }] }
|
13
|
-
let(:rights_list) { [{ value: "CC0 1.0 Universal", rights_uri: "http://creativecommons.org/publicdomain/zero/1.0/" }] }
|
14
|
-
let(:media) { [{ mime_type: "application/pdf", url:"http://www.datacite.org/cirneco-test.pdf" }]}
|
15
|
-
let(:metadata) { { "doi" => doi,
|
16
|
-
"url" => url,
|
17
|
-
"creators" => creators,
|
18
|
-
"title" => title,
|
19
|
-
"publisher" => publisher,
|
20
|
-
"publication_year" => publication_year,
|
21
|
-
"resource_type" => resource_type,
|
22
|
-
"subjects" => subjects,
|
23
|
-
"descriptions" => descriptions,
|
24
|
-
"rights_list" => rights_list,
|
25
|
-
"media" => media } }
|
4
|
+
let(:input) { "https://blog.datacite.org/eating-your-own-dog-food/" }
|
5
|
+
let(:media) { [{ mime_type: "application/pdf", url: "http://www.datacite.org/cirneco-test.pdf" }] }
|
26
6
|
let(:username) { ENV['MDS_USERNAME'] }
|
27
7
|
let(:password) { ENV['MDS_PASSWORD'] }
|
28
8
|
let(:fixture_path) { "spec/fixtures/" }
|
29
9
|
let(:samples_path) { "resources/kernel-4.0/samples/" }
|
30
10
|
|
31
|
-
subject { Cirneco::Work.new(
|
11
|
+
subject { Cirneco::Work.new(input: input, from: "schema_org", media: media) }
|
32
12
|
|
33
13
|
describe 'schema' do
|
34
|
-
it
|
35
|
-
|
36
|
-
expect(
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
expect(subject.
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
expect(subject.
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
subject.
|
49
|
-
expect(subject.validation_errors.body["errors"]).to eq([{"title"=>"Element '{http://datacite.org/schema/kernel-4}resourceType', attribute 'resourceTypeGeneral': [facet 'enumeration'] The value '' is not an element of the set {'Audiovisual', 'Collection', 'Dataset', 'Event', 'Image', 'InteractiveResource', 'Model', 'PhysicalObject', 'Service', 'Software', 'Sound', 'Text', 'Workflow', 'Other'}."}, {"title"=>"Element '{http://datacite.org/schema/kernel-4}resourceType', attribute 'resourceTypeGeneral': '' is not a valid value of the atomic type '{http://datacite.org/schema/kernel-4}resourceType'."}])
|
14
|
+
it "BlogPosting" do
|
15
|
+
expect(subject.valid?).to be true
|
16
|
+
expect(subject.id).to eq("https://doi.org/10.5438/4k3m-nyvg")
|
17
|
+
expect(subject.url).to eq("https://blog.datacite.org/eating-your-own-dog-food")
|
18
|
+
expect(subject.type).to eq("BlogPosting")
|
19
|
+
expect(subject.author).to eq("type"=>"Person", "id"=>"http://orcid.org/0000-0003-1419-2405", "name"=>"Martin Fenner", "givenName"=>"Martin", "familyName"=>"Fenner")
|
20
|
+
expect(subject.title).to eq("Eating your own Dog Food")
|
21
|
+
expect(subject.alternate_name).to eq("MS-49-3632-5083")
|
22
|
+
expect(subject.description["text"]).to start_with("Eating your own dog food")
|
23
|
+
expect(subject.keywords).to eq(["datacite", "doi", "metadata", "featured"])
|
24
|
+
expect(subject.date_published).to eq("2016-12-20")
|
25
|
+
expect(subject.date_modified).to eq("2016-12-20")
|
26
|
+
expect(subject.is_part_of).to eq("id"=>"https://doi.org/10.5438/0000-00ss", "type"=>"Blog", "title"=>"DataCite Blog")
|
27
|
+
expect(subject.references).to eq([{"id"=>"https://doi.org/10.5438/0012", "type"=>"CreativeWork"}, {"id"=>"https://doi.org/10.5438/55e5-t5c0", "type"=>"CreativeWork"}])
|
28
|
+
expect(subject.publisher).to eq("DataCite")
|
50
29
|
end
|
51
30
|
|
52
|
-
it 'validates
|
53
|
-
|
54
|
-
|
55
|
-
|
31
|
+
it 'validates example full' do
|
32
|
+
input = samples_path + 'datacite-example-full-v4.0.xml'
|
33
|
+
subject = Cirneco::Work.new(input: input, from: "datacite")
|
34
|
+
|
35
|
+
expect(subject.valid?).to be true
|
36
|
+
expect(subject.id).to eq("https://doi.org/10.5072/example-full")
|
37
|
+
expect(subject.type).to eq("SoftwareSourceCode")
|
38
|
+
expect(subject.author).to eq("type"=>"Person", "id"=>"https://orcid.org/0000-0001-5000-0007", "name"=>"Miller, Elizabeth", "givenName"=>"Elizabeth", "familyName"=>"Miller")
|
39
|
+
expect(subject.title).to eq([{"lang"=>"en-us", "text"=>"Full DataCite XML Example"}, {"title_type"=>"Subtitle", "lang"=>"en-us", "text"=>"Demonstration of DataCite Properties."}])
|
40
|
+
expect(subject.alternate_name).to eq("type"=>"URL", "name"=>"http://schema.datacite.org/schema/meta/kernel-3.1/example/datacite-example-full-v3.1.xml")
|
41
|
+
expect(subject.description["text"]).to start_with("XML example of all DataCite Metadata Schema v4.0 properties.")
|
42
|
+
expect(subject.keywords).to eq([{"subject_scheme"=>"dewey", "scheme_uri"=>"http://dewey.info/", "text"=>"000 computer science"}])
|
43
|
+
expect(subject.date_published).to eq("2014")
|
44
|
+
expect(subject.date_modified).to eq("2014-10-17")
|
45
|
+
expect(subject.publisher).to eq("DataCite")
|
56
46
|
end
|
57
47
|
end
|
58
48
|
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: cirneco
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.9.
|
4
|
+
version: 0.9.13
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Martin Fenner
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-
|
11
|
+
date: 2017-07-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: maremma
|
@@ -16,14 +16,20 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: 3.
|
19
|
+
version: '3.5'
|
20
|
+
- - ">="
|
21
|
+
- !ruby/object:Gem::Version
|
22
|
+
version: 3.5.7
|
20
23
|
type: :runtime
|
21
24
|
prerelease: false
|
22
25
|
version_requirements: !ruby/object:Gem::Requirement
|
23
26
|
requirements:
|
24
27
|
- - "~>"
|
25
28
|
- !ruby/object:Gem::Version
|
26
|
-
version: 3.
|
29
|
+
version: '3.5'
|
30
|
+
- - ">="
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: 3.5.7
|
27
33
|
- !ruby/object:Gem::Dependency
|
28
34
|
name: bergamasco
|
29
35
|
requirement: !ruby/object:Gem::Requirement
|
@@ -38,6 +44,20 @@ dependencies:
|
|
38
44
|
- - "~>"
|
39
45
|
- !ruby/object:Gem::Version
|
40
46
|
version: '0.3'
|
47
|
+
- !ruby/object:Gem::Dependency
|
48
|
+
name: bolognese
|
49
|
+
requirement: !ruby/object:Gem::Requirement
|
50
|
+
requirements:
|
51
|
+
- - "~>"
|
52
|
+
- !ruby/object:Gem::Version
|
53
|
+
version: 0.9.32
|
54
|
+
type: :runtime
|
55
|
+
prerelease: false
|
56
|
+
version_requirements: !ruby/object:Gem::Requirement
|
57
|
+
requirements:
|
58
|
+
- - "~>"
|
59
|
+
- !ruby/object:Gem::Version
|
60
|
+
version: 0.9.32
|
41
61
|
- !ruby/object:Gem::Dependency
|
42
62
|
name: base32-crockford-checksum
|
43
63
|
requirement: !ruby/object:Gem::Requirement
|
@@ -96,22 +116,22 @@ dependencies:
|
|
96
116
|
name: activesupport
|
97
117
|
requirement: !ruby/object:Gem::Requirement
|
98
118
|
requirements:
|
99
|
-
- - "~>"
|
100
|
-
- !ruby/object:Gem::Version
|
101
|
-
version: '4.2'
|
102
119
|
- - ">="
|
103
120
|
- !ruby/object:Gem::Version
|
104
121
|
version: 4.2.5
|
122
|
+
- - "<"
|
123
|
+
- !ruby/object:Gem::Version
|
124
|
+
version: '6'
|
105
125
|
type: :runtime
|
106
126
|
prerelease: false
|
107
127
|
version_requirements: !ruby/object:Gem::Requirement
|
108
128
|
requirements:
|
109
|
-
- - "~>"
|
110
|
-
- !ruby/object:Gem::Version
|
111
|
-
version: '4.2'
|
112
129
|
- - ">="
|
113
130
|
- !ruby/object:Gem::Version
|
114
131
|
version: 4.2.5
|
132
|
+
- - "<"
|
133
|
+
- !ruby/object:Gem::Version
|
134
|
+
version: '6'
|
115
135
|
- !ruby/object:Gem::Dependency
|
116
136
|
name: dotenv
|
117
137
|
requirement: !ruby/object:Gem::Requirement
|
@@ -242,20 +262,20 @@ dependencies:
|
|
242
262
|
requirements:
|
243
263
|
- - "~>"
|
244
264
|
- !ruby/object:Gem::Version
|
245
|
-
version: '
|
265
|
+
version: '3.0'
|
246
266
|
- - ">="
|
247
267
|
- !ruby/object:Gem::Version
|
248
|
-
version:
|
268
|
+
version: 3.0.1
|
249
269
|
type: :development
|
250
270
|
prerelease: false
|
251
271
|
version_requirements: !ruby/object:Gem::Requirement
|
252
272
|
requirements:
|
253
273
|
- - "~>"
|
254
274
|
- !ruby/object:Gem::Version
|
255
|
-
version: '
|
275
|
+
version: '3.0'
|
256
276
|
- - ">="
|
257
277
|
- !ruby/object:Gem::Version
|
258
|
-
version:
|
278
|
+
version: 3.0.1
|
259
279
|
- !ruby/object:Gem::Dependency
|
260
280
|
name: codeclimate-test-reporter
|
261
281
|
requirement: !ruby/object:Gem::Requirement
|
@@ -282,14 +302,14 @@ dependencies:
|
|
282
302
|
requirements:
|
283
303
|
- - "~>"
|
284
304
|
- !ruby/object:Gem::Version
|
285
|
-
version: 0.
|
305
|
+
version: 0.14.1
|
286
306
|
type: :development
|
287
307
|
prerelease: false
|
288
308
|
version_requirements: !ruby/object:Gem::Requirement
|
289
309
|
requirements:
|
290
310
|
- - "~>"
|
291
311
|
- !ruby/object:Gem::Version
|
292
|
-
version: 0.
|
312
|
+
version: 0.14.1
|
293
313
|
description: Ruby client library for the DataCite Metadata Store (MDS) API.
|
294
314
|
email: mfenner@datacite.org
|
295
315
|
executables:
|
@@ -400,31 +420,35 @@ files:
|
|
400
420
|
- spec/fixtures/references.yaml
|
401
421
|
- spec/fixtures/site.yml
|
402
422
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/get/should_get_all_dois_by_prefix.yml
|
423
|
+
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/jats/should_generate_jats_for_all_urls.yml
|
403
424
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_all_urls.yml
|
404
425
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_url.yml
|
405
426
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_metadata_for_work.yml
|
406
427
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_all_urls.yml
|
407
428
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_url.yml
|
408
429
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_all_urls.yml
|
409
|
-
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_url.yml
|
410
430
|
- spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_post_metadata_for_work.yml
|
411
431
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_all_dois.yml
|
412
432
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_doi.yml
|
413
433
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/put/should_put_doi.yml
|
434
|
+
- spec/fixtures/vcr_cassettes/Cirneco_Doi/jats/writes_jats_for_list_of_urls.yml
|
414
435
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_a_doi.yml
|
415
|
-
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/
|
436
|
+
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_dois_for_list_of_urls.yml
|
416
437
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_a_doi.yml
|
417
438
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_dois_for_list_of_urls.yml
|
418
439
|
- spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_dois_for_list_of_urls.yml
|
419
440
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_all_dois.yml
|
420
441
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi.yml
|
421
442
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi_not_found.yml
|
443
|
+
- spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/username_missing.yml
|
422
444
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/put/should_put_doi.yml
|
423
445
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/get/should_get_media.yml
|
424
446
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/post/should_post_media.yml
|
425
447
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/delete/should_delete_metadata.yml
|
426
448
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/get/should_get_metadata.yml
|
427
449
|
- spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/post/should_post_metadata.yml
|
450
|
+
- spec/fixtures/vcr_cassettes/Cirneco_Work/media/includes_media.yml
|
451
|
+
- spec/fixtures/vcr_cassettes/Cirneco_Work/schema/BlogPosting.yml
|
428
452
|
- spec/spec_helper.rb
|
429
453
|
- spec/utils_spec.rb
|
430
454
|
- spec/work_spec.rb
|
@@ -448,7 +472,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
448
472
|
version: '0'
|
449
473
|
requirements: []
|
450
474
|
rubyforge_project:
|
451
|
-
rubygems_version: 2.6.
|
475
|
+
rubygems_version: 2.6.11
|
452
476
|
signing_key:
|
453
477
|
specification_version: 4
|
454
478
|
summary: Ruby client library for the DataCite MDS
|