Fixes featured hashtag setting page erroring out instead of rejecting invalid tags (#12436)
* Revert "Fix ignoring whole status because of one invalid hashtag (#11621)"
This reverts commit dff46b260b
.
* Fix statuses being rejected because of invalid hashtag names
* Add spec for invalid hashtag names in statuses
* Add test for featured tags controller
master
parent
3830c0b741
commit
da2143b308
@ -0,0 +1,43 @@ |
||||
require 'rails_helper' |
||||
|
||||
describe Settings::FeaturedTagsController do |
||||
render_views |
||||
|
||||
shared_examples 'authenticate user' do |
||||
it 'redirects to sign_in page' do |
||||
is_expected.to redirect_to new_user_session_path |
||||
end |
||||
end |
||||
|
||||
describe 'POST #create' do |
||||
context 'when user is not sign in' do |
||||
subject { post :create } |
||||
|
||||
it_behaves_like 'authenticate user' |
||||
end |
||||
|
||||
context 'when user is sign in' do |
||||
subject { post :create, params: { featured_tag: params } } |
||||
|
||||
let(:user) { Fabricate(:user, password: '12345678') } |
||||
|
||||
before { sign_in user, scope: :user } |
||||
|
||||
context 'when parameter is valid' do |
||||
let(:params) { { name: 'test' } } |
||||
|
||||
it 'creates featured tag' do |
||||
expect { subject }.to change { user.account.featured_tags.count }.by(1) |
||||
end |
||||
end |
||||
|
||||
context 'when parameter is invalid' do |
||||
let(:params) { { name: 'test, #foo !bleh' } } |
||||
|
||||
it 'renders new' do |
||||
expect(subject).to render_template :index |
||||
end |
||||
end |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue