pandexio 0.0.7 → 0.0.8
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.
- data/lib/http_client.rb +308 -0
- data/lib/request.rb +3 -0
- data/lib/scope_patterns.rb +1 -0
- data/test/test_header_signing.rb +1 -1
- data/test/test_http_client.rb +1238 -0
- data/test/test_query_string_signing.rb +1 -1
- data/test/test_request.rb +98 -0
- data/test/test_scope.rb +1 -1
- data/test/test_scope_patterns.rb +1 -1
- data/test/test_signer.rb +1 -1
- metadata +22 -3
data/lib/http_client.rb
ADDED
@@ -0,0 +1,308 @@
|
|
1
|
+
require 'net/http'
|
2
|
+
require 'json'
|
3
|
+
require 'stringio'
|
4
|
+
require 'open-uri'
|
5
|
+
require_relative 'request.rb'
|
6
|
+
require_relative 'scope_patterns.rb'
|
7
|
+
require_relative 'signer.rb'
|
8
|
+
require_relative 'signing_mechanisms.rb'
|
9
|
+
|
10
|
+
module Pandexio
|
11
|
+
|
12
|
+
HOSTED_HOST = "hosted.pandexio.com"
|
13
|
+
PLATFORM_HOST = "platform.pandexio.com"
|
14
|
+
|
15
|
+
class DocumentSource
|
16
|
+
|
17
|
+
def initialize(params = {})
|
18
|
+
@id = params.fetch(:id, nil)
|
19
|
+
@name = params.fetch(:name, nil)
|
20
|
+
@content = params.fetch(:content, nil)
|
21
|
+
@location = params.fetch(:location, nil)
|
22
|
+
end
|
23
|
+
|
24
|
+
attr_accessor :id
|
25
|
+
attr_accessor :name
|
26
|
+
attr_accessor :content
|
27
|
+
attr_accessor :location
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
class Document
|
32
|
+
|
33
|
+
def initialize(params = {})
|
34
|
+
@document_id = params.fetch(:document_id, nil)
|
35
|
+
@name = params.fetch(:name, nil)
|
36
|
+
@page_count = params.fetch(:page_count, nil)
|
37
|
+
@content_type = params.fetch(:content_type, nil)
|
38
|
+
@content_length = params.fetch(:content_length, nil)
|
39
|
+
@cover = params.fetch(:cover, nil)
|
40
|
+
end
|
41
|
+
|
42
|
+
attr_accessor :document_id
|
43
|
+
attr_accessor :name
|
44
|
+
attr_accessor :page_count
|
45
|
+
attr_accessor :content_type
|
46
|
+
attr_accessor :content_length
|
47
|
+
attr_accessor :cover
|
48
|
+
|
49
|
+
end
|
50
|
+
|
51
|
+
class HttpClient
|
52
|
+
|
53
|
+
private
|
54
|
+
|
55
|
+
def build_headers(headers, content_type)
|
56
|
+
|
57
|
+
items = {'Content-Type' => content_type}
|
58
|
+
|
59
|
+
headers.each do |key, value|
|
60
|
+
items[key] = value.to_s
|
61
|
+
end
|
62
|
+
|
63
|
+
return items
|
64
|
+
end
|
65
|
+
|
66
|
+
def build_query_string(query_parameters)
|
67
|
+
|
68
|
+
query_string_builder = StringIO.new
|
69
|
+
|
70
|
+
query_parameters.each do |key, value|
|
71
|
+
query_string_builder << "&" if query_string_builder.length > 0
|
72
|
+
encodedKey = URI::encode(key.to_s)
|
73
|
+
encodedValue = URI::encode(value.to_s)
|
74
|
+
query_string_builder << "#{encodedKey}=#{encodedValue}"
|
75
|
+
end
|
76
|
+
|
77
|
+
return query_string_builder.string
|
78
|
+
end
|
79
|
+
|
80
|
+
public
|
81
|
+
|
82
|
+
def load_document(source_document, signing_options)
|
83
|
+
|
84
|
+
raise ArgumentError, "Document source is nil." if source_document.nil?
|
85
|
+
raise ArgumentError, "Signing options is nil." if signing_options.nil?
|
86
|
+
|
87
|
+
id = source_document.id.to_s
|
88
|
+
name = source_document.name.to_s
|
89
|
+
content = source_document.content.to_s
|
90
|
+
location = source_document.location.to_s
|
91
|
+
|
92
|
+
raise ArgumentError, "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}." if !source_document.id.is_a?(String) || id.nil? || id.empty? || !id.strip!.nil? || id.match(Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN).nil?
|
93
|
+
raise ArgumentError, "Document name is not a string or is nil or empty." if !source_document.name.is_a?(String) || name.nil? || name.empty? || !name.strip!.nil?
|
94
|
+
raise ArgumentError, "Document content is not a string or is nil or empty." if !source_document.content.is_a?(String) || content.nil? || content.empty? || !content.strip!.nil?
|
95
|
+
raise ArgumentError, "Document location must be AWS, Azure, Internet, or Inline." unless location == "AWS" || location == "Azure" || location == "Internet" || location == "Inline"
|
96
|
+
|
97
|
+
path = "/api/documents/#{id}"
|
98
|
+
payload = {
|
99
|
+
"name" => name,
|
100
|
+
"content" => content,
|
101
|
+
"location" => location
|
102
|
+
}.to_json
|
103
|
+
|
104
|
+
normalized_request = Pandexio::Request.new(
|
105
|
+
:method => "PUT",
|
106
|
+
:path => path,
|
107
|
+
:query_parameters => { },
|
108
|
+
:headers => { "Host" => HOSTED_HOST },
|
109
|
+
:payload => payload)
|
110
|
+
|
111
|
+
signer = Pandexio::Signer.new()
|
112
|
+
|
113
|
+
authorized_request = signer.sign(normalized_request, signing_options)
|
114
|
+
|
115
|
+
headers = build_headers(authorized_request.headers, 'application/json; charset=utf-8')
|
116
|
+
query_string = build_query_string(authorized_request.query_parameters)
|
117
|
+
|
118
|
+
http = Net::HTTP.new(HOSTED_HOST, 443)
|
119
|
+
http.use_ssl = true
|
120
|
+
http.open_timeout = 60
|
121
|
+
http.read_timeout = 600
|
122
|
+
|
123
|
+
req = Net::HTTP::Put.new("#{path}?#{query_string}", initheader = headers)
|
124
|
+
req.body = payload
|
125
|
+
res = http.start {|http| http.request(req)}
|
126
|
+
|
127
|
+
case res.code
|
128
|
+
when "202"
|
129
|
+
data = JSON.parse(res.body)
|
130
|
+
document = Pandexio::Document.new(
|
131
|
+
:document_id => data['documentId'],
|
132
|
+
:name => data['name'],
|
133
|
+
:page_count => data['pageCount'],
|
134
|
+
:content_type => data['contentType'],
|
135
|
+
:content_length => data['contentLength'],
|
136
|
+
:cover => data['cover'])
|
137
|
+
else
|
138
|
+
raise StandardError, "Failed to load document."
|
139
|
+
end
|
140
|
+
|
141
|
+
end
|
142
|
+
|
143
|
+
def get_document(document_id, cover_size, signing_options)
|
144
|
+
|
145
|
+
raise ArgumentError, "Signing options is nil." if signing_options.nil?
|
146
|
+
|
147
|
+
id = document_id.to_s
|
148
|
+
|
149
|
+
raise ArgumentError, "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}." if !document_id.is_a?(String) || id.nil? || id.empty? || !id.strip!.nil? || id.match(Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN).nil?
|
150
|
+
raise ArgumentError, "Document cover size must be xs, s, m, l, or xl." unless cover_size == 'xs' || cover_size == 's' || cover_size == 'm' || cover_size == 'l' || cover_size == 'xl'
|
151
|
+
|
152
|
+
path = "/v2/documents/#{id}"
|
153
|
+
|
154
|
+
normalized_request = Pandexio::Request.new(
|
155
|
+
:method => "GET",
|
156
|
+
:path => path,
|
157
|
+
:query_parameters => { "coverSize" => cover_size },
|
158
|
+
:headers => { "Host" => PLATFORM_HOST },
|
159
|
+
:payload => '')
|
160
|
+
|
161
|
+
signer = Pandexio::Signer.new()
|
162
|
+
|
163
|
+
authorized_request = signer.sign(normalized_request, signing_options)
|
164
|
+
|
165
|
+
headers = build_headers(authorized_request.headers, 'application/json; charset=utf-8')
|
166
|
+
query_string = build_query_string(authorized_request.query_parameters)
|
167
|
+
|
168
|
+
http = Net::HTTP.new(PLATFORM_HOST, 443)
|
169
|
+
http.use_ssl = true
|
170
|
+
http.open_timeout = 60
|
171
|
+
http.read_timeout = 120
|
172
|
+
|
173
|
+
req = Net::HTTP::Get.new("#{path}?#{query_string}", initheader = headers)
|
174
|
+
res = http.start {|http| http.request(req)}
|
175
|
+
|
176
|
+
case res.code
|
177
|
+
when "200"
|
178
|
+
data = JSON.parse(res.body)
|
179
|
+
document = Pandexio::Document.new(
|
180
|
+
:document_id => data['documentId'],
|
181
|
+
:name => data['name'],
|
182
|
+
:page_count => data['pageCount'],
|
183
|
+
:content_type => data['contentType'],
|
184
|
+
:content_length => data['contentLength'],
|
185
|
+
:cover => data['cover'])
|
186
|
+
when "404"
|
187
|
+
return nil
|
188
|
+
else
|
189
|
+
raise StandardError, "Failed to get document."
|
190
|
+
end
|
191
|
+
|
192
|
+
end
|
193
|
+
|
194
|
+
def get_document_cover(document_id, cover_size, signing_options)
|
195
|
+
|
196
|
+
raise ArgumentError, "Signing options is nil." if signing_options.nil?
|
197
|
+
|
198
|
+
id = document_id.to_s
|
199
|
+
|
200
|
+
raise ArgumentError, "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}." if !document_id.is_a?(String) || id.nil? || id.empty? || !id.strip!.nil? || id.match(Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN).nil?
|
201
|
+
raise ArgumentError, "Document cover size must be xs, s, m, l, or xl." unless cover_size == 'xs' || cover_size == 's' || cover_size == 'm' || cover_size == 'l' || cover_size == 'xl'
|
202
|
+
|
203
|
+
path = "/v2/documents/#{id}/cover"
|
204
|
+
|
205
|
+
normalized_request = Pandexio::Request.new(
|
206
|
+
:method => "GET",
|
207
|
+
:path => path,
|
208
|
+
:query_parameters => { "coverSize" => cover_size },
|
209
|
+
:headers => { "Host" => PLATFORM_HOST },
|
210
|
+
:payload => '')
|
211
|
+
|
212
|
+
signer = Pandexio::Signer.new()
|
213
|
+
|
214
|
+
authorized_request = signer.sign(normalized_request, signing_options)
|
215
|
+
|
216
|
+
headers = build_headers(authorized_request.headers, 'image/png')
|
217
|
+
query_string = build_query_string(authorized_request.query_parameters)
|
218
|
+
|
219
|
+
http = Net::HTTP.new(PLATFORM_HOST, 443)
|
220
|
+
http.use_ssl = true
|
221
|
+
http.open_timeout = 60
|
222
|
+
http.read_timeout = 120
|
223
|
+
|
224
|
+
req = Net::HTTP::Get.new("#{path}?#{query_string}", initheader = headers)
|
225
|
+
res = http.start {|http| http.request(req)}
|
226
|
+
|
227
|
+
case res.code
|
228
|
+
when "200"
|
229
|
+
return res.body
|
230
|
+
when "404"
|
231
|
+
return nil
|
232
|
+
else
|
233
|
+
raise StandardError, "Failed to get document cover."
|
234
|
+
end
|
235
|
+
|
236
|
+
end
|
237
|
+
|
238
|
+
def get_document_cover_url(document_id, cover_size, signing_options)
|
239
|
+
|
240
|
+
id = document_id.to_s
|
241
|
+
|
242
|
+
raise ArgumentError, "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}." if !document_id.is_a?(String) || id.nil? || id.empty? || !id.strip!.nil? || id.match(Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN).nil?
|
243
|
+
raise ArgumentError, "Document cover size must be xs, s, m, l, or xl." unless cover_size == 'xs' || cover_size == 's' || cover_size == 'm' || cover_size == 'l' || cover_size == 'xl'
|
244
|
+
|
245
|
+
raise ArgumentError, "Signing options is nil." if signing_options.nil?
|
246
|
+
raise ArgumentError, "Signing mechanism must be QueryString." unless signing_options.mechanism == Pandexio::SigningMechanisms::QUERY_STRING
|
247
|
+
|
248
|
+
path = "/v2/documents/#{id}/cover"
|
249
|
+
|
250
|
+
normalized_request = Pandexio::Request.new(
|
251
|
+
:method => "GET",
|
252
|
+
:path => path,
|
253
|
+
:query_parameters => { "coverSize" => cover_size },
|
254
|
+
:headers => { "Host" => PLATFORM_HOST },
|
255
|
+
:payload => '')
|
256
|
+
|
257
|
+
signer = Pandexio::Signer.new()
|
258
|
+
|
259
|
+
authorized_request = signer.sign(normalized_request, signing_options)
|
260
|
+
|
261
|
+
query_string = build_query_string(authorized_request.query_parameters)
|
262
|
+
|
263
|
+
return "https://#{PLATFORM_HOST}#{path}?#{query_string}"
|
264
|
+
|
265
|
+
end
|
266
|
+
|
267
|
+
def get_document_snip_count(document_id, signing_options)
|
268
|
+
|
269
|
+
raise ArgumentError, "Signing options is nil." if signing_options.nil?
|
270
|
+
|
271
|
+
id = document_id.to_s
|
272
|
+
|
273
|
+
raise ArgumentError, "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}." if !document_id.is_a?(String) || id.nil? || id.empty? || !id.strip!.nil? || id.match(Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN).nil?
|
274
|
+
|
275
|
+
path = "/v2/documents/#{id}/snips/count"
|
276
|
+
|
277
|
+
normalized_request = Pandexio::Request.new(
|
278
|
+
:method => "GET",
|
279
|
+
:path => path,
|
280
|
+
:query_parameters => {},
|
281
|
+
:headers => { "Host" => PLATFORM_HOST },
|
282
|
+
:payload => '')
|
283
|
+
|
284
|
+
signer = Pandexio::Signer.new()
|
285
|
+
|
286
|
+
authorized_request = signer.sign(normalized_request, signing_options)
|
287
|
+
|
288
|
+
headers = build_headers(authorized_request.headers, 'application/json; charset=utf-8')
|
289
|
+
query_string = build_query_string(authorized_request.query_parameters)
|
290
|
+
|
291
|
+
http = Net::HTTP.new(PLATFORM_HOST, 443)
|
292
|
+
http.use_ssl = true
|
293
|
+
|
294
|
+
req = Net::HTTP::Get.new("#{path}?#{query_string}", initheader = headers)
|
295
|
+
res = http.start {|http| http.request(req)}
|
296
|
+
|
297
|
+
case res.code
|
298
|
+
when "200"
|
299
|
+
return res.body.to_i
|
300
|
+
else
|
301
|
+
raise StandardError, "Failed to get document snip count."
|
302
|
+
end
|
303
|
+
|
304
|
+
end
|
305
|
+
|
306
|
+
end
|
307
|
+
|
308
|
+
end
|
data/lib/request.rb
CHANGED
data/lib/scope_patterns.rb
CHANGED
data/test/test_header_signing.rb
CHANGED
@@ -0,0 +1,1238 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
|
3
|
+
require 'time'
|
4
|
+
require 'uuid'
|
5
|
+
require 'minitest/autorun'
|
6
|
+
#require 'pandexio'
|
7
|
+
require_relative 'test_config.rb'
|
8
|
+
require_relative '../lib/http_client.rb'
|
9
|
+
require_relative '../lib/scope_patterns.rb'
|
10
|
+
require_relative '../lib/signing_options.rb'
|
11
|
+
require_relative '../lib/signing_algorithms.rb'
|
12
|
+
require_relative '../lib/signing_mechanisms.rb'
|
13
|
+
|
14
|
+
describe Pandexio::HttpClient do
|
15
|
+
|
16
|
+
describe "#load_document" do
|
17
|
+
|
18
|
+
describe "when id is nil" do
|
19
|
+
|
20
|
+
before do
|
21
|
+
document_source = Pandexio::DocumentSource.new(:id => nil, :name => "test_name", :content => "test_content", :location => "Inline")
|
22
|
+
signing_options = Pandexio::SigningOptions.new()
|
23
|
+
http_client = Pandexio::HttpClient.new()
|
24
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
25
|
+
end
|
26
|
+
|
27
|
+
it "should raise ArgumentError" do
|
28
|
+
err = @load_document.must_raise ArgumentError
|
29
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
|
34
|
+
describe "when id is empty" do
|
35
|
+
|
36
|
+
before do
|
37
|
+
document_source = Pandexio::DocumentSource.new(:id => "", :name => "test_name", :content => "test_content", :location => "Inline")
|
38
|
+
signing_options = Pandexio::SigningOptions.new()
|
39
|
+
http_client = Pandexio::HttpClient.new()
|
40
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
41
|
+
end
|
42
|
+
|
43
|
+
it "should raise ArgumentError" do
|
44
|
+
err = @load_document.must_raise ArgumentError
|
45
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
46
|
+
end
|
47
|
+
|
48
|
+
end
|
49
|
+
|
50
|
+
describe "when id is blank" do
|
51
|
+
|
52
|
+
before do
|
53
|
+
document_source = Pandexio::DocumentSource.new(:id => " ", :name => "test_name", :content => "test_content", :location => "Inline")
|
54
|
+
signing_options = Pandexio::SigningOptions.new()
|
55
|
+
http_client = Pandexio::HttpClient.new()
|
56
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
57
|
+
end
|
58
|
+
|
59
|
+
it "should raise ArgumentError" do
|
60
|
+
err = @load_document.must_raise ArgumentError
|
61
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
62
|
+
end
|
63
|
+
|
64
|
+
end
|
65
|
+
|
66
|
+
describe "when id is not a string" do
|
67
|
+
|
68
|
+
before do
|
69
|
+
document_source = Pandexio::DocumentSource.new(:id => 123, :name => "test_name", :content => "test_content", :location => "Inline")
|
70
|
+
signing_options = Pandexio::SigningOptions.new()
|
71
|
+
http_client = Pandexio::HttpClient.new()
|
72
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
73
|
+
end
|
74
|
+
|
75
|
+
it "should raise ArgumentError" do
|
76
|
+
err = @load_document.must_raise ArgumentError
|
77
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
78
|
+
end
|
79
|
+
|
80
|
+
end
|
81
|
+
|
82
|
+
describe "when id does not match RegEx" do
|
83
|
+
|
84
|
+
before do
|
85
|
+
document_source = Pandexio::DocumentSource.new(:id => "123^%$*abc", :name => "test_name", :content => "test_content", :location => "Inline")
|
86
|
+
signing_options = Pandexio::SigningOptions.new()
|
87
|
+
http_client = Pandexio::HttpClient.new()
|
88
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
89
|
+
end
|
90
|
+
|
91
|
+
it "should raise ArgumentError" do
|
92
|
+
err = @load_document.must_raise ArgumentError
|
93
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
94
|
+
end
|
95
|
+
|
96
|
+
end
|
97
|
+
|
98
|
+
describe "when name is nil" do
|
99
|
+
|
100
|
+
before do
|
101
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => nil, :content => "test_content", :location => "Inline")
|
102
|
+
signing_options = Pandexio::SigningOptions.new()
|
103
|
+
http_client = Pandexio::HttpClient.new()
|
104
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
105
|
+
end
|
106
|
+
|
107
|
+
it "should raise ArgumentError" do
|
108
|
+
err = @load_document.must_raise ArgumentError
|
109
|
+
err.message.must_match "Document name is not a string or is nil or empty."
|
110
|
+
end
|
111
|
+
|
112
|
+
end
|
113
|
+
|
114
|
+
describe "when name is empty" do
|
115
|
+
|
116
|
+
before do
|
117
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "", :content => "test_content", :location => "Inline")
|
118
|
+
signing_options = Pandexio::SigningOptions.new()
|
119
|
+
http_client = Pandexio::HttpClient.new()
|
120
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
121
|
+
end
|
122
|
+
|
123
|
+
it "should raise ArgumentError" do
|
124
|
+
err = @load_document.must_raise ArgumentError
|
125
|
+
err.message.must_match "Document name is not a string or is nil or empty."
|
126
|
+
end
|
127
|
+
|
128
|
+
end
|
129
|
+
|
130
|
+
describe "when name is blank" do
|
131
|
+
|
132
|
+
before do
|
133
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => " ", :content => "test_content", :location => "Inline")
|
134
|
+
signing_options = Pandexio::SigningOptions.new()
|
135
|
+
http_client = Pandexio::HttpClient.new()
|
136
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
137
|
+
end
|
138
|
+
|
139
|
+
it "should raise ArgumentError" do
|
140
|
+
err = @load_document.must_raise ArgumentError
|
141
|
+
err.message.must_match "Document name is not a string or is nil or empty."
|
142
|
+
end
|
143
|
+
|
144
|
+
end
|
145
|
+
|
146
|
+
describe "when name is not a string" do
|
147
|
+
|
148
|
+
before do
|
149
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => 123, :content => "test_content", :location => "Inline")
|
150
|
+
signing_options = Pandexio::SigningOptions.new()
|
151
|
+
http_client = Pandexio::HttpClient.new()
|
152
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
153
|
+
end
|
154
|
+
|
155
|
+
it "should raise ArgumentError" do
|
156
|
+
err = @load_document.must_raise ArgumentError
|
157
|
+
err.message.must_match "Document name is not a string or is nil or empty."
|
158
|
+
end
|
159
|
+
|
160
|
+
end
|
161
|
+
|
162
|
+
describe "when content is nil" do
|
163
|
+
|
164
|
+
before do
|
165
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "test_name", :content => nil, :location => "Inline")
|
166
|
+
signing_options = Pandexio::SigningOptions.new()
|
167
|
+
http_client = Pandexio::HttpClient.new()
|
168
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
169
|
+
end
|
170
|
+
|
171
|
+
it "should raise ArgumentError" do
|
172
|
+
err = @load_document.must_raise ArgumentError
|
173
|
+
err.message.must_match "Document content is not a string or is nil or empty."
|
174
|
+
end
|
175
|
+
|
176
|
+
end
|
177
|
+
|
178
|
+
describe "when content is empty" do
|
179
|
+
|
180
|
+
before do
|
181
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "test_name", :content => "", :location => "Inline")
|
182
|
+
signing_options = Pandexio::SigningOptions.new()
|
183
|
+
http_client = Pandexio::HttpClient.new()
|
184
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
185
|
+
end
|
186
|
+
|
187
|
+
it "should raise ArgumentError" do
|
188
|
+
err = @load_document.must_raise ArgumentError
|
189
|
+
err.message.must_match "Document content is not a string or is nil or empty."
|
190
|
+
end
|
191
|
+
|
192
|
+
end
|
193
|
+
|
194
|
+
describe "when content is blank" do
|
195
|
+
|
196
|
+
before do
|
197
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "test_name", :content => " ", :location => "Inline")
|
198
|
+
signing_options = Pandexio::SigningOptions.new()
|
199
|
+
http_client = Pandexio::HttpClient.new()
|
200
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
201
|
+
end
|
202
|
+
|
203
|
+
it "should raise ArgumentError" do
|
204
|
+
err = @load_document.must_raise ArgumentError
|
205
|
+
err.message.must_match "Document content is not a string or is nil or empty."
|
206
|
+
end
|
207
|
+
|
208
|
+
end
|
209
|
+
|
210
|
+
describe "when content is not a string" do
|
211
|
+
|
212
|
+
before do
|
213
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "test_name", :content => 123, :location => "Inline")
|
214
|
+
signing_options = Pandexio::SigningOptions.new()
|
215
|
+
http_client = Pandexio::HttpClient.new()
|
216
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
217
|
+
end
|
218
|
+
|
219
|
+
it "should raise ArgumentError" do
|
220
|
+
err = @load_document.must_raise ArgumentError
|
221
|
+
err.message.must_match "Document content is not a string or is nil or empty."
|
222
|
+
end
|
223
|
+
|
224
|
+
end
|
225
|
+
|
226
|
+
describe "when location is not AWS" do
|
227
|
+
|
228
|
+
before do
|
229
|
+
document_source = Pandexio::DocumentSource.new(:id => "test_id", :name => "test_name", :content => "test_content", :location => "AUUS")
|
230
|
+
signing_options = Pandexio::SigningOptions.new()
|
231
|
+
http_client = Pandexio::HttpClient.new()
|
232
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
233
|
+
end
|
234
|
+
|
235
|
+
it "should raise ArgumentError" do
|
236
|
+
err = @load_document.must_raise ArgumentError
|
237
|
+
err.message.must_match "Document location must be AWS, Azure, Internet, or Inline."
|
238
|
+
end
|
239
|
+
|
240
|
+
end
|
241
|
+
|
242
|
+
describe "when content is data URL" do
|
243
|
+
|
244
|
+
before do
|
245
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
246
|
+
@id = UUID.new.generate
|
247
|
+
document_source = Pandexio::DocumentSource.new(
|
248
|
+
:id => @id,
|
249
|
+
:name => "test_name_#{@id}.txt",
|
250
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
251
|
+
:location => "Inline")
|
252
|
+
signing_options = Pandexio::SigningOptions.new(
|
253
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
254
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
255
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
256
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
257
|
+
:date => Time.now.utc,
|
258
|
+
:expires => 90,
|
259
|
+
:originator => "HttpClientTest",
|
260
|
+
:email_address => "HttpClientTest",
|
261
|
+
:display_name => "HttpClientTest")
|
262
|
+
http_client = Pandexio::HttpClient.new()
|
263
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
264
|
+
end
|
265
|
+
|
266
|
+
it "should return document details" do
|
267
|
+
doc = @load_document.call
|
268
|
+
doc.document_id.must_equal @id
|
269
|
+
doc.name.must_equal "test_name_#{@id}.txt"
|
270
|
+
doc.page_count.must_equal 1
|
271
|
+
doc.content_type.must_equal "text/plain"
|
272
|
+
doc.content_length.must_equal 11
|
273
|
+
doc.cover[0..29].must_equal ''
|
274
|
+
doc.cover.length.must_equal 24846
|
275
|
+
end
|
276
|
+
|
277
|
+
end
|
278
|
+
|
279
|
+
describe "when content is HTTP URL" do
|
280
|
+
|
281
|
+
before do
|
282
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
283
|
+
@id = UUID.new.generate
|
284
|
+
document_source = Pandexio::DocumentSource.new(
|
285
|
+
:id => @id,
|
286
|
+
:name => "test_name_#{@id}.pdf",
|
287
|
+
:content => "http://martinfowler.com/ieeeSoftware/whenType.pdf",
|
288
|
+
:location => "Internet")
|
289
|
+
signing_options = Pandexio::SigningOptions.new(
|
290
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
291
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
292
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
293
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
294
|
+
:date => Time.now.utc,
|
295
|
+
:expires => 90,
|
296
|
+
:originator => "HttpClientTest",
|
297
|
+
:email_address => "HttpClientTest",
|
298
|
+
:display_name => "HttpClientTest")
|
299
|
+
http_client = Pandexio::HttpClient.new()
|
300
|
+
@load_document = ->{ http_client.load_document(document_source, signing_options) }
|
301
|
+
end
|
302
|
+
|
303
|
+
it "should return document details" do
|
304
|
+
doc = @load_document.call
|
305
|
+
doc.document_id.must_equal @id
|
306
|
+
doc.name.must_equal "test_name_#{@id}.pdf"
|
307
|
+
doc.page_count.must_equal 2
|
308
|
+
doc.content_type.must_equal "application/pdf"
|
309
|
+
doc.content_length.must_equal 289041
|
310
|
+
doc.cover[0..29].must_equal ''
|
311
|
+
doc.cover.length.must_equal 436650
|
312
|
+
end
|
313
|
+
|
314
|
+
end
|
315
|
+
|
316
|
+
end
|
317
|
+
|
318
|
+
describe "#get_document" do
|
319
|
+
|
320
|
+
describe "when id is nil" do
|
321
|
+
|
322
|
+
before do
|
323
|
+
signing_options = Pandexio::SigningOptions.new()
|
324
|
+
http_client = Pandexio::HttpClient.new()
|
325
|
+
@get_document = ->{ http_client.get_document(nil, 'm', signing_options) }
|
326
|
+
end
|
327
|
+
|
328
|
+
it "should raise ArgumentError" do
|
329
|
+
err = @get_document.must_raise ArgumentError
|
330
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
331
|
+
end
|
332
|
+
|
333
|
+
end
|
334
|
+
|
335
|
+
describe "when id is empty" do
|
336
|
+
|
337
|
+
before do
|
338
|
+
signing_options = Pandexio::SigningOptions.new()
|
339
|
+
http_client = Pandexio::HttpClient.new()
|
340
|
+
@get_document = ->{ http_client.get_document("", 'm', signing_options) }
|
341
|
+
end
|
342
|
+
|
343
|
+
it "should raise ArgumentError" do
|
344
|
+
err = @get_document.must_raise ArgumentError
|
345
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
346
|
+
end
|
347
|
+
|
348
|
+
end
|
349
|
+
|
350
|
+
describe "when id is blank" do
|
351
|
+
|
352
|
+
before do
|
353
|
+
signing_options = Pandexio::SigningOptions.new()
|
354
|
+
http_client = Pandexio::HttpClient.new()
|
355
|
+
@get_document = ->{ http_client.get_document(" ", 'm', signing_options) }
|
356
|
+
end
|
357
|
+
|
358
|
+
it "should raise ArgumentError" do
|
359
|
+
err = @get_document.must_raise ArgumentError
|
360
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
361
|
+
end
|
362
|
+
|
363
|
+
end
|
364
|
+
|
365
|
+
describe "when id is not a string" do
|
366
|
+
|
367
|
+
before do
|
368
|
+
signing_options = Pandexio::SigningOptions.new()
|
369
|
+
http_client = Pandexio::HttpClient.new()
|
370
|
+
@get_document = ->{ http_client.get_document(123, 'm', signing_options) }
|
371
|
+
end
|
372
|
+
|
373
|
+
it "should raise ArgumentError" do
|
374
|
+
err = @get_document.must_raise ArgumentError
|
375
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
376
|
+
end
|
377
|
+
|
378
|
+
end
|
379
|
+
|
380
|
+
describe "when id does not match RegEx" do
|
381
|
+
|
382
|
+
before do
|
383
|
+
signing_options = Pandexio::SigningOptions.new()
|
384
|
+
http_client = Pandexio::HttpClient.new()
|
385
|
+
@get_document = ->{ http_client.get_document("123^%$*abc", 'm', signing_options) }
|
386
|
+
end
|
387
|
+
|
388
|
+
it "should raise ArgumentError" do
|
389
|
+
err = @get_document.must_raise ArgumentError
|
390
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
391
|
+
end
|
392
|
+
|
393
|
+
end
|
394
|
+
|
395
|
+
describe "when cover_size is invalid" do
|
396
|
+
|
397
|
+
before do
|
398
|
+
signing_options = Pandexio::SigningOptions.new()
|
399
|
+
http_client = Pandexio::HttpClient.new()
|
400
|
+
@get_document = ->{ http_client.get_document('test_id', 'abc', signing_options) }
|
401
|
+
end
|
402
|
+
|
403
|
+
it "should raise ArgumentError" do
|
404
|
+
err = @get_document.must_raise ArgumentError
|
405
|
+
err.message.must_match "Document cover size must be xs, s, m, l, or xl."
|
406
|
+
end
|
407
|
+
|
408
|
+
end
|
409
|
+
|
410
|
+
describe "when document does not exist" do
|
411
|
+
|
412
|
+
before do
|
413
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
414
|
+
id = UUID.new.generate
|
415
|
+
signing_options = Pandexio::SigningOptions.new(
|
416
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
417
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
418
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
419
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
420
|
+
:date => Time.now.utc,
|
421
|
+
:expires => 90,
|
422
|
+
:originator => "HttpClientTest",
|
423
|
+
:email_address => "HttpClientTest",
|
424
|
+
:display_name => "HttpClientTest")
|
425
|
+
http_client = Pandexio::HttpClient.new()
|
426
|
+
@get_document = ->{ http_client.get_document(id, 'm', signing_options) }
|
427
|
+
end
|
428
|
+
|
429
|
+
it "should return nil" do
|
430
|
+
doc = @get_document.call
|
431
|
+
doc.must_be_nil
|
432
|
+
end
|
433
|
+
|
434
|
+
end
|
435
|
+
|
436
|
+
describe "when document exists" do
|
437
|
+
|
438
|
+
before do
|
439
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
440
|
+
@id = UUID.new.generate
|
441
|
+
document_source = Pandexio::DocumentSource.new(
|
442
|
+
:id => @id,
|
443
|
+
:name => "test_name_#{@id}.txt",
|
444
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
445
|
+
:location => "Inline")
|
446
|
+
signing_options = Pandexio::SigningOptions.new(
|
447
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
448
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
449
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
450
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
451
|
+
:date => Time.now.utc,
|
452
|
+
:expires => 90,
|
453
|
+
:originator => "HttpClientTest",
|
454
|
+
:email_address => "HttpClientTest",
|
455
|
+
:display_name => "HttpClientTest")
|
456
|
+
http_client = Pandexio::HttpClient.new()
|
457
|
+
http_client.load_document(document_source, signing_options)
|
458
|
+
sleep(3)
|
459
|
+
@get_document = ->{ http_client.get_document(@id, 'm', signing_options) }
|
460
|
+
end
|
461
|
+
|
462
|
+
it "should return document details" do
|
463
|
+
doc = @get_document.call
|
464
|
+
doc.document_id.must_equal @id
|
465
|
+
doc.name.must_equal "test_name_#{@id}.txt"
|
466
|
+
doc.page_count.must_equal 1
|
467
|
+
doc.content_type.must_equal "text/plain"
|
468
|
+
doc.content_length.must_equal 11
|
469
|
+
doc.cover[0..29].must_equal ''
|
470
|
+
doc.cover.length.must_equal 2542
|
471
|
+
end
|
472
|
+
|
473
|
+
end
|
474
|
+
|
475
|
+
describe "when cover size is xs" do
|
476
|
+
|
477
|
+
before do
|
478
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
479
|
+
@id = UUID.new.generate
|
480
|
+
document_source = Pandexio::DocumentSource.new(
|
481
|
+
:id => @id,
|
482
|
+
:name => "test_name_#{@id}.txt",
|
483
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
484
|
+
:location => "Inline")
|
485
|
+
signing_options = Pandexio::SigningOptions.new(
|
486
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
487
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
488
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
489
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
490
|
+
:date => Time.now.utc,
|
491
|
+
:expires => 90,
|
492
|
+
:originator => "HttpClientTest",
|
493
|
+
:email_address => "HttpClientTest",
|
494
|
+
:display_name => "HttpClientTest")
|
495
|
+
http_client = Pandexio::HttpClient.new()
|
496
|
+
http_client.load_document(document_source, signing_options)
|
497
|
+
sleep(3)
|
498
|
+
@get_document = ->{ http_client.get_document(@id, 'xs', signing_options) }
|
499
|
+
end
|
500
|
+
|
501
|
+
it "should return document details" do
|
502
|
+
doc = @get_document.call
|
503
|
+
doc.document_id.must_equal @id
|
504
|
+
doc.name.must_equal "test_name_#{@id}.txt"
|
505
|
+
doc.page_count.must_equal 1
|
506
|
+
doc.content_type.must_equal "text/plain"
|
507
|
+
doc.content_length.must_equal 11
|
508
|
+
doc.cover[0..29].must_equal ''
|
509
|
+
doc.cover.length.must_equal 370
|
510
|
+
end
|
511
|
+
|
512
|
+
end
|
513
|
+
|
514
|
+
end
|
515
|
+
|
516
|
+
describe "#get_document_cover" do
|
517
|
+
|
518
|
+
describe "when id is nil" do
|
519
|
+
|
520
|
+
before do
|
521
|
+
signing_options = Pandexio::SigningOptions.new()
|
522
|
+
http_client = Pandexio::HttpClient.new()
|
523
|
+
@get_document_cover = ->{ http_client.get_document_cover(nil, 'm', signing_options) }
|
524
|
+
end
|
525
|
+
|
526
|
+
it "should raise ArgumentError" do
|
527
|
+
err = @get_document_cover.must_raise ArgumentError
|
528
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
529
|
+
end
|
530
|
+
|
531
|
+
end
|
532
|
+
|
533
|
+
describe "when id is empty" do
|
534
|
+
|
535
|
+
before do
|
536
|
+
signing_options = Pandexio::SigningOptions.new()
|
537
|
+
http_client = Pandexio::HttpClient.new()
|
538
|
+
@get_document_cover = ->{ http_client.get_document_cover("", 'm', signing_options) }
|
539
|
+
end
|
540
|
+
|
541
|
+
it "should raise ArgumentError" do
|
542
|
+
err = @get_document_cover.must_raise ArgumentError
|
543
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
544
|
+
end
|
545
|
+
|
546
|
+
end
|
547
|
+
|
548
|
+
describe "when id is blank" do
|
549
|
+
|
550
|
+
before do
|
551
|
+
signing_options = Pandexio::SigningOptions.new()
|
552
|
+
http_client = Pandexio::HttpClient.new()
|
553
|
+
@get_document_cover = ->{ http_client.get_document_cover(" ", 'm', signing_options) }
|
554
|
+
end
|
555
|
+
|
556
|
+
it "should raise ArgumentError" do
|
557
|
+
err = @get_document_cover.must_raise ArgumentError
|
558
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
559
|
+
end
|
560
|
+
|
561
|
+
end
|
562
|
+
|
563
|
+
describe "when id is not a string" do
|
564
|
+
|
565
|
+
before do
|
566
|
+
signing_options = Pandexio::SigningOptions.new()
|
567
|
+
http_client = Pandexio::HttpClient.new()
|
568
|
+
@get_document_cover = ->{ http_client.get_document_cover(123, 'm', signing_options) }
|
569
|
+
end
|
570
|
+
|
571
|
+
it "should raise ArgumentError" do
|
572
|
+
err = @get_document_cover.must_raise ArgumentError
|
573
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
574
|
+
end
|
575
|
+
|
576
|
+
end
|
577
|
+
|
578
|
+
describe "when id does not match RegEx" do
|
579
|
+
|
580
|
+
before do
|
581
|
+
signing_options = Pandexio::SigningOptions.new()
|
582
|
+
http_client = Pandexio::HttpClient.new()
|
583
|
+
@get_document_cover = ->{ http_client.get_document_cover("123^%$*abc", 'm', signing_options) }
|
584
|
+
end
|
585
|
+
|
586
|
+
it "should raise ArgumentError" do
|
587
|
+
err = @get_document_cover.must_raise ArgumentError
|
588
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
589
|
+
end
|
590
|
+
|
591
|
+
end
|
592
|
+
|
593
|
+
describe "when cover_size is invalid" do
|
594
|
+
|
595
|
+
before do
|
596
|
+
signing_options = Pandexio::SigningOptions.new()
|
597
|
+
http_client = Pandexio::HttpClient.new()
|
598
|
+
@get_document_cover = ->{ http_client.get_document_cover('test_id', 'abc', signing_options) }
|
599
|
+
end
|
600
|
+
|
601
|
+
it "should raise ArgumentError" do
|
602
|
+
err = @get_document_cover.must_raise ArgumentError
|
603
|
+
err.message.must_match "Document cover size must be xs, s, m, l, or xl."
|
604
|
+
end
|
605
|
+
|
606
|
+
end
|
607
|
+
|
608
|
+
describe "when document does not exist" do
|
609
|
+
|
610
|
+
before do
|
611
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
612
|
+
id = UUID.new.generate
|
613
|
+
signing_options = Pandexio::SigningOptions.new(
|
614
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
615
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
616
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
617
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
618
|
+
:date => Time.now.utc,
|
619
|
+
:expires => 90,
|
620
|
+
:originator => "HttpClientTest",
|
621
|
+
:email_address => "HttpClientTest",
|
622
|
+
:display_name => "HttpClientTest")
|
623
|
+
http_client = Pandexio::HttpClient.new()
|
624
|
+
@get_document_cover = ->{ http_client.get_document_cover(id, 'm', signing_options) }
|
625
|
+
end
|
626
|
+
|
627
|
+
it "should return nil" do
|
628
|
+
doc = @get_document_cover.call
|
629
|
+
doc.must_be_nil
|
630
|
+
end
|
631
|
+
|
632
|
+
end
|
633
|
+
|
634
|
+
describe "when cover size is xs" do
|
635
|
+
|
636
|
+
before do
|
637
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
638
|
+
@id = UUID.new.generate
|
639
|
+
document_source = Pandexio::DocumentSource.new(
|
640
|
+
:id => @id,
|
641
|
+
:name => "test_name_#{@id}.txt",
|
642
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
643
|
+
:location => "Inline")
|
644
|
+
signing_options = Pandexio::SigningOptions.new(
|
645
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
646
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
647
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
648
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
649
|
+
:date => Time.now.utc,
|
650
|
+
:expires => 90,
|
651
|
+
:originator => "HttpClientTest",
|
652
|
+
:email_address => "HttpClientTest",
|
653
|
+
:display_name => "HttpClientTest")
|
654
|
+
http_client = Pandexio::HttpClient.new()
|
655
|
+
http_client.load_document(document_source, signing_options)
|
656
|
+
sleep(3)
|
657
|
+
@get_document_cover = ->{ http_client.get_document_cover(@id, 'xs', signing_options) }
|
658
|
+
end
|
659
|
+
|
660
|
+
it "should return document details" do
|
661
|
+
cover = @get_document_cover.call
|
662
|
+
cover.length.must_equal 259
|
663
|
+
end
|
664
|
+
|
665
|
+
end
|
666
|
+
|
667
|
+
describe "when cover size is s" do
|
668
|
+
|
669
|
+
before do
|
670
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
671
|
+
@id = UUID.new.generate
|
672
|
+
document_source = Pandexio::DocumentSource.new(
|
673
|
+
:id => @id,
|
674
|
+
:name => "test_name_#{@id}.txt",
|
675
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
676
|
+
:location => "Inline")
|
677
|
+
signing_options = Pandexio::SigningOptions.new(
|
678
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
679
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
680
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
681
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
682
|
+
:date => Time.now.utc,
|
683
|
+
:expires => 90,
|
684
|
+
:originator => "HttpClientTest",
|
685
|
+
:email_address => "HttpClientTest",
|
686
|
+
:display_name => "HttpClientTest")
|
687
|
+
http_client = Pandexio::HttpClient.new()
|
688
|
+
http_client.load_document(document_source, signing_options)
|
689
|
+
sleep(3)
|
690
|
+
@get_document_cover = ->{ http_client.get_document_cover(@id, 's', signing_options) }
|
691
|
+
end
|
692
|
+
|
693
|
+
it "should return document details" do
|
694
|
+
cover = @get_document_cover.call
|
695
|
+
cover.length.must_equal 808
|
696
|
+
end
|
697
|
+
|
698
|
+
end
|
699
|
+
|
700
|
+
describe "when cover size is m" do
|
701
|
+
|
702
|
+
before do
|
703
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
704
|
+
@id = UUID.new.generate
|
705
|
+
document_source = Pandexio::DocumentSource.new(
|
706
|
+
:id => @id,
|
707
|
+
:name => "test_name_#{@id}.txt",
|
708
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
709
|
+
:location => "Inline")
|
710
|
+
signing_options = Pandexio::SigningOptions.new(
|
711
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
712
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
713
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
714
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
715
|
+
:date => Time.now.utc,
|
716
|
+
:expires => 90,
|
717
|
+
:originator => "HttpClientTest",
|
718
|
+
:email_address => "HttpClientTest",
|
719
|
+
:display_name => "HttpClientTest")
|
720
|
+
http_client = Pandexio::HttpClient.new()
|
721
|
+
http_client.load_document(document_source, signing_options)
|
722
|
+
sleep(3)
|
723
|
+
@get_document_cover = ->{ http_client.get_document_cover(@id, 'm', signing_options) }
|
724
|
+
end
|
725
|
+
|
726
|
+
it "should return document details" do
|
727
|
+
cover = @get_document_cover.call
|
728
|
+
cover.length.must_equal 1888
|
729
|
+
end
|
730
|
+
|
731
|
+
end
|
732
|
+
|
733
|
+
describe "when cover size is l" do
|
734
|
+
|
735
|
+
before do
|
736
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
737
|
+
@id = UUID.new.generate
|
738
|
+
document_source = Pandexio::DocumentSource.new(
|
739
|
+
:id => @id,
|
740
|
+
:name => "test_name_#{@id}.txt",
|
741
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
742
|
+
:location => "Inline")
|
743
|
+
signing_options = Pandexio::SigningOptions.new(
|
744
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
745
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
746
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
747
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
748
|
+
:date => Time.now.utc,
|
749
|
+
:expires => 90,
|
750
|
+
:originator => "HttpClientTest",
|
751
|
+
:email_address => "HttpClientTest",
|
752
|
+
:display_name => "HttpClientTest")
|
753
|
+
http_client = Pandexio::HttpClient.new()
|
754
|
+
http_client.load_document(document_source, signing_options)
|
755
|
+
sleep(3)
|
756
|
+
@get_document_cover = ->{ http_client.get_document_cover(@id, 'l', signing_options) }
|
757
|
+
end
|
758
|
+
|
759
|
+
it "should return document details" do
|
760
|
+
cover = @get_document_cover.call
|
761
|
+
cover.length.must_equal 3726
|
762
|
+
end
|
763
|
+
|
764
|
+
end
|
765
|
+
|
766
|
+
describe "when cover size is xl" do
|
767
|
+
|
768
|
+
before do
|
769
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
770
|
+
@id = UUID.new.generate
|
771
|
+
document_source = Pandexio::DocumentSource.new(
|
772
|
+
:id => @id,
|
773
|
+
:name => "test_name_#{@id}.txt",
|
774
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
775
|
+
:location => "Inline")
|
776
|
+
signing_options = Pandexio::SigningOptions.new(
|
777
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
778
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
779
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
780
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
781
|
+
:date => Time.now.utc,
|
782
|
+
:expires => 90,
|
783
|
+
:originator => "HttpClientTest",
|
784
|
+
:email_address => "HttpClientTest",
|
785
|
+
:display_name => "HttpClientTest")
|
786
|
+
http_client = Pandexio::HttpClient.new()
|
787
|
+
http_client.load_document(document_source, signing_options)
|
788
|
+
sleep(3)
|
789
|
+
@get_document_cover = ->{ http_client.get_document_cover(@id, 'xl', signing_options) }
|
790
|
+
end
|
791
|
+
|
792
|
+
it "should return document details" do
|
793
|
+
cover = @get_document_cover.call
|
794
|
+
cover.length.must_equal 7089
|
795
|
+
end
|
796
|
+
|
797
|
+
end
|
798
|
+
|
799
|
+
end
|
800
|
+
|
801
|
+
describe "#get_document_cover_url" do
|
802
|
+
|
803
|
+
describe "when id is nil" do
|
804
|
+
|
805
|
+
before do
|
806
|
+
signing_options = Pandexio::SigningOptions.new()
|
807
|
+
http_client = Pandexio::HttpClient.new()
|
808
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url(nil, 'm', signing_options) }
|
809
|
+
end
|
810
|
+
|
811
|
+
it "should raise ArgumentError" do
|
812
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
813
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
814
|
+
end
|
815
|
+
|
816
|
+
end
|
817
|
+
|
818
|
+
describe "when id is empty" do
|
819
|
+
|
820
|
+
before do
|
821
|
+
signing_options = Pandexio::SigningOptions.new()
|
822
|
+
http_client = Pandexio::HttpClient.new()
|
823
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url("", 'm', signing_options) }
|
824
|
+
end
|
825
|
+
|
826
|
+
it "should raise ArgumentError" do
|
827
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
828
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
829
|
+
end
|
830
|
+
|
831
|
+
end
|
832
|
+
|
833
|
+
describe "when id is blank" do
|
834
|
+
|
835
|
+
before do
|
836
|
+
signing_options = Pandexio::SigningOptions.new()
|
837
|
+
http_client = Pandexio::HttpClient.new()
|
838
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url(" ", 'm', signing_options) }
|
839
|
+
end
|
840
|
+
|
841
|
+
it "should raise ArgumentError" do
|
842
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
843
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
844
|
+
end
|
845
|
+
|
846
|
+
end
|
847
|
+
|
848
|
+
describe "when id is not a string" do
|
849
|
+
|
850
|
+
before do
|
851
|
+
signing_options = Pandexio::SigningOptions.new()
|
852
|
+
http_client = Pandexio::HttpClient.new()
|
853
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url(123, 'm', signing_options) }
|
854
|
+
end
|
855
|
+
|
856
|
+
it "should raise ArgumentError" do
|
857
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
858
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
859
|
+
end
|
860
|
+
|
861
|
+
end
|
862
|
+
|
863
|
+
describe "when id does not match RegEx" do
|
864
|
+
|
865
|
+
before do
|
866
|
+
signing_options = Pandexio::SigningOptions.new()
|
867
|
+
http_client = Pandexio::HttpClient.new()
|
868
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url("123^%$*abc", 'm', signing_options) }
|
869
|
+
end
|
870
|
+
|
871
|
+
it "should raise ArgumentError" do
|
872
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
873
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
874
|
+
end
|
875
|
+
|
876
|
+
end
|
877
|
+
|
878
|
+
describe "when cover_size is invalid" do
|
879
|
+
|
880
|
+
before do
|
881
|
+
signing_options = Pandexio::SigningOptions.new()
|
882
|
+
http_client = Pandexio::HttpClient.new()
|
883
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url('test_id', 'abc', signing_options) }
|
884
|
+
end
|
885
|
+
|
886
|
+
it "should raise ArgumentError" do
|
887
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
888
|
+
err.message.must_match "Document cover size must be xs, s, m, l, or xl."
|
889
|
+
end
|
890
|
+
|
891
|
+
end
|
892
|
+
|
893
|
+
describe "when signing_mechanism is Header" do
|
894
|
+
|
895
|
+
before do
|
896
|
+
id = UUID.new.generate
|
897
|
+
signing_options = Pandexio::SigningOptions.new(
|
898
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
899
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
900
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
901
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
902
|
+
:date => Time.now.utc,
|
903
|
+
:expires => 90,
|
904
|
+
:originator => "HttpClientTest",
|
905
|
+
:email_address => "HttpClientTest",
|
906
|
+
:display_name => "HttpClientTest")
|
907
|
+
http_client = Pandexio::HttpClient.new()
|
908
|
+
@get_document_cover_url = ->{ http_client.get_document_cover_url(id, 'm', signing_options) }
|
909
|
+
end
|
910
|
+
|
911
|
+
it "should return nil" do
|
912
|
+
err = @get_document_cover_url.must_raise ArgumentError
|
913
|
+
err.message.must_match "Signing mechanism must be QueryString."
|
914
|
+
end
|
915
|
+
|
916
|
+
end
|
917
|
+
|
918
|
+
describe "when cover size is xs" do
|
919
|
+
|
920
|
+
before do
|
921
|
+
@id = UUID.new.generate
|
922
|
+
document_source = Pandexio::DocumentSource.new(
|
923
|
+
:id => @id,
|
924
|
+
:name => "test_name_#{@id}.txt",
|
925
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
926
|
+
:location => "Inline")
|
927
|
+
signing_options = Pandexio::SigningOptions.new(
|
928
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
929
|
+
:mechanism => Pandexio::SigningMechanisms::QUERY_STRING,
|
930
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
931
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
932
|
+
:date => Time.now.utc,
|
933
|
+
:expires => 90,
|
934
|
+
:originator => "HttpClientTest",
|
935
|
+
:email_address => "HttpClientTest",
|
936
|
+
:display_name => "HttpClientTest")
|
937
|
+
http_client = Pandexio::HttpClient.new()
|
938
|
+
@document_cover_url = http_client.get_document_cover_url(@id, 'xs', signing_options)
|
939
|
+
end
|
940
|
+
|
941
|
+
it "should return document details" do
|
942
|
+
(@document_cover_url.include? "/v2/documents/#{@id}/cover").must_equal true
|
943
|
+
(@document_cover_url.include? "coverSize=xs").must_equal true
|
944
|
+
(@document_cover_url.include? "X-Pdx-Originator=HttpClientTest").must_equal true
|
945
|
+
(@document_cover_url.include? "X-Pdx-EmailAddress=HttpClientTest").must_equal true
|
946
|
+
(@document_cover_url.include? "X-Pdx-DisplayName=HttpClientTest").must_equal true
|
947
|
+
(@document_cover_url.include? "X-Pdx-Expires=90").must_equal true
|
948
|
+
(@document_cover_url.include? "X-Pdx-Credential=#{TestConfig::DOMAIN_ID}").must_equal true
|
949
|
+
(@document_cover_url.include? "X-Pdx-Signature=").must_equal true
|
950
|
+
end
|
951
|
+
|
952
|
+
end
|
953
|
+
|
954
|
+
describe "when cover size is s" do
|
955
|
+
|
956
|
+
before do
|
957
|
+
@id = UUID.new.generate
|
958
|
+
document_source = Pandexio::DocumentSource.new(
|
959
|
+
:id => @id,
|
960
|
+
:name => "test_name_#{@id}.txt",
|
961
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
962
|
+
:location => "Inline")
|
963
|
+
signing_options = Pandexio::SigningOptions.new(
|
964
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
965
|
+
:mechanism => Pandexio::SigningMechanisms::QUERY_STRING,
|
966
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
967
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
968
|
+
:date => Time.now.utc,
|
969
|
+
:expires => 90,
|
970
|
+
:originator => "HttpClientTest",
|
971
|
+
:email_address => "HttpClientTest",
|
972
|
+
:display_name => "HttpClientTest")
|
973
|
+
http_client = Pandexio::HttpClient.new()
|
974
|
+
@document_cover_url = http_client.get_document_cover_url(@id, 's', signing_options)
|
975
|
+
end
|
976
|
+
|
977
|
+
it "should return document details" do
|
978
|
+
(@document_cover_url.include? "/v2/documents/#{@id}/cover").must_equal true
|
979
|
+
(@document_cover_url.include? "coverSize=s").must_equal true
|
980
|
+
(@document_cover_url.include? "X-Pdx-Originator=HttpClientTest").must_equal true
|
981
|
+
(@document_cover_url.include? "X-Pdx-EmailAddress=HttpClientTest").must_equal true
|
982
|
+
(@document_cover_url.include? "X-Pdx-DisplayName=HttpClientTest").must_equal true
|
983
|
+
(@document_cover_url.include? "X-Pdx-Expires=90").must_equal true
|
984
|
+
(@document_cover_url.include? "X-Pdx-Credential=#{TestConfig::DOMAIN_ID}").must_equal true
|
985
|
+
(@document_cover_url.include? "X-Pdx-Signature=").must_equal true
|
986
|
+
end
|
987
|
+
|
988
|
+
end
|
989
|
+
|
990
|
+
describe "when cover size is m" do
|
991
|
+
|
992
|
+
before do
|
993
|
+
@id = UUID.new.generate
|
994
|
+
document_source = Pandexio::DocumentSource.new(
|
995
|
+
:id => @id,
|
996
|
+
:name => "test_name_#{@id}.txt",
|
997
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
998
|
+
:location => "Inline")
|
999
|
+
signing_options = Pandexio::SigningOptions.new(
|
1000
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
1001
|
+
:mechanism => Pandexio::SigningMechanisms::QUERY_STRING,
|
1002
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
1003
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
1004
|
+
:date => Time.now.utc,
|
1005
|
+
:expires => 90,
|
1006
|
+
:originator => "HttpClientTest",
|
1007
|
+
:email_address => "HttpClientTest",
|
1008
|
+
:display_name => "HttpClientTest")
|
1009
|
+
http_client = Pandexio::HttpClient.new()
|
1010
|
+
@document_cover_url = http_client.get_document_cover_url(@id, 'm', signing_options)
|
1011
|
+
end
|
1012
|
+
|
1013
|
+
it "should return document details" do
|
1014
|
+
(@document_cover_url.include? "/v2/documents/#{@id}/cover").must_equal true
|
1015
|
+
(@document_cover_url.include? "coverSize=m").must_equal true
|
1016
|
+
(@document_cover_url.include? "X-Pdx-Originator=HttpClientTest").must_equal true
|
1017
|
+
(@document_cover_url.include? "X-Pdx-EmailAddress=HttpClientTest").must_equal true
|
1018
|
+
(@document_cover_url.include? "X-Pdx-DisplayName=HttpClientTest").must_equal true
|
1019
|
+
(@document_cover_url.include? "X-Pdx-Expires=90").must_equal true
|
1020
|
+
(@document_cover_url.include? "X-Pdx-Credential=#{TestConfig::DOMAIN_ID}").must_equal true
|
1021
|
+
(@document_cover_url.include? "X-Pdx-Signature=").must_equal true
|
1022
|
+
end
|
1023
|
+
|
1024
|
+
end
|
1025
|
+
|
1026
|
+
describe "when cover size is l" do
|
1027
|
+
|
1028
|
+
before do
|
1029
|
+
@id = UUID.new.generate
|
1030
|
+
document_source = Pandexio::DocumentSource.new(
|
1031
|
+
:id => @id,
|
1032
|
+
:name => "test_name_#{@id}.txt",
|
1033
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
1034
|
+
:location => "Inline")
|
1035
|
+
signing_options = Pandexio::SigningOptions.new(
|
1036
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
1037
|
+
:mechanism => Pandexio::SigningMechanisms::QUERY_STRING,
|
1038
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
1039
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
1040
|
+
:date => Time.now.utc,
|
1041
|
+
:expires => 90,
|
1042
|
+
:originator => "HttpClientTest",
|
1043
|
+
:email_address => "HttpClientTest",
|
1044
|
+
:display_name => "HttpClientTest")
|
1045
|
+
http_client = Pandexio::HttpClient.new()
|
1046
|
+
@document_cover_url = http_client.get_document_cover_url(@id, 'l', signing_options)
|
1047
|
+
end
|
1048
|
+
|
1049
|
+
it "should return document details" do
|
1050
|
+
(@document_cover_url.include? "/v2/documents/#{@id}/cover").must_equal true
|
1051
|
+
(@document_cover_url.include? "coverSize=l").must_equal true
|
1052
|
+
(@document_cover_url.include? "X-Pdx-Originator=HttpClientTest").must_equal true
|
1053
|
+
(@document_cover_url.include? "X-Pdx-EmailAddress=HttpClientTest").must_equal true
|
1054
|
+
(@document_cover_url.include? "X-Pdx-DisplayName=HttpClientTest").must_equal true
|
1055
|
+
(@document_cover_url.include? "X-Pdx-Expires=90").must_equal true
|
1056
|
+
(@document_cover_url.include? "X-Pdx-Credential=#{TestConfig::DOMAIN_ID}").must_equal true
|
1057
|
+
(@document_cover_url.include? "X-Pdx-Signature=").must_equal true
|
1058
|
+
end
|
1059
|
+
|
1060
|
+
end
|
1061
|
+
|
1062
|
+
describe "when cover size is xl" do
|
1063
|
+
|
1064
|
+
before do
|
1065
|
+
@id = UUID.new.generate
|
1066
|
+
document_source = Pandexio::DocumentSource.new(
|
1067
|
+
:id => @id,
|
1068
|
+
:name => "test_name_#{@id}.txt",
|
1069
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
1070
|
+
:location => "Inline")
|
1071
|
+
signing_options = Pandexio::SigningOptions.new(
|
1072
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
1073
|
+
:mechanism => Pandexio::SigningMechanisms::QUERY_STRING,
|
1074
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
1075
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
1076
|
+
:date => Time.now.utc,
|
1077
|
+
:expires => 90,
|
1078
|
+
:originator => "HttpClientTest",
|
1079
|
+
:email_address => "HttpClientTest",
|
1080
|
+
:display_name => "HttpClientTest")
|
1081
|
+
http_client = Pandexio::HttpClient.new()
|
1082
|
+
@document_cover_url = http_client.get_document_cover_url(@id, 'xl', signing_options).to_s
|
1083
|
+
end
|
1084
|
+
|
1085
|
+
it "should return document details" do
|
1086
|
+
(@document_cover_url.include? "/v2/documents/#{@id}/cover").must_equal true
|
1087
|
+
(@document_cover_url.include? "coverSize=xl").must_equal true
|
1088
|
+
(@document_cover_url.include? "X-Pdx-Originator=HttpClientTest").must_equal true
|
1089
|
+
(@document_cover_url.include? "X-Pdx-EmailAddress=HttpClientTest").must_equal true
|
1090
|
+
(@document_cover_url.include? "X-Pdx-DisplayName=HttpClientTest").must_equal true
|
1091
|
+
(@document_cover_url.include? "X-Pdx-Expires=90").must_equal true
|
1092
|
+
(@document_cover_url.include? "X-Pdx-Credential=#{TestConfig::DOMAIN_ID}").must_equal true
|
1093
|
+
(@document_cover_url.include? "X-Pdx-Signature=").must_equal true
|
1094
|
+
end
|
1095
|
+
|
1096
|
+
end
|
1097
|
+
|
1098
|
+
end
|
1099
|
+
|
1100
|
+
describe "#get_document_snip_count" do
|
1101
|
+
|
1102
|
+
describe "when id is nil" do
|
1103
|
+
|
1104
|
+
before do
|
1105
|
+
signing_options = Pandexio::SigningOptions.new()
|
1106
|
+
http_client = Pandexio::HttpClient.new()
|
1107
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count(nil, signing_options) }
|
1108
|
+
end
|
1109
|
+
|
1110
|
+
it "should raise ArgumentError" do
|
1111
|
+
err = @get_document_snip_count.must_raise ArgumentError
|
1112
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
1113
|
+
end
|
1114
|
+
|
1115
|
+
end
|
1116
|
+
|
1117
|
+
describe "when id is empty" do
|
1118
|
+
|
1119
|
+
before do
|
1120
|
+
signing_options = Pandexio::SigningOptions.new()
|
1121
|
+
http_client = Pandexio::HttpClient.new()
|
1122
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count("", signing_options) }
|
1123
|
+
end
|
1124
|
+
|
1125
|
+
it "should raise ArgumentError" do
|
1126
|
+
err = @get_document_snip_count.must_raise ArgumentError
|
1127
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
1128
|
+
end
|
1129
|
+
|
1130
|
+
end
|
1131
|
+
|
1132
|
+
describe "when id is blank" do
|
1133
|
+
|
1134
|
+
before do
|
1135
|
+
signing_options = Pandexio::SigningOptions.new()
|
1136
|
+
http_client = Pandexio::HttpClient.new()
|
1137
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count(" ", signing_options) }
|
1138
|
+
end
|
1139
|
+
|
1140
|
+
it "should raise ArgumentError" do
|
1141
|
+
err = @get_document_snip_count.must_raise ArgumentError
|
1142
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
1143
|
+
end
|
1144
|
+
|
1145
|
+
end
|
1146
|
+
|
1147
|
+
describe "when id is not a string" do
|
1148
|
+
|
1149
|
+
before do
|
1150
|
+
signing_options = Pandexio::SigningOptions.new()
|
1151
|
+
http_client = Pandexio::HttpClient.new()
|
1152
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count(123, signing_options) }
|
1153
|
+
end
|
1154
|
+
|
1155
|
+
it "should raise ArgumentError" do
|
1156
|
+
err = @get_document_snip_count.must_raise ArgumentError
|
1157
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
1158
|
+
end
|
1159
|
+
|
1160
|
+
end
|
1161
|
+
|
1162
|
+
describe "when id does not match RegEx" do
|
1163
|
+
|
1164
|
+
before do
|
1165
|
+
signing_options = Pandexio::SigningOptions.new()
|
1166
|
+
http_client = Pandexio::HttpClient.new()
|
1167
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count("123^%$*abc", signing_options) }
|
1168
|
+
end
|
1169
|
+
|
1170
|
+
it "should raise ArgumentError" do
|
1171
|
+
err = @get_document_snip_count.must_raise ArgumentError
|
1172
|
+
err.message.must_match "Document ID is not a string, is nil or empty, or does not match RegEx pattern: #{Pandexio::ScopePatterns::DOCUMENT_ID_PATTERN}."
|
1173
|
+
end
|
1174
|
+
|
1175
|
+
end
|
1176
|
+
|
1177
|
+
describe "when document does not exist" do
|
1178
|
+
|
1179
|
+
before do
|
1180
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
1181
|
+
id = UUID.new.generate
|
1182
|
+
signing_options = Pandexio::SigningOptions.new(
|
1183
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
1184
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
1185
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
1186
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
1187
|
+
:date => Time.now.utc,
|
1188
|
+
:expires => 90,
|
1189
|
+
:originator => "HttpClientTest",
|
1190
|
+
:email_address => "HttpClientTest",
|
1191
|
+
:display_name => "HttpClientTest")
|
1192
|
+
http_client = Pandexio::HttpClient.new()
|
1193
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count(id, signing_options) }
|
1194
|
+
end
|
1195
|
+
|
1196
|
+
it "should return ." do
|
1197
|
+
count = @get_document_snip_count.call
|
1198
|
+
count.must_equal 0
|
1199
|
+
end
|
1200
|
+
|
1201
|
+
end
|
1202
|
+
|
1203
|
+
describe "when document exists" do
|
1204
|
+
|
1205
|
+
before do
|
1206
|
+
skip("skip integration tests") if TestConfig::SKIP_INTEGRATION_TESTS
|
1207
|
+
@id = UUID.new.generate
|
1208
|
+
document_source = Pandexio::DocumentSource.new(
|
1209
|
+
:id => @id,
|
1210
|
+
:name => "test_name_#{@id}.txt",
|
1211
|
+
:content => "data:text/plain;base64,dGVzdGluZyAxMjM=",
|
1212
|
+
:location => "Inline")
|
1213
|
+
signing_options = Pandexio::SigningOptions.new(
|
1214
|
+
:algorithm => Pandexio::SigningAlgorithms::PDX_HMAC_SHA256,
|
1215
|
+
:mechanism => Pandexio::SigningMechanisms::HEADER,
|
1216
|
+
:domain_id => TestConfig::DOMAIN_ID,
|
1217
|
+
:domain_key => TestConfig::DOMAIN_KEY,
|
1218
|
+
:date => Time.now.utc,
|
1219
|
+
:expires => 90,
|
1220
|
+
:originator => "HttpClientTest",
|
1221
|
+
:email_address => "HttpClientTest",
|
1222
|
+
:display_name => "HttpClientTest")
|
1223
|
+
http_client = Pandexio::HttpClient.new()
|
1224
|
+
http_client.load_document(document_source, signing_options)
|
1225
|
+
sleep(3)
|
1226
|
+
@get_document_snip_count = ->{ http_client.get_document_snip_count(@id, signing_options) }
|
1227
|
+
end
|
1228
|
+
|
1229
|
+
it "should return document details" do
|
1230
|
+
count = @get_document_snip_count.call
|
1231
|
+
count.must_equal 0
|
1232
|
+
end
|
1233
|
+
|
1234
|
+
end
|
1235
|
+
|
1236
|
+
end
|
1237
|
+
|
1238
|
+
end
|