gearheads
/
mastodon
Archived
2
0
Fork 0

Fix Admin::TagsController#unhide (#9481)

gh/stable
ysksn 2018-12-11 05:37:38 +09:00 committed by Eugen Rochko
parent ae3d2f446a
commit 361818e931
2 changed files with 72 additions and 1 deletions

View File

@ -18,7 +18,7 @@ module Admin
def unhide def unhide
authorize @tag, :unhide? authorize @tag, :unhide?
@tag.account_tag_stat.update!(hidden: true) @tag.account_tag_stat.update!(hidden: false)
redirect_to admin_tags_path(@filter_params) redirect_to admin_tags_path(@filter_params)
end end

View File

@ -0,0 +1,71 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe Admin::TagsController, type: :controller do
render_views
before do
sign_in Fabricate(:user, admin: true)
end
describe 'GET #index' do
before do
account_tag_stat = Fabricate(:tag).account_tag_stat
account_tag_stat.update(hidden: hidden, accounts_count: 1)
get :index, params: { hidden: hidden }
end
context 'with hidden tags' do
let(:hidden) { true }
it 'returns status 200' do
expect(response).to have_http_status(200)
end
end
context 'without hidden tags' do
let(:hidden) { false }
it 'returns status 200' do
expect(response).to have_http_status(200)
end
end
end
describe 'POST #hide' do
let(:tag) { Fabricate(:tag) }
before do
tag.account_tag_stat.update(hidden: false)
post :hide, params: { id: tag.id }
end
it 'hides tag' do
tag.reload
expect(tag).to be_hidden
end
it 'redirects to admin_tags_path' do
expect(response).to redirect_to(admin_tags_path(controller.instance_variable_get(:@filter_params)))
end
end
describe 'POST #unhide' do
let(:tag) { Fabricate(:tag) }
before do
tag.account_tag_stat.update(hidden: true)
post :unhide, params: { id: tag.id }
end
it 'unhides tag' do
tag.reload
expect(tag).not_to be_hidden
end
it 'redirects to admin_tags_path' do
expect(response).to redirect_to(admin_tags_path(controller.instance_variable_get(:@filter_params)))
end
end
end