onfido 0.15.1 → 2.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/gem-push.yml +31 -0
- data/.github/workflows/ruby.yml +25 -0
- data/.rubocop.yml +5 -49
- data/.travis.yml +3 -10
- data/CHANGELOG.md +28 -0
- data/Gemfile +2 -0
- data/LICENSE +2 -1
- data/README.md +46 -172
- data/lib/onfido.rb +4 -4
- data/lib/onfido/api.rb +21 -15
- data/lib/onfido/errors/connection_error.rb +2 -0
- data/lib/onfido/errors/onfido_error.rb +2 -0
- data/lib/onfido/errors/request_error.rb +2 -0
- data/lib/onfido/errors/server_error.rb +2 -0
- data/lib/onfido/options.rb +38 -0
- data/lib/onfido/resource.rb +44 -61
- data/lib/onfido/resources/address.rb +3 -2
- data/lib/onfido/resources/applicant.rb +8 -6
- data/lib/onfido/resources/check.rb +15 -19
- data/lib/onfido/resources/document.rb +13 -11
- data/lib/onfido/resources/extraction.rb +11 -0
- data/lib/onfido/resources/live_photo.rb +11 -14
- data/lib/onfido/resources/live_video.rb +7 -8
- data/lib/onfido/resources/report.rb +10 -9
- data/lib/onfido/resources/sdk_token.rb +5 -5
- data/lib/onfido/resources/webhook.rb +15 -11
- data/lib/onfido/version.rb +3 -1
- data/onfido.gemspec +10 -12
- data/spec/integrations/address_spec.rb +5 -2
- data/spec/integrations/applicant_spec.rb +29 -42
- data/spec/integrations/check_spec.rb +28 -69
- data/spec/integrations/document_spec.rb +22 -19
- data/spec/integrations/extraction_spec.rb +23 -0
- data/spec/integrations/live_photo_spec.rb +18 -15
- data/spec/integrations/live_video_spec.rb +13 -11
- data/spec/integrations/report_spec.rb +16 -13
- data/spec/integrations/resource_spec.rb +93 -0
- data/spec/integrations/sdk_token_spec.rb +10 -6
- data/spec/integrations/webhook_spec.rb +56 -37
- data/spec/onfido/api_spec.rb +14 -25
- data/spec/onfido/connection_error_spec.rb +4 -2
- data/spec/onfido/options_spec.rb +39 -0
- data/spec/onfido/request_error_spec.rb +4 -2
- data/spec/spec_helper.rb +3 -5
- data/spec/support/fake_onfido_api.rb +77 -88
- data/spec/support/fixtures/applicant.json +21 -42
- data/spec/support/fixtures/check.json +4 -4
- data/spec/support/fixtures/checks.json +4 -4
- data/spec/support/fixtures/document.json +2 -2
- data/spec/support/fixtures/documents.json +8 -8
- data/spec/support/fixtures/extraction.json +23 -0
- data/spec/support/fixtures/live_photo.json +3 -3
- data/spec/support/fixtures/live_photos.json +6 -6
- data/spec/support/fixtures/live_video.json +3 -3
- data/spec/support/fixtures/live_videos.json +4 -4
- data/spec/support/fixtures/report.json +4 -4
- data/spec/support/fixtures/reports.json +8 -8
- data/spec/support/fixtures/webhook.json +6 -5
- data/spec/support/fixtures/webhooks.json +17 -12
- metadata +27 -65
- data/Rakefile +0 -1
- data/lib/onfido/configuration.rb +0 -47
- data/lib/onfido/null_logger.rb +0 -5
- data/lib/onfido/resources/report_type_group.rb +0 -11
- data/spec/integrations/exceptions_spec.rb +0 -74
- data/spec/integrations/report_type_group_spec.rb +0 -19
- data/spec/onfido/resource_spec.rb +0 -137
- data/spec/onfido_spec.rb +0 -84
- data/spec/support/fixtures/check_with_expanded_reports.json +0 -30
- data/spec/support/fixtures/checks_with_expanded_reports.json +0 -34
- data/spec/support/fixtures/report_type_group.json +0 -25
- data/spec/support/fixtures/report_type_groups.json +0 -30
@@ -1,30 +1,27 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Onfido
|
2
4
|
class LivePhoto < Resource
|
3
5
|
# with open-uri the file can be a link or an actual file
|
4
6
|
|
5
|
-
def create(applicant_id
|
6
|
-
validate_file!(
|
7
|
+
def create(applicant_id:, file:, **payload)
|
8
|
+
validate_file!(file)
|
7
9
|
payload[:applicant_id] = applicant_id
|
10
|
+
payload[:file] = file
|
8
11
|
|
9
|
-
post(
|
10
|
-
url: url_for("/live_photos"),
|
11
|
-
payload: payload
|
12
|
-
)
|
12
|
+
post(path: 'live_photos', payload: payload)
|
13
13
|
end
|
14
14
|
|
15
|
-
def find(
|
16
|
-
|
17
|
-
get(url: url_for("live_photos/#{live_photo_id}?#{query_string}"))
|
15
|
+
def find(live_photo_id)
|
16
|
+
get(path: "live_photos/#{live_photo_id}")
|
18
17
|
end
|
19
18
|
|
20
|
-
def download(
|
21
|
-
|
22
|
-
get(url: url_for("live_photos/#{live_photo_id}/download?#{query_string}"))
|
19
|
+
def download(live_photo_id)
|
20
|
+
get(path: "live_photos/#{live_photo_id}/download")
|
23
21
|
end
|
24
22
|
|
25
23
|
def all(applicant_id)
|
26
|
-
|
27
|
-
get(url: url_for("live_photos?#{query_string}"))
|
24
|
+
get(path: "live_photos?applicant_id=#{applicant_id}")
|
28
25
|
end
|
29
26
|
end
|
30
27
|
end
|
@@ -1,18 +1,17 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Onfido
|
2
4
|
class LiveVideo < Resource
|
3
|
-
def find(
|
4
|
-
|
5
|
-
get(url: url_for("live_videos/#{live_video_id}?#{query_string}"))
|
5
|
+
def find(live_video_id)
|
6
|
+
get(path: "live_videos/#{live_video_id}")
|
6
7
|
end
|
7
8
|
|
8
|
-
def download(
|
9
|
-
|
10
|
-
get(url: url_for("live_videos/#{live_video_id}/download?#{query_string}"))
|
9
|
+
def download(live_video_id)
|
10
|
+
get(path: "live_videos/#{live_video_id}/download")
|
11
11
|
end
|
12
12
|
|
13
13
|
def all(applicant_id)
|
14
|
-
|
15
|
-
get(url: url_for("live_videos?#{query_string}"))
|
14
|
+
get(path: "live_videos?applicant_id=#{applicant_id}")
|
16
15
|
end
|
17
16
|
end
|
18
17
|
end
|
@@ -1,20 +1,21 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Onfido
|
2
4
|
class Report < Resource
|
3
|
-
def find(
|
4
|
-
get(
|
5
|
+
def find(report_id)
|
6
|
+
get(path: "reports/#{report_id}")
|
5
7
|
end
|
6
8
|
|
7
|
-
def all(check_id
|
8
|
-
|
9
|
-
get(url: url_for("checks/#{check_id}/reports?#{querystring}"))
|
9
|
+
def all(check_id)
|
10
|
+
get(path: "reports?check_id=#{check_id}")
|
10
11
|
end
|
11
12
|
|
12
|
-
def resume(
|
13
|
-
post(
|
13
|
+
def resume(report_id)
|
14
|
+
post(path: "reports/#{report_id}/resume")
|
14
15
|
end
|
15
16
|
|
16
|
-
def cancel(
|
17
|
-
post(
|
17
|
+
def cancel(report_id)
|
18
|
+
post(path: "reports/#{report_id}/cancel")
|
18
19
|
end
|
19
20
|
end
|
20
21
|
end
|
@@ -1,10 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Onfido
|
2
4
|
class SdkToken < Resource
|
3
|
-
def create(payload)
|
4
|
-
|
5
|
-
|
6
|
-
payload: payload
|
7
|
-
)
|
5
|
+
def create(applicant_id:, **payload)
|
6
|
+
payload[:applicant_id] = applicant_id
|
7
|
+
post(path: 'sdk_token', payload: payload)
|
8
8
|
end
|
9
9
|
end
|
10
10
|
end
|
@@ -1,18 +1,22 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Onfido
|
2
4
|
class Webhook < Resource
|
3
|
-
def create(payload)
|
4
|
-
|
5
|
-
|
6
|
-
payload: payload
|
7
|
-
)
|
5
|
+
def create(url:, **payload)
|
6
|
+
payload[:url] = url
|
7
|
+
post(path: 'webhooks', payload: payload)
|
8
8
|
end
|
9
9
|
|
10
10
|
def find(webhooks_id)
|
11
|
-
get(
|
11
|
+
get(path: "webhooks/#{webhooks_id}")
|
12
|
+
end
|
13
|
+
|
14
|
+
def all
|
15
|
+
get(path: 'webhooks')
|
12
16
|
end
|
13
17
|
|
14
|
-
def
|
15
|
-
|
18
|
+
def destroy(webhook_id)
|
19
|
+
delete(path: "webhooks/#{webhook_id}")
|
16
20
|
end
|
17
21
|
|
18
22
|
# As well as being a normal resource, Onfido::Webhook also supports
|
@@ -20,8 +24,8 @@ module Onfido
|
|
20
24
|
# request to one computed from the body
|
21
25
|
def self.valid?(request_body, request_signature, token)
|
22
26
|
if [request_body, request_signature, token].any?(&:nil?)
|
23
|
-
raise ArgumentError,
|
24
|
-
|
27
|
+
raise ArgumentError, 'A request body, request signature and token ' \
|
28
|
+
'must be provided'
|
25
29
|
end
|
26
30
|
|
27
31
|
computed_signature = generate_signature(request_body, token)
|
@@ -29,7 +33,7 @@ module Onfido
|
|
29
33
|
end
|
30
34
|
|
31
35
|
def self.generate_signature(request_body, token)
|
32
|
-
OpenSSL::HMAC.hexdigest(OpenSSL::Digest.new('
|
36
|
+
OpenSSL::HMAC.hexdigest(OpenSSL::Digest.new('sha256'), token, request_body)
|
33
37
|
end
|
34
38
|
private_class_method :generate_signature
|
35
39
|
end
|
data/lib/onfido/version.rb
CHANGED
data/onfido.gemspec
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
#
|
1
|
+
# frozen_string_literal: true
|
2
2
|
|
3
3
|
lib = File.expand_path('lib', __dir__)
|
4
4
|
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
@@ -7,27 +7,25 @@ require 'onfido/version'
|
|
7
7
|
Gem::Specification.new do |spec|
|
8
8
|
spec.name = 'onfido'
|
9
9
|
spec.version = Onfido::VERSION
|
10
|
-
spec.authors = ['
|
11
|
-
spec.email = ['
|
10
|
+
spec.authors = ['Onfido']
|
11
|
+
spec.email = ['engineering@onfido.com']
|
12
12
|
spec.summary = 'A wrapper for Onfido API'
|
13
|
-
spec.description = "A thin wrapper for Onfido's API. This gem supports "\
|
14
|
-
"
|
15
|
-
|
16
|
-
|
17
|
-
spec.homepage = 'http://github.com/
|
13
|
+
spec.description = "A thin wrapper for Onfido's API. This gem only supports "\
|
14
|
+
"v3 of the Onfido API. Refer to Onfido's "\
|
15
|
+
'API documentation for details of the expected '\
|
16
|
+
'requests and responses.'
|
17
|
+
spec.homepage = 'http://github.com/onfido/onfido-ruby'
|
18
18
|
spec.license = 'MIT'
|
19
19
|
|
20
20
|
spec.files = `git ls-files -z`.split("\x0")
|
21
21
|
spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
|
22
22
|
spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
|
23
23
|
spec.require_paths = ['lib']
|
24
|
-
spec.required_ruby_version =
|
24
|
+
spec.required_ruby_version = '>= 2.4.0'
|
25
25
|
|
26
|
-
spec.add_development_dependency 'bundler', '~> 2.0'
|
27
|
-
spec.add_development_dependency 'rake', '~> 12.0'
|
28
26
|
spec.add_development_dependency 'rspec', '~> 3.1'
|
29
27
|
spec.add_development_dependency 'rspec-its', '~> 1.2'
|
30
|
-
spec.add_development_dependency 'rubocop', '~>
|
28
|
+
spec.add_development_dependency 'rubocop', '~> 1.11'
|
31
29
|
spec.add_development_dependency 'sinatra', '~> 1.4'
|
32
30
|
spec.add_development_dependency 'webmock', '~> 3.0'
|
33
31
|
|
@@ -1,9 +1,12 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
describe Onfido::Address do
|
2
|
-
|
4
|
+
include_context 'fake onfido api'
|
3
5
|
|
4
6
|
describe '#all' do
|
5
7
|
it 'returns the addresses matching the postcode' do
|
6
|
-
response =
|
8
|
+
response = onfido.address.all('SW1 4NG')
|
9
|
+
|
7
10
|
expect(response['addresses'].count).to eq(2)
|
8
11
|
end
|
9
12
|
end
|
@@ -1,38 +1,29 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
describe Onfido::Applicant do
|
2
|
-
|
4
|
+
include_context 'fake onfido api'
|
5
|
+
|
6
|
+
subject(:applicant) { onfido.applicant }
|
7
|
+
|
8
|
+
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
3
9
|
let(:params) do
|
4
10
|
{
|
5
11
|
'title' => 'Mr',
|
6
12
|
'first_name' => 'Chandler',
|
7
13
|
'last_name' => 'Bing',
|
8
|
-
'gender' => 'male',
|
9
14
|
'middle_name' => 'Muriel',
|
10
15
|
'dob' => '1968-04-08',
|
11
|
-
'telephone' => '555555555',
|
12
|
-
'mobile' => '77777777',
|
13
16
|
'email' => 'chandler_bing_6@friends.com',
|
14
|
-
'
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
},
|
25
|
-
{
|
26
|
-
'flat_number' => '1',
|
27
|
-
'building_number' => '10',
|
28
|
-
'building_name' => 'Great Building',
|
29
|
-
'street' => 'Old Street',
|
30
|
-
'sub_street' => 'Sub Street',
|
31
|
-
'town' => 'London',
|
32
|
-
'postcode' => 'SW1 4NG',
|
33
|
-
'country' => 'GBR'
|
34
|
-
}
|
35
|
-
]
|
17
|
+
'address' => {
|
18
|
+
'flat_number' => '4',
|
19
|
+
'building_number' => '100',
|
20
|
+
'building_name' => 'Awesome Building',
|
21
|
+
'street' => 'Main Street',
|
22
|
+
'sub_street' => 'A sub street',
|
23
|
+
'town' => 'London',
|
24
|
+
'postcode' => 'SW4 6EH',
|
25
|
+
'country' => 'GBR'
|
26
|
+
}
|
36
27
|
}
|
37
28
|
end
|
38
29
|
|
@@ -43,9 +34,9 @@ describe Onfido::Applicant do
|
|
43
34
|
|
44
35
|
it 'serializes the payload correctly' do
|
45
36
|
WebMock.after_request do |request_signature, _response|
|
46
|
-
if request_signature.uri.path == '
|
47
|
-
expect(Rack::Utils.parse_nested_query(request_signature.body))
|
48
|
-
to eq(params)
|
37
|
+
if request_signature.uri.path == 'v3.1/applicants'
|
38
|
+
expect(Rack::Utils.parse_nested_query(request_signature.body))
|
39
|
+
.to eq(params)
|
49
40
|
end
|
50
41
|
end
|
51
42
|
end
|
@@ -57,26 +48,22 @@ describe Onfido::Applicant do
|
|
57
48
|
end
|
58
49
|
|
59
50
|
describe '#update' do
|
60
|
-
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
61
|
-
|
62
51
|
it 'updates an applicant' do
|
63
52
|
response = applicant.update(applicant_id, params)
|
53
|
+
|
64
54
|
expect(response['id']).to eq(applicant_id)
|
65
55
|
end
|
66
56
|
end
|
67
57
|
|
68
58
|
describe '#find' do
|
69
|
-
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
70
|
-
|
71
59
|
it 'returns the applicant' do
|
72
60
|
response = applicant.find(applicant_id)
|
61
|
+
|
73
62
|
expect(response['id']).to eq(applicant_id)
|
74
63
|
end
|
75
64
|
end
|
76
65
|
|
77
66
|
describe '#destroy' do
|
78
|
-
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
79
|
-
|
80
67
|
it 'returns success code' do
|
81
68
|
expect { applicant.destroy(applicant_id) }.not_to raise_error
|
82
69
|
end
|
@@ -86,6 +73,7 @@ describe Onfido::Applicant do
|
|
86
73
|
context 'with the default page and per page params' do
|
87
74
|
it 'returns all the applicants' do
|
88
75
|
response = applicant.all
|
76
|
+
|
89
77
|
expect(response['applicants'].size).to eq(2)
|
90
78
|
end
|
91
79
|
end
|
@@ -93,6 +81,7 @@ describe Onfido::Applicant do
|
|
93
81
|
context 'with specific range of results for a page' do
|
94
82
|
it 'returns the specified applicants' do
|
95
83
|
response = applicant.all(page: 1, per_page: 1)
|
84
|
+
|
96
85
|
expect(response['applicants'].size).to eq(1)
|
97
86
|
end
|
98
87
|
end
|
@@ -100,24 +89,22 @@ describe Onfido::Applicant do
|
|
100
89
|
|
101
90
|
describe '#restore' do
|
102
91
|
context 'an applicant scheduled for deletion' do
|
103
|
-
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
104
|
-
|
105
92
|
it 'returns nil' do
|
106
93
|
expect(applicant.restore(applicant_id)).to be_nil
|
107
94
|
end
|
108
95
|
end
|
109
96
|
|
110
97
|
context 'an applicant not scheduled for deletion' do
|
111
|
-
let(:applicant_id) { 'a2fb9c62-ab10-4898-a8ec-342c4b552ad5' }
|
112
|
-
|
113
98
|
it 'returns an error' do
|
114
|
-
|
99
|
+
applicant_id = 'a2fb9c62-ab10-4898-a8ec-342c4b552ad5'
|
100
|
+
|
101
|
+
expect { applicant.restore(applicant_id) }.to raise_error do |error|
|
115
102
|
expect(error).to be_a(Onfido::RequestError)
|
116
103
|
expect(error.message).to eq('There was a validation error on this request')
|
117
104
|
expect(error.fields).to eq(
|
118
|
-
|
105
|
+
'Applicant a2fb9c62-ab10-4898-a8ec-342c4b552ad5 is not scheduled for deletion'
|
119
106
|
)
|
120
|
-
|
107
|
+
end
|
121
108
|
end
|
122
109
|
end
|
123
110
|
end
|
@@ -1,105 +1,64 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
describe Onfido::Check do
|
2
|
-
|
4
|
+
include_context 'fake onfido api'
|
5
|
+
|
6
|
+
subject(:check) { onfido.check }
|
7
|
+
|
3
8
|
let(:applicant_id) { '61f659cb-c90b-4067-808a-6136b5c01351' }
|
9
|
+
let(:check_id) { '8546921-123123-123123' }
|
4
10
|
|
5
11
|
describe '#create' do
|
6
|
-
let(:params) { { type: 'express', reports: [{ name: 'identity' }] } }
|
7
|
-
|
8
12
|
it 'creates a new check for an applicant' do
|
9
|
-
response = check.create(
|
13
|
+
response = check.create(
|
14
|
+
applicant_id: applicant_id,
|
15
|
+
report_names: ['identity_enhanced']
|
16
|
+
)
|
10
17
|
expect(response['id']).not_to be_nil
|
11
18
|
end
|
12
19
|
end
|
13
20
|
|
14
21
|
describe '#find' do
|
15
|
-
let(:check_id) { '8546921-123123-123123' }
|
16
|
-
|
17
22
|
it 'returns an existing check for the applicant' do
|
18
|
-
response = check.find(
|
19
|
-
expect(response['id']).to eq(check_id)
|
20
|
-
end
|
21
|
-
|
22
|
-
it "returns unexpanded reports" do
|
23
|
-
response = check.find(applicant_id, check_id)
|
24
|
-
expect(response['reports'].first).to be_a(String)
|
25
|
-
end
|
26
|
-
|
27
|
-
it 'allows you to expand the reports' do
|
28
|
-
response = check.find(applicant_id, check_id, expand: "reports")
|
29
|
-
expect(response['reports'].first).to be_a(Hash)
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
describe '#find_by_url' do
|
34
|
-
let(:check_id) { '8546921-123123-123123' }
|
35
|
-
|
36
|
-
context 'partial url' do
|
37
|
-
let(:url) { "applicants/#{applicant_id}/checks/#{check_id}" }
|
38
|
-
|
39
|
-
it 'returns an existing check for the applicant with the partial url' do
|
40
|
-
response = check.find_by_url(url)
|
41
|
-
expect(response['id']).to eq(check_id)
|
42
|
-
end
|
43
|
-
|
44
|
-
it "returns unexpanded reports" do
|
45
|
-
response = check.find_by_url(url)
|
46
|
-
expect(response['reports'].first).to be_a(String)
|
47
|
-
end
|
23
|
+
response = check.find(check_id)
|
48
24
|
|
49
|
-
|
50
|
-
response = check.find_by_url(url, expand: "reports")
|
51
|
-
expect(response['reports'].first).to be_a(Hash)
|
52
|
-
end
|
25
|
+
expect(response['id']).to eq(check_id)
|
53
26
|
end
|
54
27
|
|
55
|
-
|
56
|
-
|
57
|
-
"https://api.onfido.com/v2/applicants/#{applicant_id}/checks/#{check_id}"
|
58
|
-
end
|
28
|
+
it 'returns report_ids' do
|
29
|
+
response = check.find(check_id)
|
59
30
|
|
60
|
-
|
61
|
-
response = check.find_by_url(url)
|
62
|
-
expect(response['id']).to eq(check_id)
|
63
|
-
end
|
64
|
-
|
65
|
-
it "returns unexpanded reports" do
|
66
|
-
response = check.find_by_url(url)
|
67
|
-
expect(response['reports'].first).to be_a(String)
|
68
|
-
end
|
69
|
-
|
70
|
-
it 'allows you to expand the reports' do
|
71
|
-
response = check.find_by_url(url, expand: "reports")
|
72
|
-
expect(response['reports'].first).to be_a(Hash)
|
73
|
-
end
|
31
|
+
expect(response['report_ids'].first).to be_a(String)
|
74
32
|
end
|
75
33
|
end
|
76
34
|
|
77
35
|
describe '#all' do
|
78
|
-
let(:check_id) { '8546921-123123-123123' }
|
79
|
-
|
80
36
|
context 'with the default page and per page params' do
|
81
37
|
it 'returns all existing checks for the applicant' do
|
82
38
|
response = check.all(applicant_id)
|
39
|
+
|
83
40
|
expect(response['checks'].size).to eq(1)
|
84
41
|
end
|
85
42
|
end
|
86
43
|
|
87
|
-
it
|
44
|
+
it 'returns report_ids' do
|
88
45
|
response = check.all(applicant_id)
|
89
|
-
expect(response['checks'].first['reports'].first).to be_a(String)
|
90
|
-
end
|
91
46
|
|
92
|
-
|
93
|
-
response = check.all(applicant_id, expand: "reports")
|
94
|
-
expect(response['checks'].first['reports'].first).to be_a(Hash)
|
47
|
+
expect(response['checks'].first['report_ids'].first).to be_a(String)
|
95
48
|
end
|
96
49
|
end
|
97
50
|
|
98
|
-
describe
|
99
|
-
let(:check_id) { '8546921-123123-123123' }
|
100
|
-
|
51
|
+
describe '#resume' do
|
101
52
|
it 'returns success response' do
|
102
53
|
expect { check.resume(check_id) }.not_to raise_error
|
103
54
|
end
|
104
55
|
end
|
56
|
+
|
57
|
+
describe '#download' do
|
58
|
+
it 'returns the file data' do
|
59
|
+
response = check.download(check_id)
|
60
|
+
|
61
|
+
expect(response).not_to be_nil
|
62
|
+
end
|
63
|
+
end
|
105
64
|
end
|