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
This commit is contained in:
parent
3830c0b741
commit
da2143b308
|
@ -157,7 +157,7 @@ class ActivityPub::Activity::Create < ActivityPub::Activity
|
||||||
return if tag['name'].blank?
|
return if tag['name'].blank?
|
||||||
|
|
||||||
Tag.find_or_create_by_names(tag['name']) do |hashtag|
|
Tag.find_or_create_by_names(tag['name']) do |hashtag|
|
||||||
@tags << hashtag unless @tags.include?(hashtag)
|
@tags << hashtag unless @tags.include?(hashtag) || !hashtag.valid?
|
||||||
end
|
end
|
||||||
rescue ActiveRecord::RecordInvalid
|
rescue ActiveRecord::RecordInvalid
|
||||||
nil
|
nil
|
||||||
|
|
|
@ -117,7 +117,7 @@ class Tag < ApplicationRecord
|
||||||
class << self
|
class << self
|
||||||
def find_or_create_by_names(name_or_names)
|
def find_or_create_by_names(name_or_names)
|
||||||
Array(name_or_names).map(&method(:normalize)).uniq { |str| str.mb_chars.downcase.to_s }.map do |normalized_name|
|
Array(name_or_names).map(&method(:normalize)).uniq { |str| str.mb_chars.downcase.to_s }.map do |normalized_name|
|
||||||
tag = matching_name(normalized_name).first || create!(name: normalized_name)
|
tag = matching_name(normalized_name).first || create(name: normalized_name)
|
||||||
|
|
||||||
yield tag if block_given?
|
yield tag if block_given?
|
||||||
|
|
||||||
|
|
43
spec/controllers/settings/featured_tags_controller_spec.rb
Normal file
43
spec/controllers/settings/featured_tags_controller_spec.rb
Normal file
|
@ -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
|
|
@ -378,6 +378,28 @@ RSpec.describe ActivityPub::Activity::Create do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with hashtags invalid name' do
|
||||||
|
let(:object_json) do
|
||||||
|
{
|
||||||
|
id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
|
||||||
|
type: 'Note',
|
||||||
|
content: 'Lorem ipsum',
|
||||||
|
tag: [
|
||||||
|
{
|
||||||
|
type: 'Hashtag',
|
||||||
|
href: 'http://example.com/blah',
|
||||||
|
name: 'foo, #eh !',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'creates status' do
|
||||||
|
status = sender.statuses.first
|
||||||
|
expect(status).to_not be_nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'with emojis' do
|
context 'with emojis' do
|
||||||
let(:object_json) do
|
let(:object_json) do
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue