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