cirneco 0.9.12 → 0.9.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +124 -49
  3. data/cirneco.gemspec +5 -4
  4. data/lib/cirneco/api.rb +8 -8
  5. data/lib/cirneco/base.rb +2 -2
  6. data/lib/cirneco/cli.rb +1 -1
  7. data/lib/cirneco/utils.rb +48 -95
  8. data/lib/cirneco/version.rb +1 -1
  9. data/lib/cirneco/work.rb +8 -203
  10. data/spec/api_spec.rb +16 -28
  11. data/spec/doi_spec.rb +9 -11
  12. data/spec/fixtures/cool-dois-minted/index.html +189 -234
  13. data/spec/fixtures/cool-dois-minted.html.md +1 -1
  14. data/spec/fixtures/cool-dois.html.md +2 -2
  15. data/spec/fixtures/index-minted.html +1 -1
  16. data/spec/fixtures/index.html +50 -1
  17. data/spec/fixtures/index.html.erb +2 -2
  18. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/get/should_get_all_dois_by_prefix.yml +20 -18
  19. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/jats/should_generate_jats_for_all_urls.yml +38 -0
  20. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_all_urls.yml +20 -20
  21. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_for_url.yml +19 -17
  22. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_hide_metadata_for_work.yml +19 -17
  23. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_all_urls.yml +204 -108
  24. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_and_hide_for_url.yml +72 -64
  25. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_all_urls.yml +17 -291
  26. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_post_metadata_for_work.yml +47 -82
  27. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_all_dois.yml +22 -18
  28. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/get/should_get_doi.yml +19 -17
  29. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/MDS_DOI_API/put/should_put_doi.yml +20 -18
  30. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/jats/writes_jats_for_list_of_urls.yml +38 -0
  31. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_a_doi.yml +19 -17
  32. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/hides_dois_for_list_of_urls.yml +81 -0
  33. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_a_doi.yml +72 -64
  34. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_and_hides_dois_for_list_of_urls.yml +204 -108
  35. data/spec/fixtures/vcr_cassettes/Cirneco_Doi/mint_and_hide_DOIs/mints_dois_for_list_of_urls.yml +17 -291
  36. data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_all_dois.yml +140 -18
  37. data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi.yml +137 -17
  38. data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/should_get_doi_not_found.yml +134 -16
  39. data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/get/username_missing.yml +121 -0
  40. data/spec/fixtures/vcr_cassettes/Cirneco_Work/DOI_API/put/should_put_doi.yml +138 -18
  41. data/spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/get/should_get_media.yml +135 -17
  42. data/spec/fixtures/vcr_cassettes/Cirneco_Work/Media_API/post/should_post_media.yml +137 -17
  43. data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/delete/should_delete_metadata.yml +137 -17
  44. data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/get/should_get_metadata.yml +170 -27
  45. data/spec/fixtures/vcr_cassettes/Cirneco_Work/Metadata_API/post/should_post_metadata.yml +173 -28
  46. data/spec/fixtures/vcr_cassettes/Cirneco_Work/media/includes_media.yml +121 -0
  47. data/spec/fixtures/vcr_cassettes/Cirneco_Work/schema/BlogPosting.yml +121 -0
  48. data/spec/spec_helper.rb +1 -1
  49. data/spec/utils_spec.rb +28 -41
  50. data/spec/work_spec.rb +33 -43
  51. metadata +43 -19
  52. data/spec/fixtures/vcr_cassettes/Cirneco_DataCenter/mint_and_hide_DOIs/should_mint_for_url.yml +0 -174
  53. 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(76)
24
- expect(dois.first).to eq("10.5072/0000-00SS")
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.5072/0000-03WD"
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.5072/0000-03VC")
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.5072/0000-03VC")
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.5072")
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.5072/0000-03VC minted for cool-dois.html.md")
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.5072/0000-03WD hidden for cool-dois-minted.html.md")
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.5072/0000-03VC minted and hidden for cool-dois.html.md")
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.5072/0000-03VC minted for cool-dois.html.md\nDOI 10.5072/0000-00SS minted for index.html.erb")
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.5072/0000-NW90: Not found\n")
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.5072/0000-03VC minted and hidden for cool-dois.html.md\nDOI 10.5072/0000-00SS minted and hidden for index.html.erb")
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 generate metadata for work' do
156
+ it 'should get_json_ld_from_work' do
157
157
  filepath = fixture_path + 'cool-dois/index.html'
158
- metadata = subject.generate_metadata_for_work(filepath)
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["creators"]).to eq([{:given_name=>"Martin", :family_name=>"Fenner", :orcid=>"0000-0003-1419-2405"}])
161
- expect(metadata["descriptions"]).to eq([{:value=>"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...",:description_type=>"Abstract"}])
162
- expect(metadata["related_identifiers"]).to eq([{:value=>"https://www.w3.org/Provider/Style/URI",
163
- :related_identifier_type=>"URL",
164
- :relation_type=>"References"},
165
- { :value=>"10.1371/JOURNAL.PONE.0115253",
166
- :related_identifier_type=>"DOI",
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
- metadata = subject.generate_metadata_for_work(filepath)
186
- response = subject.post_metadata_for_work(metadata, options)
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(200)
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
- metadata = subject.generate_metadata_for_work(filepath)
194
- response = subject.hide_metadata_for_work(metadata, options)
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(:doi) { "10.5072/0000-03VC" }
5
- let(:url) { "http://www.datacite.org" }
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(metadata) }
11
+ subject { Cirneco::Work.new(input: input, from: "schema_org", media: media) }
32
12
 
33
13
  describe 'schema' do
34
- it 'validates example full' do
35
- validation_errors = subject.schema.validate(samples_path + 'datacite-example-full-v4.0.xml').map { |error| error.to_s }
36
- expect(validation_errors).to be_empty
37
- end
38
-
39
- it 'exists' do
40
- expect(subject.schema.errors).to be_empty
41
- end
42
-
43
- it 'validates data' do
44
- expect(subject.validation_errors.body["errors"]).to be_empty
45
- end
46
-
47
- it 'validates work without resource_type_general with errors' do
48
- subject.resource_type[:resource_type_general] = nil
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 work without title with errors' do
53
- subject.title = nil
54
- expect(subject.validation_errors.body["errors"]).to eq([{"title"=>"Element '{http://datacite.org/schema/kernel-4}title': [facet 'minLength'] The value has a length of '0'; this underruns the allowed minimum length of '1'."},
55
- {"title"=>"Element '{http://datacite.org/schema/kernel-4}title': '' is not a valid value of the atomic type '{http://datacite.org/schema/kernel-4}nonemptycontentStringType'."}])
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.12
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-02-06 00:00:00.000000000 Z
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.1.2
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.1.2
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: '1.22'
265
+ version: '3.0'
246
266
  - - ">="
247
267
  - !ruby/object:Gem::Version
248
- version: 1.22.3
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: '1.22'
275
+ version: '3.0'
256
276
  - - ">="
257
277
  - !ruby/object:Gem::Version
258
- version: 1.22.3
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.12.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.12.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/mints_a_doi.yml
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.8
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