A minor change for ProviderDiscovery and spec (#3543)
* Do not default the format in ProviderDiscovery The format should be determined when discovering, as it is in the current implementation, and it is a flaw if it is not determined. * Spec ProviderDiscoverymaster
parent
c7af8cbc90
commit
e674608d10
@ -0,0 +1,7 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<link href=':' rel='alternate' type='application/xml+oembed'> |
||||
</head> |
||||
<body></body> |
||||
</html> |
@ -0,0 +1,7 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<link href='https://host/provider.json' rel='alternate' type='application/json+oembed'> |
||||
</head> |
||||
<body></body> |
||||
</html> |
@ -0,0 +1,8 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<link href='https://host/provider.json' rel='alternate' type='application/json+oembed'> |
||||
<link href='https://host/provider.xml' rel='alternate' type='application/xml+oembed'> |
||||
</head> |
||||
<body></body> |
||||
</html> |
@ -0,0 +1,5 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head></head> |
||||
<body></body> |
||||
</html> |
@ -0,0 +1,7 @@ |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<link href='https://host/provider.xml' rel='alternate' type='application/xml+oembed'> |
||||
</head> |
||||
<body></body> |
||||
</html> |
@ -0,0 +1,118 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
require 'rails_helper' |
||||
|
||||
describe ProviderDiscovery do |
||||
describe 'discover_provider' do |
||||
context 'when status code is 200 and MIME type is text/html' do |
||||
context 'Both of JSON and XML provider are discoverable' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_json_xml.html') |
||||
) |
||||
end |
||||
|
||||
it 'returns new OEmbed::Provider for JSON provider if :format option is set to :json' do |
||||
provider = ProviderDiscovery.discover_provider('https://host/oembed.html', format: :json) |
||||
expect(provider.endpoint).to eq 'https://host/provider.json' |
||||
expect(provider.format).to eq :json |
||||
end |
||||
|
||||
it 'returns new OEmbed::Provider for XML provider if :format option is set to :xml' do |
||||
provider = ProviderDiscovery.discover_provider('https://host/oembed.html', format: :xml) |
||||
expect(provider.endpoint).to eq 'https://host/provider.xml' |
||||
expect(provider.format).to eq :xml |
||||
end |
||||
end |
||||
|
||||
context 'JSON provider is discoverable while XML provider is not' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_json.html') |
||||
) |
||||
end |
||||
|
||||
it 'returns new OEmbed::Provider for JSON provider' do |
||||
provider = ProviderDiscovery.discover_provider('https://host/oembed.html') |
||||
expect(provider.endpoint).to eq 'https://host/provider.json' |
||||
expect(provider.format).to eq :json |
||||
end |
||||
end |
||||
|
||||
context 'XML provider is discoverable while JSON provider is not' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_xml.html') |
||||
) |
||||
end |
||||
|
||||
it 'returns new OEmbed::Provider for XML provider' do |
||||
provider = ProviderDiscovery.discover_provider('https://host/oembed.html') |
||||
expect(provider.endpoint).to eq 'https://host/provider.xml' |
||||
expect(provider.format).to eq :xml |
||||
end |
||||
end |
||||
|
||||
context 'Invalid XML provider is discoverable while JSON provider is not' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_invalid_xml.html') |
||||
) |
||||
end |
||||
|
||||
it 'raises OEmbed::NotFound' do |
||||
expect { ProviderDiscovery.discover_provider('https://host/oembed.html') }.to raise_error OEmbed::NotFound |
||||
end |
||||
end |
||||
|
||||
context 'Neither of JSON and XML provider is discoverable' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_undiscoverable.html') |
||||
) |
||||
end |
||||
|
||||
it 'raises OEmbed::NotFound' do |
||||
expect { ProviderDiscovery.discover_provider('https://host/oembed.html') }.to raise_error OEmbed::NotFound |
||||
end |
||||
end |
||||
end |
||||
|
||||
context 'when status code is not 200' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 400, |
||||
headers: { 'Content-Type': 'text/html' }, |
||||
body: request_fixture('oembed_xml.html') |
||||
) |
||||
end |
||||
|
||||
it 'raises OEmbed::NotFound' do |
||||
expect { ProviderDiscovery.discover_provider('https://host/oembed.html') }.to raise_error OEmbed::NotFound |
||||
end |
||||
end |
||||
|
||||
context 'when MIME type is not text/html' do |
||||
before do |
||||
stub_request(:get, 'https://host/oembed.html').to_return( |
||||
status: 200, |
||||
body: request_fixture('oembed_xml.html') |
||||
) |
||||
end |
||||
|
||||
it 'raises OEmbed::NotFound' do |
||||
expect { ProviderDiscovery.discover_provider('https://host/oembed.html') }.to raise_error OEmbed::NotFound |
||||
end |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue