diff options
author | Claire <claire.github-309c@sitedethib.com> | 2021-03-11 18:04:18 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-11 18:04:18 +0100 |
commit | 935e376078fa8716ea5475a45602301fd3d6b081 (patch) | |
tree | 656d328e630e1a4fa11e9853203f4dba8e29cb71 /spec/validators/note_length_validator_spec.rb | |
parent | 318efa49de8d0b9615427c99ab07c591230dfd80 (diff) | |
parent | 1b6a21e6bc7ec9c0d5bb3daf2646d003ba90404c (diff) |
Merge pull request #1510 from ClearlyClaire/glitch-soc/merge-upstream
Merge upstream changes
Diffstat (limited to 'spec/validators/note_length_validator_spec.rb')
-rw-r--r-- | spec/validators/note_length_validator_spec.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/spec/validators/note_length_validator_spec.rb b/spec/validators/note_length_validator_spec.rb new file mode 100644 index 000000000..6e9b4e132 --- /dev/null +++ b/spec/validators/note_length_validator_spec.rb @@ -0,0 +1,33 @@ +# frozen_string_literal: true + +require 'rails_helper' + +describe NoteLengthValidator do + subject { NoteLengthValidator.new(attributes: { note: true }, maximum: 500) } + + describe '#validate' do + it 'adds an error when text is over 500 characters' do + text = 'a' * 520 + account = double(note: text, errors: double(add: nil)) + + subject.validate_each(account, 'note', text) + expect(account.errors).to have_received(:add) + end + + it 'counts URLs as 23 characters flat' do + text = ('a' * 476) + " http://#{'b' * 30}.com/example" + account = double(note: text, errors: double(add: nil)) + + subject.validate_each(account, 'note', text) + expect(account.errors).to_not have_received(:add) + end + + it 'does not count non-autolinkable URLs as 23 characters flat' do + text = ('a' * 476) + "http://#{'b' * 30}.com/example" + account = double(note: text, errors: double(add: nil)) + + subject.validate_each(account, 'note', text) + expect(account.errors).to have_received(:add) + end + end +end |