mirror of
https://github.com/mastodon/mastodon.git
synced 2025-05-07 12:16:14 +00:00

Some checks are pending
Check i18n / check-i18n (push) Waiting to run
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (ruby) (push) Waiting to run
Check formatting / lint (push) Waiting to run
CSS Linting / lint (push) Waiting to run
JavaScript Linting / lint (push) Waiting to run
Ruby Linting / lint (push) Waiting to run
JavaScript Testing / test (push) Waiting to run
Historical data migration test / test (14-alpine) (push) Waiting to run
Historical data migration test / test (15-alpine) (push) Waiting to run
Historical data migration test / test (16-alpine) (push) Waiting to run
Historical data migration test / test (17-alpine) (push) Waiting to run
Ruby Testing / build (production) (push) Waiting to run
Ruby Testing / build (test) (push) Waiting to run
Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
Ruby Testing / test (3.2) (push) Blocked by required conditions
Ruby Testing / test (3.3) (push) Blocked by required conditions
Ruby Testing / Libvips tests (.ruby-version) (push) Blocked by required conditions
Ruby Testing / Libvips tests (3.2) (push) Blocked by required conditions
Ruby Testing / Libvips tests (3.3) (push) Blocked by required conditions
Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.3) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.3, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
72 lines
1.9 KiB
Ruby
72 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe PollOptionsValidator do
|
|
describe '#validate' do
|
|
before do
|
|
validator.validate(poll)
|
|
end
|
|
|
|
let(:validator) { described_class.new }
|
|
let(:poll) { instance_double(Poll, options: options, expires_at: expires_at, errors: errors) }
|
|
let(:errors) { instance_double(ActiveModel::Errors, add: nil) }
|
|
let(:options) { %w(foo bar) }
|
|
let(:expires_at) { 1.day.from_now }
|
|
|
|
it 'has no errors' do
|
|
expect(errors).to_not have_received(:add)
|
|
end
|
|
|
|
context 'when the poll has duplicate options' do
|
|
let(:options) { %w(foo foo) }
|
|
|
|
it 'adds errors' do
|
|
expect(errors).to have_received(:add)
|
|
end
|
|
end
|
|
|
|
context 'when the poll has no options' do
|
|
let(:options) { [] }
|
|
|
|
it 'adds errors' do
|
|
expect(errors).to have_received(:add)
|
|
end
|
|
end
|
|
|
|
context 'when the poll has too many options' do
|
|
let(:options) { Array.new(described_class::MAX_OPTIONS + 1) { |i| "option #{i}" } }
|
|
|
|
it 'adds errors' do
|
|
expect(errors).to have_received(:add)
|
|
end
|
|
end
|
|
|
|
describe 'character length of poll options' do
|
|
context 'when poll has acceptable length options' do
|
|
let(:options) { %w(test this) }
|
|
|
|
it 'has no errors' do
|
|
expect(errors).to_not have_received(:add)
|
|
end
|
|
end
|
|
|
|
context 'when poll has multibyte and ZWJ emoji options' do
|
|
let(:options) { ['✨' * described_class::MAX_OPTION_CHARS, '🏳️⚧️' * described_class::MAX_OPTION_CHARS] }
|
|
|
|
it 'has no errors' do
|
|
expect(errors).to_not have_received(:add)
|
|
end
|
|
end
|
|
|
|
context 'when poll has options that are too long' do
|
|
let(:options) { ['ok', 'a' * (described_class::MAX_OPTION_CHARS**2)] }
|
|
|
|
it 'has errors' do
|
|
expect(errors).to have_received(:add)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|