2017-07-29 00:06:29 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe StatusLengthValidator do
|
|
|
|
describe '#validate' do
|
2018-12-28 08:18:47 +01:00
|
|
|
it 'does not add errors onto remote statuses' do
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, local?: false)
|
2023-11-07 10:46:28 +01:00
|
|
|
allow(status).to receive(:errors)
|
|
|
|
|
2018-12-28 08:18:47 +01:00
|
|
|
subject.validate(status)
|
2023-11-07 10:46:28 +01:00
|
|
|
|
|
|
|
expect(status).to_not have_received(:errors)
|
2018-12-28 08:18:47 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not add errors onto local reblogs' do
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, local?: false, reblog?: true)
|
2023-11-07 10:46:28 +01:00
|
|
|
allow(status).to receive(:errors)
|
|
|
|
|
2018-12-28 08:18:47 +01:00
|
|
|
subject.validate(status)
|
2023-11-07 10:46:28 +01:00
|
|
|
|
|
|
|
expect(status).to_not have_received(:errors)
|
2018-12-28 08:18:47 +01:00
|
|
|
end
|
2017-07-29 00:06:29 +02:00
|
|
|
|
2017-08-28 04:12:10 +02:00
|
|
|
it 'adds an error when content warning is over MAX_CHARS characters' do
|
|
|
|
chars = StatusLengthValidator::MAX_CHARS + 1
|
2023-06-25 12:02:52 +02:00
|
|
|
status = instance_double(Status, spoiler_text: 'a' * chars, text: '', errors: activemodel_errors, local?: true, reblog?: false)
|
2017-07-29 00:06:29 +02:00
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
|
|
|
|
2017-08-28 04:12:10 +02:00
|
|
|
it 'adds an error when text is over MAX_CHARS characters' do
|
|
|
|
chars = StatusLengthValidator::MAX_CHARS + 1
|
2023-06-25 12:02:52 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: 'a' * chars, errors: activemodel_errors, local?: true, reblog?: false)
|
2017-07-29 00:06:29 +02:00
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
|
|
|
|
2017-08-28 04:12:10 +02:00
|
|
|
it 'adds an error when text and content warning are over MAX_CHARS characters total' do
|
|
|
|
chars1 = 20
|
|
|
|
chars2 = StatusLengthValidator::MAX_CHARS + 1 - chars1
|
2023-06-25 12:02:52 +02:00
|
|
|
status = instance_double(Status, spoiler_text: 'a' * chars1, text: 'b' * chars2, errors: activemodel_errors, local?: true, reblog?: false)
|
2017-07-29 00:06:29 +02:00
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'counts URLs as 23 characters flat' do
|
2017-08-28 04:12:10 +02:00
|
|
|
chars = StatusLengthValidator::MAX_CHARS - 1 - 23
|
|
|
|
text = ('a' * chars) + " http://#{'b' * 30}.com/example"
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: text, errors: activemodel_errors, local?: true, reblog?: false)
|
2017-07-29 00:06:29 +02:00
|
|
|
|
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to_not have_received(:add)
|
|
|
|
end
|
|
|
|
|
2021-03-02 12:02:56 +01:00
|
|
|
it 'does not count non-autolinkable URLs as 23 characters flat' do
|
|
|
|
text = ('a' * 476) + "http://#{'b' * 30}.com/example"
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: text, errors: activemodel_errors, local?: true, reblog?: false)
|
2021-03-02 12:02:56 +01:00
|
|
|
|
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
|
|
|
|
2022-03-30 14:46:03 +02:00
|
|
|
it 'does not count overly long URLs as 23 characters flat' do
|
|
|
|
text = "http://example.com/valid?#{'#foo?' * 1000}"
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: text, errors: activemodel_errors, local?: true, reblog?: false)
|
2022-03-30 14:46:03 +02:00
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
|
|
|
|
2017-07-29 00:06:29 +02:00
|
|
|
it 'counts only the front part of remote usernames' do
|
2017-08-28 04:12:10 +02:00
|
|
|
username = '@alice'
|
|
|
|
chars = StatusLengthValidator::MAX_CHARS - 1 - username.length
|
2023-04-09 11:25:30 +02:00
|
|
|
text = ('a' * chars) + " #{username}@#{'b' * 30}.com"
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: text, errors: activemodel_errors, local?: true, reblog?: false)
|
2017-07-29 00:06:29 +02:00
|
|
|
|
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to_not have_received(:add)
|
|
|
|
end
|
2022-03-30 14:46:03 +02:00
|
|
|
|
|
|
|
it 'does count both parts of remote usernames for overly long domains' do
|
|
|
|
text = "@alice@#{'b' * 500}.com"
|
2023-06-22 14:55:22 +02:00
|
|
|
status = instance_double(Status, spoiler_text: '', text: text, errors: activemodel_errors, local?: true, reblog?: false)
|
2022-03-30 14:46:03 +02:00
|
|
|
|
|
|
|
subject.validate(status)
|
|
|
|
expect(status.errors).to have_received(:add)
|
|
|
|
end
|
2017-07-29 00:06:29 +02:00
|
|
|
end
|
2023-06-22 14:55:22 +02:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def activemodel_errors
|
|
|
|
instance_double(ActiveModel::Errors, add: nil)
|
|
|
|
end
|
2017-07-29 00:06:29 +02:00
|
|
|
end
|