Convert tags
controller spec to system and request specs (#31708)
This commit is contained in:
parent
0437dd9e77
commit
219458d7d4
|
@ -1,45 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'rails_helper'
|
|
||||||
|
|
||||||
RSpec.describe TagsController do
|
|
||||||
render_views
|
|
||||||
|
|
||||||
describe 'GET #show' do
|
|
||||||
let(:format) { 'html' }
|
|
||||||
let(:tag) { Fabricate(:tag, name: 'test') }
|
|
||||||
let(:tag_name) { tag&.name }
|
|
||||||
|
|
||||||
before do
|
|
||||||
get :show, params: { id: tag_name, format: format }
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when tag exists' do
|
|
||||||
context 'when requested as HTML' do
|
|
||||||
it 'returns http success' do
|
|
||||||
expect(response).to have_http_status(200)
|
|
||||||
end
|
|
||||||
|
|
||||||
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when requested as JSON' do
|
|
||||||
let(:format) { 'json' }
|
|
||||||
|
|
||||||
it 'returns http success' do
|
|
||||||
expect(response).to have_http_status(200)
|
|
||||||
end
|
|
||||||
|
|
||||||
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'when tag does not exist' do
|
|
||||||
let(:tag_name) { 'hoge' }
|
|
||||||
|
|
||||||
it 'returns http not found' do
|
|
||||||
expect(response).to have_http_status(404)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
59
spec/requests/tags_spec.rb
Normal file
59
spec/requests/tags_spec.rb
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe 'Tags' do
|
||||||
|
describe 'GET /tags/:id' do
|
||||||
|
context 'when tag exists' do
|
||||||
|
let(:tag) { Fabricate :tag }
|
||||||
|
|
||||||
|
context 'with HTML format' do
|
||||||
|
# TODO: Convert the cacheable response shared example into a matcher,
|
||||||
|
# remove this example, rely on system spec (which should use matcher)
|
||||||
|
before { get tag_path(tag) }
|
||||||
|
|
||||||
|
it 'returns http success' do
|
||||||
|
expect(response)
|
||||||
|
.to have_http_status(200)
|
||||||
|
end
|
||||||
|
|
||||||
|
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with JSON format' do
|
||||||
|
before { get tag_path(tag, format: :json) }
|
||||||
|
|
||||||
|
it 'returns http success' do
|
||||||
|
expect(response)
|
||||||
|
.to have_http_status(200)
|
||||||
|
expect(response.content_type)
|
||||||
|
.to start_with('application/activity+json')
|
||||||
|
end
|
||||||
|
|
||||||
|
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with RSS format' do
|
||||||
|
before { get tag_path(tag, format: :rss) }
|
||||||
|
|
||||||
|
it 'returns http success' do
|
||||||
|
expect(response)
|
||||||
|
.to have_http_status(200)
|
||||||
|
expect(response.content_type)
|
||||||
|
.to start_with('application/rss+xml')
|
||||||
|
end
|
||||||
|
|
||||||
|
it_behaves_like 'cacheable response', expects_vary: 'Accept, Accept-Language, Cookie'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when tag does not exist' do
|
||||||
|
before { get tag_path('missing') }
|
||||||
|
|
||||||
|
it 'returns http not found' do
|
||||||
|
expect(response)
|
||||||
|
.to have_http_status(404)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
16
spec/system/tags_spec.rb
Normal file
16
spec/system/tags_spec.rb
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe 'Tags' do
|
||||||
|
describe 'Viewing a tag' do
|
||||||
|
let(:tag) { Fabricate(:tag, name: 'test') }
|
||||||
|
|
||||||
|
it 'visits the tag page and renders the web app' do
|
||||||
|
visit tag_path(tag)
|
||||||
|
|
||||||
|
expect(page)
|
||||||
|
.to have_css('noscript', text: /Mastodon/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue