FIX: Unicode aware text sentinel (#4301)
* FIX: Handle unicode text on Text Sentinel Uses active_support to properly handle unicode text * Adds test cases to unicode Text Sentinel
This commit is contained in:
parent
166d753bd3
commit
5915929166
|
@ -1,3 +1,7 @@
|
||||||
|
# Whe use ActiveSupport mb_chars from here to properly support non ascii downcase
|
||||||
|
# TODO remove when ruby 2.4 lands
|
||||||
|
require 'active_support/core_ext/string/multibyte'
|
||||||
|
|
||||||
#
|
#
|
||||||
# Given a string, tell us whether or not is acceptable.
|
# Given a string, tell us whether or not is acceptable.
|
||||||
#
|
#
|
||||||
|
@ -72,8 +76,8 @@ class TextSentinel
|
||||||
|
|
||||||
|
|
||||||
def seems_quiet?
|
def seems_quiet?
|
||||||
# We don't allow all upper case content in english
|
# We don't allow all upper case content
|
||||||
SiteSetting.allow_uppercase_posts || not((@text =~ /[A-Z]+/) && !(@text =~ /[^[:ascii:]]/) && (@text == @text.upcase))
|
SiteSetting.allow_uppercase_posts || @text == @text.mb_chars.downcase.to_s || @text != @text.mb_chars.upcase.to_s
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -49,7 +49,7 @@ describe TextSentinel do
|
||||||
[ 'evil trout is evil',
|
[ 'evil trout is evil',
|
||||||
"去年十社會警告",
|
"去年十社會警告",
|
||||||
"P.S. Пробирочка очень толковая и весьма умная, так что не обнимайтесь.",
|
"P.S. Пробирочка очень толковая и весьма умная, так что не обнимайтесь.",
|
||||||
"LOOK: 去年十社會警告"
|
"Look: 去年十社會警告"
|
||||||
].each do |valid_body|
|
].each do |valid_body|
|
||||||
it "handles a valid body in a private message" do
|
it "handles a valid body in a private message" do
|
||||||
expect(TextSentinel.body_sentinel(valid_body, private_message: true)).to be_valid
|
expect(TextSentinel.body_sentinel(valid_body, private_message: true)).to be_valid
|
||||||
|
@ -74,6 +74,10 @@ describe TextSentinel do
|
||||||
expect(TextSentinel.new(valid_string.upcase)).not_to be_valid
|
expect(TextSentinel.new(valid_string.upcase)).not_to be_valid
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "doesn't allow all caps foreign topics" do
|
||||||
|
expect(TextSentinel.new('É COM VOCÊ LOMBARDIAM. MA VEJAM SÓ, VEJAM SÓ. VALENDO UM MILHÃO DE REAISAMMM. MA VALE DÉRREAISAM?')).not_to be_valid
|
||||||
|
end
|
||||||
|
|
||||||
it "allows all caps topics when loud posts are allowed" do
|
it "allows all caps topics when loud posts are allowed" do
|
||||||
SiteSetting.stubs(:allow_uppercase_posts).returns(true)
|
SiteSetting.stubs(:allow_uppercase_posts).returns(true)
|
||||||
expect(TextSentinel.new(valid_string.upcase)).to be_valid
|
expect(TextSentinel.new(valid_string.upcase)).to be_valid
|
||||||
|
|
Loading…
Reference in New Issue