summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatt Jankowski <matt@jankowski.online>2023-11-08 09:43:17 -0500
committerGitHub <noreply@github.com>2023-11-08 14:43:17 +0000
commit4329616c53c8fdcc3e3cc7e0e27f8292e5386f31 (patch)
tree113a96dc353ace14d819e6c60c5fbe256c2436aa
parentc73d5a6075d6a6ef9cbfc84e34015603d5126982 (diff)
Ignore block result of `send` method and remove `rubocop:disable` in deepl spec (#27741)
-rw-r--r--spec/lib/translation_service/deepl_spec.rb39
1 files changed, 19 insertions, 20 deletions
diff --git a/spec/lib/translation_service/deepl_spec.rb b/spec/lib/translation_service/deepl_spec.rb
index 5a1d0f094a8..4797a3dc638 100644
--- a/spec/lib/translation_service/deepl_spec.rb
+++ b/spec/lib/translation_service/deepl_spec.rb
@@ -8,12 +8,14 @@ RSpec.describe TranslationService::DeepL do
let(:plan) { 'advanced' }
before do
- stub_request(:get, 'https://api.deepl.com/v2/languages?type=source').to_return(
- body: '[{"language":"EN","name":"English"},{"language":"UK","name":"Ukrainian"}]'
- )
- stub_request(:get, 'https://api.deepl.com/v2/languages?type=target').to_return(
- body: '[{"language":"EN-GB","name":"English (British)"},{"language":"ZH","name":"Chinese"}]'
- )
+ %w(api-free.deepl.com api.deepl.com).each do |host|
+ stub_request(:get, "https://#{host}/v2/languages?type=source").to_return(
+ body: '[{"language":"EN","name":"English"},{"language":"UK","name":"Ukrainian"}]'
+ )
+ stub_request(:get, "https://#{host}/v2/languages?type=target").to_return(
+ body: '[{"language":"EN-GB","name":"English (British)"},{"language":"ZH","name":"Chinese"}]'
+ )
+ end
end
describe '#translate' do
@@ -73,28 +75,25 @@ RSpec.describe TranslationService::DeepL do
end
end
- describe '#request' do
+ describe 'the paid and free plan api hostnames' do
before do
- stub_request(:any, //)
- # rubocop:disable Lint/EmptyBlock
- service.send(:request, :get, '/v2/languages') { |res| }
- # rubocop:enable Lint/EmptyBlock
+ service.languages
end
- it 'uses paid plan base URL' do
- expect(a_request(:get, 'https://api.deepl.com/v2/languages')).to have_been_made.once
+ context 'without a plan set' do
+ it 'uses paid plan base URL and sends an API key' do
+ expect(a_request(:get, 'https://api.deepl.com/v2/languages?type=source').with(headers: { Authorization: 'DeepL-Auth-Key my-api-key' })).to have_been_made.once
+ expect(a_request(:get, 'https://api.deepl.com/v2/languages?type=target').with(headers: { Authorization: 'DeepL-Auth-Key my-api-key' })).to have_been_made.once
+ end
end
- context 'with free plan' do
+ context 'with the free plan' do
let(:plan) { 'free' }
- it 'uses free plan base URL' do
- expect(a_request(:get, 'https://api-free.deepl.com/v2/languages')).to have_been_made.once
+ it 'uses free plan base URL and sends an API key' do
+ expect(a_request(:get, 'https://api-free.deepl.com/v2/languages?type=source').with(headers: { Authorization: 'DeepL-Auth-Key my-api-key' })).to have_been_made.once
+ expect(a_request(:get, 'https://api-free.deepl.com/v2/languages?type=target').with(headers: { Authorization: 'DeepL-Auth-Key my-api-key' })).to have_been_made.once
end
end
-
- it 'sends API key' do
- expect(a_request(:get, 'https://api.deepl.com/v2/languages').with(headers: { Authorization: 'DeepL-Auth-Key my-api-key' })).to have_been_made.once
- end
end
end