Improve handling of HTTP_ACCEPT for webfinger (#2008)
This change includes: - Improve the spec coverage for incoming request to the webfinger action - For requests without an accept header (ie, what a browser might look like), return a JSON response. - For requests with an explicit format of xml or json, return that format. - For requests using an accept header, return that format. Also adds failing spec showing webfinger does not return xml, which covers the issue described in: https://github.com/tootsuite/mastodon/issues/1983master
parent
3399dd7a66
commit
21a767dcfa
@ -1,33 +1,48 @@ |
|||||||
require "rails_helper" |
require 'rails_helper' |
||||||
|
|
||||||
describe "The webfinger route" do |
describe 'The webfinger route' do |
||||||
let(:alice) { Fabricate(:account, username: 'alice') } |
let(:alice) { Fabricate(:account, username: 'alice') } |
||||||
|
|
||||||
describe "requested without accepts headers" do |
describe 'requested with standard accepts headers' do |
||||||
it "returns a json response" do |
it 'returns a json response' do |
||||||
get webfinger_url, params: { resource: alice.to_webfinger_s } |
get webfinger_url(resource: alice.to_webfinger_s) |
||||||
|
|
||||||
expect(response).to have_http_status(:success) |
expect(response).to have_http_status(:success) |
||||||
expect(response.content_type).to eq "application/jrd+json" |
expect(response.content_type).to eq 'application/jrd+json' |
||||||
end |
end |
||||||
end |
end |
||||||
|
|
||||||
describe "requested with html in accepts headers" do |
describe 'asking for xml format' do |
||||||
it "returns a json response" do |
it 'returns an xml response for xml format' do |
||||||
headers = { 'HTTP_ACCEPT' => 'text/html' } |
get webfinger_url(resource: alice.to_webfinger_s, format: :xml) |
||||||
get webfinger_url, params: { resource: alice.to_webfinger_s }, headers: headers |
|
||||||
|
expect(response).to have_http_status(:success) |
||||||
|
expect(response.content_type).to eq 'application/xrd+xml' |
||||||
|
end |
||||||
|
|
||||||
|
it 'returns an xml response for xml accept header' do |
||||||
|
headers = { 'HTTP_ACCEPT' => 'application/xrd+xml' } |
||||||
|
get webfinger_url(resource: alice.to_webfinger_s), headers: headers |
||||||
|
|
||||||
expect(response).to have_http_status(:success) |
expect(response).to have_http_status(:success) |
||||||
expect(response.content_type).to eq "application/jrd+json" |
expect(response.content_type).to eq 'application/xrd+xml' |
||||||
end |
end |
||||||
end |
end |
||||||
|
|
||||||
describe "requested with xml format" do |
describe 'asking for json format' do |
||||||
it "returns an xml response" do |
it 'returns a json response for json format' do |
||||||
get webfinger_url(resource: alice.to_webfinger_s, format: :xml) |
get webfinger_url(resource: alice.to_webfinger_s, format: :json) |
||||||
|
|
||||||
|
expect(response).to have_http_status(:success) |
||||||
|
expect(response.content_type).to eq 'application/jrd+json' |
||||||
|
end |
||||||
|
|
||||||
|
it 'returns a json response for json accept header' do |
||||||
|
headers = { 'HTTP_ACCEPT' => 'application/jrd+json' } |
||||||
|
get webfinger_url(resource: alice.to_webfinger_s), headers: headers |
||||||
|
|
||||||
expect(response).to have_http_status(:success) |
expect(response).to have_http_status(:success) |
||||||
expect(response.content_type).to eq "application/xrd+xml" |
expect(response.content_type).to eq 'application/jrd+json' |
||||||
end |
end |
||||||
end |
end |
||||||
end |
end |
||||||
|
Loading…
Reference in new issue