Count all URLs in text as 23 characters flat, do not count domain part of usernames (#4427)
* Count all URLs in text as 23 characters flat, do not count domain part of usernames * Add new status text counting logic to web UImaster
parent
634b71ed1d
commit
53b2b1b238
@ -0,0 +1,7 @@ |
||||
const urlPlaceholder = 'xxxxxxxxxxxxxxxxxxxxxxx'; |
||||
|
||||
export function countableText(inputText) { |
||||
return inputText |
||||
.replace(/https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,6}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)/g, urlPlaceholder) |
||||
.replace(/(?:^|[^\/\w])@(([a-z0-9_]+)@[a-z0-9\.\-]+)/ig, '@$2'); |
||||
}; |
@ -0,0 +1,44 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
require 'rails_helper' |
||||
|
||||
describe StatusLengthValidator do |
||||
describe '#validate' do |
||||
it 'does not add errors onto remote statuses' |
||||
it 'does not add errors onto local reblogs' |
||||
|
||||
it 'adds an error when content warning is over 500 characters' do |
||||
status = double(spoiler_text: 'a' * 520, text: '', errors: double(add: nil), local?: true, reblog?: false) |
||||
subject.validate(status) |
||||
expect(status.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error when text is over 500 characters' do |
||||
status = double(spoiler_text: '', text: 'a' * 520, errors: double(add: nil), local?: true, reblog?: false) |
||||
subject.validate(status) |
||||
expect(status.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'adds an error when text and content warning are over 500 characters total' do |
||||
status = double(spoiler_text: 'a' * 250, text: 'b' * 251, errors: double(add: nil), local?: true, reblog?: false) |
||||
subject.validate(status) |
||||
expect(status.errors).to have_received(:add) |
||||
end |
||||
|
||||
it 'counts URLs as 23 characters flat' do |
||||
text = ('a' * 476) + " http://#{'b' * 30}.com/example" |
||||
status = double(spoiler_text: '', text: text, errors: double(add: nil), local?: true, reblog?: false) |
||||
|
||||
subject.validate(status) |
||||
expect(status.errors).to_not have_received(:add) |
||||
end |
||||
|
||||
it 'counts only the front part of remote usernames' do |
||||
text = ('a' * 475) + " @alice@#{'b' * 30}.com" |
||||
status = double(spoiler_text: '', text: text, errors: double(add: nil), local?: true, reblog?: false) |
||||
|
||||
subject.validate(status) |
||||
expect(status.errors).to_not have_received(:add) |
||||
end |
||||
end |
||||
end |
Loading…
Reference in new issue