resync-client 0.4.5 → 0.4.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +0 -4
- data/.ruby-version +1 -1
- data/CHANGES.md +7 -0
- data/Rakefile +4 -4
- data/lib/resync/client/http_helper.rb +3 -3
- data/lib/resync/client/mixins/downloadable.rb +2 -2
- data/lib/resync/client/version.rb +1 -1
- data/lib/resync/client/zip/bitstream.rb +3 -3
- data/lib/resync/client/zip/zip_package.rb +1 -1
- data/resync-client.gemspec +5 -4
- data/spec/.rubocop.yml +13 -0
- data/spec/rspec_custom_matchers.rb +3 -6
- data/spec/unit/resync/client/change_dump_index_spec.rb +2 -1
- data/spec/unit/resync/client/change_dump_spec.rb +9 -3
- data/spec/unit/resync/client/dump_spec.rb +2 -2
- metadata +12 -11
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e80e1bb83812f0b30e430a3acda5190b8dfefda9
|
4
|
+
data.tar.gz: 8711fbe32e6148e47e907a42872b697cb0f2270c
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c22c1d4221cff5e30392ce2cc4cca0f1f9dcdd40d128065ba72a1fbabd0439fa9d64be8f0b4c5b34a3e4c7c5561702a5ac537769271f7c05f4bb0f86218af0d6
|
7
|
+
data.tar.gz: cc49a1e20af322c80b260698464234e6578ec201e9c0728b4ecbd649c5a5d8d43b5653aa2c59405dcd21454a7b04e26e2e16fa69c1971b9954e8011d4399c02e
|
data/.rubocop.yml
CHANGED
@@ -17,7 +17,3 @@ Style/EmptyLinesAroundModuleBody:
|
|
17
17
|
# Allow one line around block body (Style/EmptyLines will still disallow two or more)
|
18
18
|
Style/EmptyLinesAroundBlockBody:
|
19
19
|
Enabled: false
|
20
|
-
|
21
|
-
# Allow %r notation for regexes with a single / character
|
22
|
-
Style/RegexpLiteral:
|
23
|
-
MaxSlashes: 0
|
data/.ruby-version
CHANGED
@@ -1 +1 @@
|
|
1
|
-
2.2.
|
1
|
+
2.2.5
|
data/CHANGES.md
CHANGED
data/Rakefile
CHANGED
@@ -8,18 +8,18 @@ namespace :spec do
|
|
8
8
|
|
9
9
|
desc 'Run all unit tests'
|
10
10
|
RSpec::Core::RakeTask.new(:unit) do |task|
|
11
|
-
task.rspec_opts = %w
|
11
|
+
task.rspec_opts = %w[--color --format documentation --order default]
|
12
12
|
task.pattern = 'unit/**/*_spec.rb'
|
13
13
|
end
|
14
14
|
|
15
15
|
desc 'Run all acceptance tests'
|
16
16
|
RSpec::Core::RakeTask.new(:acceptance) do |task|
|
17
17
|
ENV['COVERAGE'] = nil
|
18
|
-
task.rspec_opts = %w
|
18
|
+
task.rspec_opts = %w[--color --format documentation --order default]
|
19
19
|
task.pattern = 'acceptance/**/*_spec.rb'
|
20
20
|
end
|
21
21
|
|
22
|
-
task all: [
|
22
|
+
task all: %i[unit acceptance]
|
23
23
|
end
|
24
24
|
|
25
25
|
desc 'Run all tests'
|
@@ -45,7 +45,7 @@ RuboCop::RakeTask.new
|
|
45
45
|
|
46
46
|
desc 'List TODOs (from spec/todo.rb)'
|
47
47
|
RSpec::Core::RakeTask.new(:todo) do |task|
|
48
|
-
task.rspec_opts = %w
|
48
|
+
task.rspec_opts = %w[--color --format documentation --order default]
|
49
49
|
task.pattern = 'todo.rb'
|
50
50
|
end
|
51
51
|
|
@@ -74,17 +74,17 @@ module Resync
|
|
74
74
|
private
|
75
75
|
|
76
76
|
def make_request(uri, limit, &block) # rubocop:disable Metrics/MethodLength, Metrics/AbcSize
|
77
|
-
|
77
|
+
raise "Redirect limit (#{redirect_limit}) exceeded retrieving URI #{uri}" if limit <= 0
|
78
78
|
req = Net::HTTP::Get.new(uri, 'User-Agent' => user_agent)
|
79
79
|
Net::HTTP.start(uri.hostname, uri.port, use_ssl: (uri.scheme == 'https')) do |http|
|
80
80
|
http.request(req) do |response|
|
81
81
|
case response
|
82
82
|
when Net::HTTPSuccess
|
83
|
-
|
83
|
+
yield(response)
|
84
84
|
when Net::HTTPInformation, Net::HTTPRedirection
|
85
85
|
make_request(redirect_uri_for(response, uri), limit - 1, &block)
|
86
86
|
else
|
87
|
-
|
87
|
+
raise "Error #{response.code}: #{response.message} retrieving URI #{uri}"
|
88
88
|
end
|
89
89
|
end
|
90
90
|
end
|
@@ -19,14 +19,14 @@ module Resync
|
|
19
19
|
# Delegates to {Client#get} to get the contents of this +:uri+.
|
20
20
|
# The downloaded content will only be downloaded once; subsequent
|
21
21
|
# calls to this method will return the cached content.
|
22
|
-
def get
|
22
|
+
def get
|
23
23
|
@content ||= client.get(uri)
|
24
24
|
end
|
25
25
|
|
26
26
|
# Delegates to {Client#download_to_temp_file} to download the
|
27
27
|
# contents of +:uri+ to a file. Subsequent calls will download
|
28
28
|
# the contents again, each time to a fresh temporary file.
|
29
|
-
def download_to_temp_file
|
29
|
+
def download_to_temp_file
|
30
30
|
client.download_to_temp_file(uri)
|
31
31
|
end
|
32
32
|
|
@@ -63,19 +63,19 @@ module Resync
|
|
63
63
|
private
|
64
64
|
|
65
65
|
def resource=(value)
|
66
|
-
|
66
|
+
raise ArgumentError, 'nil is not a resource' unless value
|
67
67
|
self.metadata = value.metadata
|
68
68
|
@resource = value
|
69
69
|
end
|
70
70
|
|
71
71
|
def metadata=(value)
|
72
|
-
|
72
|
+
raise 'no metadata found' unless value
|
73
73
|
self.path = value.path
|
74
74
|
@metadata = value
|
75
75
|
end
|
76
76
|
|
77
77
|
def path=(value)
|
78
|
-
|
78
|
+
raise 'no path found in metadata' unless value
|
79
79
|
@path = value.start_with?('/') ? value.slice(1..-1) : value
|
80
80
|
end
|
81
81
|
|
@@ -67,7 +67,7 @@ module Resync
|
|
67
67
|
def zipfile=(value)
|
68
68
|
@zipfile = value.is_a?(::Zip::File) ? value : ::Zip::File.open(value)
|
69
69
|
manifest_entry = zipfile.find_entry('manifest.xml')
|
70
|
-
|
70
|
+
raise "No manifest.xml found in zipfile #{zipfile.name}" unless manifest_entry
|
71
71
|
manifest_stream = manifest_entry.get_input_stream
|
72
72
|
self.manifest = XMLParser.parse(manifest_stream)
|
73
73
|
end
|
data/resync-client.gemspec
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
# coding: utf-8
|
2
|
+
|
2
3
|
lib = File.expand_path('../lib', __FILE__)
|
3
4
|
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
5
|
|
@@ -15,7 +16,7 @@ Gem::Specification.new do |spec|
|
|
15
16
|
spec.license = 'MIT'
|
16
17
|
|
17
18
|
origin = `git config --get remote.origin.url`.chomp
|
18
|
-
origin_uri = origin.start_with?('http') ? URI(origin) : URI(origin.
|
19
|
+
origin_uri = origin.start_with?('http') ? URI(origin) : URI(origin.gsub(%r{git@([^:]+)(.com|.org)[^\/]+}, 'http://\1\2'))
|
19
20
|
spec.homepage = URI::HTTP.build(host: origin_uri.host, path: origin_uri.path.chomp('.git')).to_s
|
20
21
|
|
21
22
|
spec.files = `git ls-files -z`.split("\x0")
|
@@ -24,13 +25,13 @@ Gem::Specification.new do |spec|
|
|
24
25
|
spec.require_paths = ['lib']
|
25
26
|
|
26
27
|
spec.add_dependency 'promise', '~> 0.3', '>= 0.3.1'
|
27
|
-
spec.add_dependency 'resync', '~> 0.4', '>= 0.4.
|
28
|
+
spec.add_dependency 'resync', '~> 0.4', '>= 0.4.5'
|
28
29
|
spec.add_dependency 'rubyzip', '~> 1.1'
|
29
30
|
|
30
31
|
spec.add_development_dependency 'equivalent-xml', '~> 0.6.0'
|
31
|
-
spec.add_development_dependency 'rake', '
|
32
|
+
spec.add_development_dependency 'rake', '>= 10.4'
|
32
33
|
spec.add_development_dependency 'rspec', '~> 3.2'
|
33
|
-
spec.add_development_dependency 'rubocop', '~> 0.
|
34
|
+
spec.add_development_dependency 'rubocop', '~> 0.47'
|
34
35
|
spec.add_development_dependency 'simplecov', '~> 0.9.2'
|
35
36
|
spec.add_development_dependency 'simplecov-console', '~> 0.2.0'
|
36
37
|
spec.add_development_dependency 'yard', '~> 0.8'
|
data/spec/.rubocop.yml
ADDED
@@ -17,12 +17,9 @@ RSpec::Matchers.define :be_time do |expected|
|
|
17
17
|
end
|
18
18
|
|
19
19
|
match do |actual|
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
else
|
24
|
-
return actual.nil?
|
25
|
-
end
|
20
|
+
return actual.nil? unless expected
|
21
|
+
raise "Expected value #{expected} is not a Time" unless expected.is_a?(Time)
|
22
|
+
actual.is_a?(Time) && (to_string(expected) == to_string(actual))
|
26
23
|
end
|
27
24
|
|
28
25
|
failure_message do |actual|
|
@@ -18,7 +18,8 @@ module Resync
|
|
18
18
|
<loc>http://example.com/20130103-changedump.xml</loc>
|
19
19
|
<rs:md from='2013-01-03T00:00:00Z' until='2013-01-04T00:00:00Z'/>
|
20
20
|
</sitemap>
|
21
|
-
</sitemapindex>"
|
21
|
+
</sitemapindex>"
|
22
|
+
))
|
22
23
|
|
23
24
|
@change_dumps = [
|
24
25
|
"<urlset xmlns='http://www.sitemaps.org/schemas/sitemap/0.9' xmlns:rs='http://www.openarchives.org/rs/terms/'>
|
@@ -9,19 +9,25 @@ module Resync
|
|
9
9
|
modified_time: Time.utc(2013, 1, 1, 23, 59, 59),
|
10
10
|
metadata: Metadata.new(
|
11
11
|
from_time: Time.utc(2013, 1, 1),
|
12
|
-
until_time: Time.utc(2013, 1, 2)
|
12
|
+
until_time: Time.utc(2013, 1, 2)
|
13
|
+
)
|
14
|
+
),
|
13
15
|
Resource.new(
|
14
16
|
uri: URI('http://example.com/20130102-changedump.zip'),
|
15
17
|
modified_time: Time.utc(2013, 1, 2, 23, 59, 59),
|
16
18
|
metadata: Metadata.new(
|
17
19
|
from_time: Time.utc(2013, 1, 2),
|
18
|
-
until_time: Time.utc(2013, 1, 3)
|
20
|
+
until_time: Time.utc(2013, 1, 3)
|
21
|
+
)
|
22
|
+
),
|
19
23
|
Resource.new(
|
20
24
|
uri: URI('http://example.com/20130103-changedump.zip'),
|
21
25
|
modified_time: Time.utc(2013, 1, 3, 23, 59, 59),
|
22
26
|
metadata: Metadata.new(
|
23
27
|
from_time: Time.utc(2013, 1, 3),
|
24
|
-
until_time: Time.utc(2013, 1, 4)
|
28
|
+
until_time: Time.utc(2013, 1, 4)
|
29
|
+
)
|
30
|
+
)
|
25
31
|
]
|
26
32
|
@dump = ChangeDump.new(resources: @resources)
|
27
33
|
|
@@ -55,7 +55,7 @@ module Resync
|
|
55
55
|
expect(lazy_flat_mapped).to eq(all_packages)
|
56
56
|
end
|
57
57
|
|
58
|
-
it 'supports lazy iteration 'do
|
58
|
+
it 'supports lazy iteration ' do
|
59
59
|
manifests = Array.new(3) { instance_double(ChangeDumpManifest) }
|
60
60
|
all_packages = Array.new(3) do |index|
|
61
61
|
zip_package = instance_double(Client::Zip::ZipPackage)
|
@@ -159,7 +159,7 @@ module Resync
|
|
159
159
|
expect(flat_mapped).to eq(all_packages)
|
160
160
|
end
|
161
161
|
|
162
|
-
it 'supports lazy iteration 'do
|
162
|
+
it 'supports lazy iteration ' do
|
163
163
|
manifests = Array.new(3) { instance_double(ChangeDumpManifest) }
|
164
164
|
all_packages = Array.new(3) do |index|
|
165
165
|
zip_package = instance_double(Client::Zip::ZipPackage)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: resync-client
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.4.
|
4
|
+
version: 0.4.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- David Moles
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2017-04-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: promise
|
@@ -39,7 +39,7 @@ dependencies:
|
|
39
39
|
version: '0.4'
|
40
40
|
- - ">="
|
41
41
|
- !ruby/object:Gem::Version
|
42
|
-
version: 0.4.
|
42
|
+
version: 0.4.5
|
43
43
|
type: :runtime
|
44
44
|
prerelease: false
|
45
45
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -49,7 +49,7 @@ dependencies:
|
|
49
49
|
version: '0.4'
|
50
50
|
- - ">="
|
51
51
|
- !ruby/object:Gem::Version
|
52
|
-
version: 0.4.
|
52
|
+
version: 0.4.5
|
53
53
|
- !ruby/object:Gem::Dependency
|
54
54
|
name: rubyzip
|
55
55
|
requirement: !ruby/object:Gem::Requirement
|
@@ -82,14 +82,14 @@ dependencies:
|
|
82
82
|
name: rake
|
83
83
|
requirement: !ruby/object:Gem::Requirement
|
84
84
|
requirements:
|
85
|
-
- - "
|
85
|
+
- - ">="
|
86
86
|
- !ruby/object:Gem::Version
|
87
87
|
version: '10.4'
|
88
88
|
type: :development
|
89
89
|
prerelease: false
|
90
90
|
version_requirements: !ruby/object:Gem::Requirement
|
91
91
|
requirements:
|
92
|
-
- - "
|
92
|
+
- - ">="
|
93
93
|
- !ruby/object:Gem::Version
|
94
94
|
version: '10.4'
|
95
95
|
- !ruby/object:Gem::Dependency
|
@@ -112,14 +112,14 @@ dependencies:
|
|
112
112
|
requirements:
|
113
113
|
- - "~>"
|
114
114
|
- !ruby/object:Gem::Version
|
115
|
-
version: 0.
|
115
|
+
version: '0.47'
|
116
116
|
type: :development
|
117
117
|
prerelease: false
|
118
118
|
version_requirements: !ruby/object:Gem::Requirement
|
119
119
|
requirements:
|
120
120
|
- - "~>"
|
121
121
|
- !ruby/object:Gem::Version
|
122
|
-
version: 0.
|
122
|
+
version: '0.47'
|
123
123
|
- !ruby/object:Gem::Dependency
|
124
124
|
name: simplecov
|
125
125
|
requirement: !ruby/object:Gem::Requirement
|
@@ -200,6 +200,7 @@ files:
|
|
200
200
|
- lib/resync/client/zip/bitstream.rb
|
201
201
|
- lib/resync/client/zip/zip_package.rb
|
202
202
|
- resync-client.gemspec
|
203
|
+
- spec/.rubocop.yml
|
203
204
|
- spec/acceptance/example_spec.rb
|
204
205
|
- spec/data/examples/capability-list.xml
|
205
206
|
- spec/data/examples/change-dump-manifest.xml
|
@@ -241,7 +242,7 @@ files:
|
|
241
242
|
- spec/unit/resync/client/list_index_spec.rb
|
242
243
|
- spec/unit/resync/client/mixins_spec.rb
|
243
244
|
- spec/unit/resync/client/zip_package_spec.rb
|
244
|
-
homepage: http://github.com/
|
245
|
+
homepage: http://github.com/resync-client
|
245
246
|
licenses:
|
246
247
|
- MIT
|
247
248
|
metadata: {}
|
@@ -261,11 +262,12 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
261
262
|
version: '0'
|
262
263
|
requirements: []
|
263
264
|
rubyforge_project:
|
264
|
-
rubygems_version: 2.
|
265
|
+
rubygems_version: 2.6.8
|
265
266
|
signing_key:
|
266
267
|
specification_version: 4
|
267
268
|
summary: Client library for ResourceSync
|
268
269
|
test_files:
|
270
|
+
- spec/.rubocop.yml
|
269
271
|
- spec/acceptance/example_spec.rb
|
270
272
|
- spec/data/examples/capability-list.xml
|
271
273
|
- spec/data/examples/change-dump-manifest.xml
|
@@ -307,4 +309,3 @@ test_files:
|
|
307
309
|
- spec/unit/resync/client/list_index_spec.rb
|
308
310
|
- spec/unit/resync/client/mixins_spec.rb
|
309
311
|
- spec/unit/resync/client/zip_package_spec.rb
|
310
|
-
has_rdoc:
|