deepl-rb 2.5.3 → 3.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/add_issues_to_kanban.yml +16 -0
- data/.gitlab-ci.yml +135 -0
- data/.rubocop.yml +27 -0
- data/CHANGELOG.md +34 -0
- data/CODE_OF_CONDUCT.md +132 -0
- data/CONTRIBUTING.md +37 -0
- data/Gemfile +3 -1
- data/LICENSE.md +1 -0
- data/README.md +115 -5
- data/Rakefile +7 -5
- data/SECURITY.md +58 -0
- data/VERSION +1 -1
- data/deepl-rb.gemspec +36 -20
- data/lib/deepl/api.rb +11 -1
- data/lib/deepl/configuration.rb +34 -3
- data/lib/deepl/document_api.rb +120 -0
- data/lib/deepl/exceptions/authorization_failed.rb +3 -0
- data/lib/deepl/exceptions/bad_request.rb +3 -0
- data/lib/deepl/exceptions/document_translation_error.rb +15 -0
- data/lib/deepl/exceptions/error.rb +6 -0
- data/lib/deepl/exceptions/limit_exceeded.rb +7 -0
- data/lib/deepl/exceptions/not_found.rb +3 -0
- data/lib/deepl/exceptions/not_supported.rb +3 -0
- data/lib/deepl/exceptions/quota_exceeded.rb +3 -0
- data/lib/deepl/exceptions/request_entity_too_large.rb +3 -0
- data/lib/deepl/exceptions/request_error.rb +4 -2
- data/lib/deepl/exceptions/server_error.rb +18 -0
- data/lib/deepl/glossary_api.rb +3 -0
- data/lib/deepl/requests/base.rb +89 -34
- data/lib/deepl/requests/document/download.rb +44 -0
- data/lib/deepl/requests/document/get_status.rb +44 -0
- data/lib/deepl/requests/document/upload.rb +64 -0
- data/lib/deepl/requests/glossary/create.rb +15 -1
- data/lib/deepl/requests/glossary/destroy.rb +8 -1
- data/lib/deepl/requests/glossary/entries.rb +8 -1
- data/lib/deepl/requests/glossary/find.rb +8 -1
- data/lib/deepl/requests/glossary/language_pairs.rb +9 -2
- data/lib/deepl/requests/glossary/list.rb +9 -2
- data/lib/deepl/requests/languages.rb +9 -2
- data/lib/deepl/requests/translate.rb +33 -11
- data/lib/deepl/requests/usage.rb +9 -2
- data/lib/deepl/resources/base.rb +3 -0
- data/lib/deepl/resources/document_handle.rb +57 -0
- data/lib/deepl/resources/document_translation_status.rb +54 -0
- data/lib/deepl/resources/glossary.rb +3 -0
- data/lib/deepl/resources/language.rb +3 -0
- data/lib/deepl/resources/language_pair.rb +3 -0
- data/lib/deepl/resources/text.rb +3 -0
- data/lib/deepl/resources/usage.rb +3 -0
- data/lib/deepl/utils/backoff_timer.rb +46 -0
- data/lib/deepl/utils/exception_builder.rb +18 -13
- data/lib/deepl.rb +47 -0
- data/lib/http_client_options.rb +22 -0
- data/license_checker.sh +8 -0
- data/spec/api/api_spec.rb +8 -4
- data/spec/api/configuration_spec.rb +92 -18
- data/spec/api/deepl_spec.rb +225 -86
- data/spec/fixtures/vcr_cassettes/deepl_document.yml +95 -0
- data/spec/fixtures/vcr_cassettes/deepl_document_download.yml +1214 -0
- data/spec/fixtures/vcr_cassettes/deepl_glossaries.yml +812 -23
- data/spec/fixtures/vcr_cassettes/deepl_languages.yml +28 -17
- data/spec/fixtures/vcr_cassettes/deepl_translate.yml +161 -53
- data/spec/fixtures/vcr_cassettes/deepl_usage.yml +93 -3
- data/spec/fixtures/vcr_cassettes/glossaries.yml +1237 -15
- data/spec/fixtures/vcr_cassettes/languages.yml +159 -44
- data/spec/fixtures/vcr_cassettes/translate_texts.yml +9742 -12
- data/spec/fixtures/vcr_cassettes/usage.yml +134 -2
- data/spec/integration_tests/document_api_spec.rb +143 -0
- data/spec/integration_tests/integration_test_utils.rb +170 -0
- data/spec/requests/glossary/create_spec.rb +23 -13
- data/spec/requests/glossary/destroy_spec.rb +33 -17
- data/spec/requests/glossary/entries_spec.rb +31 -17
- data/spec/requests/glossary/find_spec.rb +31 -17
- data/spec/requests/glossary/language_pairs_spec.rb +17 -7
- data/spec/requests/glossary/list_spec.rb +21 -11
- data/spec/requests/languages_spec.rb +31 -21
- data/spec/requests/translate_spec.rb +125 -131
- data/spec/requests/usage_spec.rb +17 -7
- data/spec/resources/glossary_spec.rb +15 -12
- data/spec/resources/language_pair_spec.rb +10 -7
- data/spec/resources/language_spec.rb +21 -18
- data/spec/resources/text_spec.rb +10 -7
- data/spec/resources/usage_spec.rb +16 -13
- data/spec/spec_helper.rb +63 -6
- metadata +32 -9
@@ -1,8 +1,19 @@
|
|
1
|
+
# Copyright 2018 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Requests::Translate do
|
9
|
+
subject(:translate) { described_class.new(api, text, source_lang, target_lang, options) }
|
10
|
+
|
11
|
+
around do |tests|
|
12
|
+
tmp_env = replace_env_preserving_deepl_vars_except_mock_server
|
13
|
+
tests.call
|
14
|
+
ENV.replace(tmp_env)
|
15
|
+
end
|
16
|
+
|
6
17
|
let(:tags_str) { 'p,strong,span' }
|
7
18
|
let(:tags_array) { %w[p strong span] }
|
8
19
|
|
@@ -12,187 +23,170 @@ describe DeepL::Requests::Translate do
|
|
12
23
|
let(:target_lang) { 'ES' }
|
13
24
|
let(:options) { {} }
|
14
25
|
|
15
|
-
subject { DeepL::Requests::Translate.new(api, text, source_lang, target_lang, options) }
|
16
|
-
|
17
26
|
describe '#initialize' do
|
18
|
-
context '
|
19
|
-
it '
|
20
|
-
expect(
|
27
|
+
context 'when building a request' do
|
28
|
+
it 'creates a request object' do
|
29
|
+
expect(translate).to be_a(described_class)
|
21
30
|
end
|
22
31
|
end
|
23
32
|
|
24
33
|
context 'when using `splitting_tags` options' do
|
25
|
-
it '
|
26
|
-
request =
|
27
|
-
expect(request.options[:splitting_tags]).to
|
28
|
-
end
|
29
|
-
|
30
|
-
it 'should work with a blank list' do
|
31
|
-
request = DeepL::Requests::Translate.new(api, nil, nil, nil, splitting_tags: '')
|
32
|
-
expect(request.options[:splitting_tags]).to eq('')
|
34
|
+
it 'works with a nil values' do
|
35
|
+
request = described_class.new(api, nil, nil, nil, splitting_tags: nil)
|
36
|
+
expect(request.options[:splitting_tags]).to be_nil
|
33
37
|
end
|
34
38
|
|
35
|
-
it '
|
36
|
-
request =
|
37
|
-
expect(request.options[:splitting_tags]).to eq(
|
39
|
+
it 'works with a blank list' do
|
40
|
+
request = described_class.new(api, nil, nil, nil, splitting_tags: '')
|
41
|
+
expect(request.options[:splitting_tags]).to eq([])
|
38
42
|
end
|
39
43
|
|
40
|
-
it '
|
41
|
-
request =
|
42
|
-
expect(request.options[:splitting_tags]).to eq(
|
44
|
+
it 'works with a comma-separated list and converts strings to an array' do
|
45
|
+
request = described_class.new(api, nil, nil, nil, splitting_tags: tags_str)
|
46
|
+
expect(request.options[:splitting_tags]).to eq(tags_array)
|
43
47
|
end
|
44
48
|
|
45
|
-
it '
|
46
|
-
request =
|
47
|
-
expect(request.options[:splitting_tags]).to eq(
|
49
|
+
it 'works with an array of tags and leaves it as is' do
|
50
|
+
request = described_class.new(api, nil, nil, nil, splitting_tags: tags_array)
|
51
|
+
expect(request.options[:splitting_tags]).to eq(tags_array)
|
48
52
|
end
|
49
53
|
end
|
50
54
|
|
51
55
|
context 'when using `non_splitting_tags` options' do
|
52
|
-
it '
|
53
|
-
request =
|
54
|
-
expect(request.options[:non_splitting_tags]).to
|
55
|
-
end
|
56
|
-
|
57
|
-
it 'should work with a blank list' do
|
58
|
-
request = DeepL::Requests::Translate.new(api, nil, nil, nil, non_splitting_tags: '')
|
59
|
-
expect(request.options[:non_splitting_tags]).to eq('')
|
56
|
+
it 'works with a nil values' do
|
57
|
+
request = described_class.new(api, nil, nil, nil, non_splitting_tags: nil)
|
58
|
+
expect(request.options[:non_splitting_tags]).to be_nil
|
60
59
|
end
|
61
60
|
|
62
|
-
it '
|
63
|
-
request =
|
64
|
-
expect(request.options[:non_splitting_tags]).to eq(
|
61
|
+
it 'works with a blank list' do
|
62
|
+
request = described_class.new(api, nil, nil, nil, non_splitting_tags: '')
|
63
|
+
expect(request.options[:non_splitting_tags]).to eq([])
|
65
64
|
end
|
66
65
|
|
67
|
-
it '
|
68
|
-
request =
|
69
|
-
expect(request.options[:non_splitting_tags]).to eq(
|
66
|
+
it 'works with a comma-separated list and converts strings to an array' do
|
67
|
+
request = described_class.new(api, nil, nil, nil, non_splitting_tags: tags_str)
|
68
|
+
expect(request.options[:non_splitting_tags]).to eq(tags_array)
|
70
69
|
end
|
71
70
|
|
72
|
-
it '
|
73
|
-
request =
|
74
|
-
expect(request.options[:non_splitting_tags]).to eq(
|
71
|
+
it 'works with an array and leaves it as it is' do
|
72
|
+
request = described_class.new(api, nil, nil, nil, non_splitting_tags: tags_array)
|
73
|
+
expect(request.options[:non_splitting_tags]).to eq(tags_array)
|
75
74
|
end
|
76
75
|
end
|
77
76
|
|
78
77
|
context 'when using `ignore_tags` options' do
|
79
|
-
it '
|
80
|
-
request =
|
81
|
-
expect(request.options[:ignore_tags]).to
|
82
|
-
end
|
83
|
-
|
84
|
-
it 'should work with a blank list' do
|
85
|
-
request = DeepL::Requests::Translate.new(api, nil, nil, nil, ignore_tags: '')
|
86
|
-
expect(request.options[:ignore_tags]).to eq('')
|
78
|
+
it 'works with a nil values' do
|
79
|
+
request = described_class.new(api, nil, nil, nil, ignore_tags: nil)
|
80
|
+
expect(request.options[:ignore_tags]).to be_nil
|
87
81
|
end
|
88
82
|
|
89
|
-
it '
|
90
|
-
request =
|
91
|
-
expect(request.options[:ignore_tags]).to eq(
|
83
|
+
it 'works with a blank list' do
|
84
|
+
request = described_class.new(api, nil, nil, nil, ignore_tags: '')
|
85
|
+
expect(request.options[:ignore_tags]).to eq([])
|
92
86
|
end
|
93
87
|
|
94
|
-
it '
|
95
|
-
request =
|
96
|
-
expect(request.options[:ignore_tags]).to eq(
|
88
|
+
it 'works with a comma-separated list and converts a string to an array' do
|
89
|
+
request = described_class.new(api, nil, nil, nil, ignore_tags: tags_str)
|
90
|
+
expect(request.options[:ignore_tags]).to eq(tags_array)
|
97
91
|
end
|
98
92
|
|
99
|
-
it '
|
100
|
-
request =
|
101
|
-
expect(request.options[:ignore_tags]).to eq(
|
93
|
+
it 'works with an array and leaves it as it is' do
|
94
|
+
request = described_class.new(api, nil, nil, nil, ignore_tags: tags_array)
|
95
|
+
expect(request.options[:ignore_tags]).to eq(tags_array)
|
102
96
|
end
|
103
97
|
end
|
104
98
|
|
105
99
|
context 'when using `split_sentences` options' do
|
106
|
-
it '
|
107
|
-
request =
|
100
|
+
it 'converts `true` to `1`' do
|
101
|
+
request = described_class.new(api, nil, nil, nil, split_sentences: true)
|
108
102
|
expect(request.options[:split_sentences]).to eq('1')
|
109
103
|
end
|
110
104
|
|
111
|
-
it '
|
112
|
-
request =
|
105
|
+
it 'converts `false` to `0`' do
|
106
|
+
request = described_class.new(api, nil, nil, nil, split_sentences: false)
|
113
107
|
expect(request.options[:split_sentences]).to eq('0')
|
114
108
|
end
|
115
109
|
|
116
|
-
it '
|
117
|
-
request =
|
110
|
+
it 'leaves `0` as is' do
|
111
|
+
request = described_class.new(api, nil, nil, nil, split_sentences: '0')
|
118
112
|
expect(request.options[:split_sentences]).to eq('0')
|
119
113
|
end
|
120
114
|
|
121
|
-
it '
|
122
|
-
request =
|
115
|
+
it 'leaves `nonewlines` as is' do
|
116
|
+
request = described_class.new(api, nil, nil, nil, split_sentences: 'nonewlines')
|
123
117
|
expect(request.options[:split_sentences]).to eq('nonewlines')
|
124
118
|
end
|
125
119
|
|
126
|
-
it '
|
127
|
-
request =
|
120
|
+
it 'leaves `1` as is' do
|
121
|
+
request = described_class.new(api, nil, nil, nil, split_sentences: '1')
|
128
122
|
expect(request.options[:split_sentences]).to eq('1')
|
129
123
|
end
|
130
124
|
end
|
131
125
|
|
132
126
|
context 'when using `preserve_formatting` options' do
|
133
|
-
it '
|
134
|
-
request =
|
135
|
-
expect(request.options[:preserve_formatting]).to
|
127
|
+
it 'leaves `true` as is' do
|
128
|
+
request = described_class.new(api, nil, nil, nil, preserve_formatting: true)
|
129
|
+
expect(request.options[:preserve_formatting]).to be(true)
|
136
130
|
end
|
137
131
|
|
138
|
-
it '
|
139
|
-
request =
|
140
|
-
expect(request.options[:preserve_formatting]).to
|
132
|
+
it 'leaves `false` as is' do
|
133
|
+
request = described_class.new(api, nil, nil, nil, preserve_formatting: false)
|
134
|
+
expect(request.options[:preserve_formatting]).to be(false)
|
141
135
|
end
|
142
136
|
|
143
|
-
it '
|
144
|
-
request =
|
145
|
-
expect(request.options[:preserve_formatting]).to
|
137
|
+
it 'converts `0` to `false`' do
|
138
|
+
request = described_class.new(api, nil, nil, nil, preserve_formatting: '0')
|
139
|
+
expect(request.options[:preserve_formatting]).to be(false)
|
146
140
|
end
|
147
141
|
|
148
|
-
it '
|
149
|
-
request =
|
150
|
-
expect(request.options[:preserve_formatting]).to
|
142
|
+
it 'converts `1` to `true`' do
|
143
|
+
request = described_class.new(api, nil, nil, nil, preserve_formatting: '1')
|
144
|
+
expect(request.options[:preserve_formatting]).to be(true)
|
151
145
|
end
|
152
146
|
end
|
153
147
|
|
154
148
|
context 'when using `outline_detection` options' do
|
155
|
-
it '
|
156
|
-
request =
|
157
|
-
expect(request.options[:outline_detection]).to
|
149
|
+
it 'leaves `true` as is' do
|
150
|
+
request = described_class.new(api, nil, nil, nil, outline_detection: true)
|
151
|
+
expect(request.options[:outline_detection]).to be(true)
|
158
152
|
end
|
159
153
|
|
160
|
-
it '
|
161
|
-
request =
|
162
|
-
expect(request.options[:outline_detection]).to
|
154
|
+
it 'leaves `false` as is' do
|
155
|
+
request = described_class.new(api, nil, nil, nil, outline_detection: false)
|
156
|
+
expect(request.options[:outline_detection]).to be(false)
|
163
157
|
end
|
164
158
|
|
165
|
-
it '
|
166
|
-
request =
|
167
|
-
expect(request.options[:outline_detection]).to
|
159
|
+
it 'converts `0` to `false`' do
|
160
|
+
request = described_class.new(api, nil, nil, nil, outline_detection: '0')
|
161
|
+
expect(request.options[:outline_detection]).to be(false)
|
168
162
|
end
|
169
163
|
|
170
|
-
it '
|
171
|
-
request =
|
172
|
-
expect(request.options[:outline_detection]).to
|
164
|
+
it 'converts `1` to `true`' do
|
165
|
+
request = described_class.new(api, nil, nil, nil, outline_detection: '1')
|
166
|
+
expect(request.options[:outline_detection]).to be(true)
|
173
167
|
end
|
174
168
|
end
|
175
169
|
|
176
170
|
context 'when using `glossary_id` options' do
|
177
|
-
it '
|
178
|
-
request =
|
179
|
-
expect(request.options[:glossary_id]).to
|
171
|
+
it 'works with a nil values' do
|
172
|
+
request = described_class.new(api, nil, nil, nil, glossary_id: nil)
|
173
|
+
expect(request.options[:glossary_id]).to be_nil
|
180
174
|
end
|
181
175
|
|
182
|
-
it '
|
183
|
-
request =
|
176
|
+
it 'works with a string' do
|
177
|
+
request = described_class.new(api, nil, nil, nil, glossary_id: 'sample_id')
|
184
178
|
expect(request.options[:glossary_id]).to eq('sample_id')
|
185
179
|
end
|
186
180
|
end
|
187
181
|
|
188
182
|
context 'when using `formality` options' do
|
189
|
-
it '
|
190
|
-
request =
|
191
|
-
expect(request.options[:formality]).to
|
183
|
+
it 'works with a nil values' do
|
184
|
+
request = described_class.new(api, nil, nil, nil, formality: nil)
|
185
|
+
expect(request.options[:formality]).to be_nil
|
192
186
|
end
|
193
187
|
|
194
|
-
it '
|
195
|
-
request =
|
188
|
+
it 'works with a string' do
|
189
|
+
request = described_class.new(api, nil, nil, nil, formality: 'more')
|
196
190
|
expect(request.options[:formality]).to eq('more')
|
197
191
|
end
|
198
192
|
end
|
@@ -203,9 +197,9 @@ describe DeepL::Requests::Translate do
|
|
203
197
|
VCR.use_cassette('translate_texts') { example.call }
|
204
198
|
end
|
205
199
|
|
206
|
-
context '
|
207
|
-
it '
|
208
|
-
text =
|
200
|
+
context 'when performing a valid request with one text' do
|
201
|
+
it 'returns a text object' do
|
202
|
+
text = translate.request
|
209
203
|
|
210
204
|
expect(text).to be_a(DeepL::Resources::Text)
|
211
205
|
expect(text.text).to eq('Texto de muestra')
|
@@ -213,11 +207,11 @@ describe DeepL::Requests::Translate do
|
|
213
207
|
end
|
214
208
|
end
|
215
209
|
|
216
|
-
context '
|
210
|
+
context 'when performing a valid request with multiple texts' do
|
217
211
|
let(:text) { %w[Sample Word] }
|
218
212
|
|
219
|
-
it '
|
220
|
-
texts =
|
213
|
+
it 'returns a text object' do
|
214
|
+
texts = translate.request
|
221
215
|
|
222
216
|
expect(texts).to be_a(Array)
|
223
217
|
expect(texts.first.text).to eq('Muestra')
|
@@ -228,12 +222,12 @@ describe DeepL::Requests::Translate do
|
|
228
222
|
end
|
229
223
|
end
|
230
224
|
|
231
|
-
context '
|
225
|
+
context 'when performing a valid request with tag handling' do
|
232
226
|
let(:text) { '<p>Sample text</p>' }
|
233
227
|
let(:options) { { tag_handling: 'xml' } }
|
234
228
|
|
235
|
-
it '
|
236
|
-
text =
|
229
|
+
it 'returns a text object' do
|
230
|
+
text = translate.request
|
237
231
|
|
238
232
|
expect(text).to be_a(DeepL::Resources::Text)
|
239
233
|
expect(text.text).to eq('<p>Texto de muestra</p>')
|
@@ -241,12 +235,12 @@ describe DeepL::Requests::Translate do
|
|
241
235
|
end
|
242
236
|
end
|
243
237
|
|
244
|
-
context '
|
238
|
+
context 'when performing a valid request and passing a variable' do
|
245
239
|
let(:text) { 'Welcome and <code>Hello great World</code> Good Morning!' }
|
246
240
|
let(:options) { { tag_handling: 'xml', ignore_tags: %w[code span] } }
|
247
241
|
|
248
|
-
it '
|
249
|
-
text =
|
242
|
+
it 'returns a text object' do
|
243
|
+
text = translate.request
|
250
244
|
|
251
245
|
expect(text).to be_a(DeepL::Resources::Text)
|
252
246
|
expect(text.text).to eq('Bienvenido y <code>Hello great World</code> ¡Buenos días!')
|
@@ -254,7 +248,7 @@ describe DeepL::Requests::Translate do
|
|
254
248
|
end
|
255
249
|
end
|
256
250
|
|
257
|
-
context '
|
251
|
+
context 'when performing a valid request with an HTML document' do
|
258
252
|
let(:text) do
|
259
253
|
<<~XML
|
260
254
|
<document>
|
@@ -277,15 +271,15 @@ describe DeepL::Requests::Translate do
|
|
277
271
|
}
|
278
272
|
end
|
279
273
|
|
280
|
-
it '
|
281
|
-
text =
|
274
|
+
it 'returns a text object' do
|
275
|
+
text = translate.request
|
282
276
|
|
283
277
|
expect(text).to be_a(DeepL::Resources::Text)
|
284
278
|
expect(text.text).to eq(
|
285
279
|
<<~XML
|
286
280
|
<document>
|
287
281
|
<meta>
|
288
|
-
<title>
|
282
|
+
<title>Título de un documento</title>
|
289
283
|
</meta>
|
290
284
|
<content>
|
291
285
|
<par>Es la primera frase. Seguido de una segunda.</par>
|
@@ -298,44 +292,44 @@ describe DeepL::Requests::Translate do
|
|
298
292
|
end
|
299
293
|
end
|
300
294
|
|
301
|
-
context '
|
302
|
-
context '
|
295
|
+
context 'when performing a bad request' do
|
296
|
+
context 'when using an invalid token' do
|
303
297
|
let(:api) do
|
304
298
|
api = build_deepl_api
|
305
299
|
api.configuration.auth_key = 'invalid'
|
306
300
|
api
|
307
301
|
end
|
308
302
|
|
309
|
-
it '
|
310
|
-
expect {
|
303
|
+
it 'raises an unauthorized error' do
|
304
|
+
expect { translate.request }.to raise_error(DeepL::Exceptions::AuthorizationFailed)
|
311
305
|
end
|
312
306
|
end
|
313
307
|
|
314
|
-
context '
|
308
|
+
context 'when using an invalid text' do
|
315
309
|
let(:text) { nil }
|
316
310
|
|
317
|
-
it '
|
318
|
-
message = "
|
319
|
-
expect {
|
311
|
+
it 'raises a bad request error' do
|
312
|
+
message = "Invalid request: Expected 'text' parameter to be an array of strings"
|
313
|
+
expect { translate.request }.to raise_error(DeepL::Exceptions::BadRequest, message)
|
320
314
|
end
|
321
315
|
end
|
322
316
|
|
323
|
-
context '
|
317
|
+
context 'when using an invalid target language' do
|
324
318
|
let(:target_lang) { nil }
|
325
319
|
|
326
|
-
it '
|
320
|
+
it 'raises a bad request error' do
|
327
321
|
message = "Value for 'target_lang' not supported."
|
328
|
-
expect {
|
322
|
+
expect { translate.request }.to raise_error(DeepL::Exceptions::BadRequest, message)
|
329
323
|
end
|
330
324
|
end
|
331
325
|
end
|
332
326
|
|
333
|
-
context '
|
327
|
+
context 'when performing a request with too many texts' do
|
334
328
|
let(:text) { Array.new(10_000) { |i| "This is the sentence number #{i}" } }
|
335
329
|
|
336
|
-
it '
|
337
|
-
expect {
|
338
|
-
|
330
|
+
it 'raises a request entity too large error' do
|
331
|
+
expect { translate.request }.to raise_error(DeepL::Exceptions::RequestEntityTooLarge,
|
332
|
+
/request size has reached the supported limit/)
|
339
333
|
end
|
340
334
|
end
|
341
335
|
end
|
data/spec/requests/usage_spec.rb
CHANGED
@@ -1,16 +1,26 @@
|
|
1
|
+
# Copyright 2018 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Requests::Usage do
|
9
|
+
subject(:usage_req) { described_class.new(api, options) }
|
10
|
+
|
11
|
+
around do |tests|
|
12
|
+
tmp_env = replace_env_preserving_deepl_vars_except_mock_server
|
13
|
+
tests.call
|
14
|
+
ENV.replace(tmp_env)
|
15
|
+
end
|
16
|
+
|
6
17
|
let(:api) { build_deepl_api }
|
7
18
|
let(:options) { {} }
|
8
|
-
subject { DeepL::Requests::Usage.new(api, options) }
|
9
19
|
|
10
20
|
describe '#initialize' do
|
11
|
-
context '
|
12
|
-
it '
|
13
|
-
expect(
|
21
|
+
context 'when building a request' do
|
22
|
+
it 'creates a request object' do
|
23
|
+
expect(usage_req).to be_a(described_class)
|
14
24
|
end
|
15
25
|
end
|
16
26
|
end
|
@@ -20,9 +30,9 @@ describe DeepL::Requests::Usage do
|
|
20
30
|
VCR.use_cassette('usage') { example.call }
|
21
31
|
end
|
22
32
|
|
23
|
-
context '
|
24
|
-
it '
|
25
|
-
usage =
|
33
|
+
context 'when performing a valid request' do
|
34
|
+
it 'returns an usage object' do
|
35
|
+
usage = usage_req.request
|
26
36
|
|
27
37
|
expect(usage).to be_a(DeepL::Resources::Usage)
|
28
38
|
expect(usage.character_count).to be_a(Numeric)
|
@@ -1,9 +1,12 @@
|
|
1
|
+
# Copyright 2022 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Resources::Glossary do
|
6
|
-
subject do
|
9
|
+
subject(:glossary) do
|
7
10
|
described_class.new({
|
8
11
|
'glossary_id' => 'def3a26b-3e84-45b3-84ae-0c0aaf3525f7',
|
9
12
|
'name' => 'Mein Glossar',
|
@@ -16,19 +19,19 @@ describe DeepL::Resources::Glossary do
|
|
16
19
|
end
|
17
20
|
|
18
21
|
describe '#initialize' do
|
19
|
-
context '
|
20
|
-
it '
|
21
|
-
expect(
|
22
|
+
context 'when building a basic object' do
|
23
|
+
it 'creates a resource' do
|
24
|
+
expect(glossary).to be_a(described_class)
|
22
25
|
end
|
23
26
|
|
24
|
-
it '
|
25
|
-
expect(
|
26
|
-
expect(
|
27
|
-
expect(
|
28
|
-
expect(
|
29
|
-
expect(
|
30
|
-
expect(
|
31
|
-
expect(
|
27
|
+
it 'assigns the attributes' do
|
28
|
+
expect(glossary.id).to eq('def3a26b-3e84-45b3-84ae-0c0aaf3525f7')
|
29
|
+
expect(glossary.name).to eq('Mein Glossar')
|
30
|
+
expect(glossary.ready).to be(true)
|
31
|
+
expect(glossary.source_lang).to eq('EN')
|
32
|
+
expect(glossary.target_lang).to eq('DE')
|
33
|
+
expect(glossary.creation_time).to eq('2021-08-03T14:16:18.329Z')
|
34
|
+
expect(glossary.entry_count).to eq(1)
|
32
35
|
end
|
33
36
|
end
|
34
37
|
end
|
@@ -1,19 +1,22 @@
|
|
1
|
+
# Copyright 2022 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Resources::LanguagePair do
|
6
|
-
subject { described_class.new('en', 'de', nil, nil) }
|
9
|
+
subject(:language_pair) { described_class.new('en', 'de', nil, nil) }
|
7
10
|
|
8
11
|
describe '#initialize' do
|
9
|
-
context '
|
10
|
-
it '
|
11
|
-
expect(
|
12
|
+
context 'when building a basic object' do
|
13
|
+
it 'creates a resource' do
|
14
|
+
expect(language_pair).to be_a(described_class)
|
12
15
|
end
|
13
16
|
|
14
|
-
it '
|
15
|
-
expect(
|
16
|
-
expect(
|
17
|
+
it 'assigns the attributes' do
|
18
|
+
expect(language_pair.source_lang).to eq('en')
|
19
|
+
expect(language_pair.target_lang).to eq('de')
|
17
20
|
end
|
18
21
|
end
|
19
22
|
end
|
@@ -1,41 +1,44 @@
|
|
1
|
+
# Copyright 2021 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Resources::Language do
|
6
|
-
subject { described_class.new('EN', 'English', nil, nil, nil) }
|
9
|
+
subject(:language) { described_class.new('EN', 'English', nil, nil, nil) }
|
7
10
|
|
8
11
|
describe '#initialize' do
|
9
|
-
context '
|
10
|
-
it '
|
11
|
-
expect(
|
12
|
+
context 'when building a basic object' do
|
13
|
+
it 'creates a resource' do
|
14
|
+
expect(language).to be_a(described_class)
|
12
15
|
end
|
13
16
|
|
14
|
-
it '
|
15
|
-
expect(
|
16
|
-
expect(
|
17
|
+
it 'assigns the attributes' do
|
18
|
+
expect(language.code).to eq('EN')
|
19
|
+
expect(language.name).to eq('English')
|
17
20
|
end
|
18
21
|
|
19
|
-
it '
|
20
|
-
expect {
|
22
|
+
it 'does not define the supports formality method' do
|
23
|
+
expect { language.supports_formality? }.to raise_error(DeepL::Exceptions::NotSupported)
|
21
24
|
end
|
22
25
|
end
|
23
26
|
|
24
27
|
context 'when building a target language object' do
|
25
|
-
subject { described_class.new('EN', 'English', true, nil, nil) }
|
28
|
+
subject(:language) { described_class.new('EN', 'English', true, nil, nil) }
|
26
29
|
|
27
|
-
it '
|
28
|
-
expect(
|
30
|
+
it 'creates a resource' do
|
31
|
+
expect(language).to be_a(described_class)
|
29
32
|
end
|
30
33
|
|
31
|
-
it '
|
32
|
-
expect(
|
33
|
-
expect(
|
34
|
+
it 'assigns the attributes' do
|
35
|
+
expect(language.code).to eq('EN')
|
36
|
+
expect(language.name).to eq('English')
|
34
37
|
end
|
35
38
|
|
36
|
-
it '
|
37
|
-
expect {
|
38
|
-
expect(
|
39
|
+
it 'includes the supports formality method' do
|
40
|
+
expect { language.supports_formality? }.not_to raise_error
|
41
|
+
expect(language).to be_supports_formality
|
39
42
|
end
|
40
43
|
end
|
41
44
|
end
|
data/spec/resources/text_spec.rb
CHANGED
@@ -1,19 +1,22 @@
|
|
1
|
+
# Copyright 2018 Daniel Herzog
|
2
|
+
# Use of this source code is governed by an MIT
|
3
|
+
# license that can be found in the LICENSE.md file.
|
1
4
|
# frozen_string_literal: true
|
2
5
|
|
3
6
|
require 'spec_helper'
|
4
7
|
|
5
8
|
describe DeepL::Resources::Text do
|
6
|
-
subject { described_class.new('Target', 'es', nil, nil) }
|
9
|
+
subject(:text) { described_class.new('Target', 'es', nil, nil) }
|
7
10
|
|
8
11
|
describe '#initialize' do
|
9
|
-
context '
|
10
|
-
it '
|
11
|
-
expect(
|
12
|
+
context 'when building a basic object' do
|
13
|
+
it 'creates a resource' do
|
14
|
+
expect(text).to be_a(described_class)
|
12
15
|
end
|
13
16
|
|
14
|
-
it '
|
15
|
-
expect(
|
16
|
-
expect(
|
17
|
+
it 'assigns the attributes' do
|
18
|
+
expect(text.text).to eq('Target')
|
19
|
+
expect(text.detected_source_language).to eq('es')
|
17
20
|
end
|
18
21
|
end
|
19
22
|
end
|