FEATURE: new 'poll_maximum_options' site setting to limit the number of options in a poll

This commit is contained in:
Régis Hanol 2015-05-01 16:44:51 +02:00
parent f83638c154
commit 2954c99a1e
4 changed files with 27 additions and 1 deletions

View File

@ -8,6 +8,7 @@
en: en:
site_settings: site_settings:
poll_enabled: "Allow users to create polls?" poll_enabled: "Allow users to create polls?"
poll_maximum_options: "Maximum number of options allowed in a poll."
poll: poll:
multiple_polls_without_name: "There are multiple polls without a name. Use the '<code>name</code>' attribute to uniquely identify your polls." multiple_polls_without_name: "There are multiple polls without a name. Use the '<code>name</code>' attribute to uniquely identify your polls."
@ -16,8 +17,11 @@ en:
default_poll_must_have_at_least_2_options: "Poll must have at least 2 options." default_poll_must_have_at_least_2_options: "Poll must have at least 2 options."
named_poll_must_have_at_least_2_options: "Poll named <strong>%{name}</strong> must have at least 2 options." named_poll_must_have_at_least_2_options: "Poll named <strong>%{name}</strong> must have at least 2 options."
default_poll_must_have_less_options: "Poll must have less than %{max} options."
named_poll_must_have_less_options: "Poll named <strong>%{name}</strong> must have less than %{max} options."
default_poll_must_have_different_options: "Poll must have different options." default_poll_must_have_different_options: "Poll must have different options."
named_poll_must_have_different_options: "Poll name <strong>%{name}</strong> must have different options." named_poll_must_have_different_options: "Poll named <strong>%{name}</strong> must have different options."
requires_at_least_1_valid_option: "You must select at least 1 valid option." requires_at_least_1_valid_option: "You must select at least 1 valid option."
cannot_change_polls_after_5_minutes: "Polls cannot be changed after the first 5 minutes. Contact a moderator if you need to change them." cannot_change_polls_after_5_minutes: "Polls cannot be changed after the first 5 minutes. Contact a moderator if you need to change them."

View File

@ -1,3 +1,5 @@
plugins: plugins:
poll_enabled: poll_enabled:
default: true default: true
poll_maximum_options:
default: 10

View File

@ -231,6 +231,14 @@ after_initialize do
return return
end end
# maximum # of options
if poll["options"].size > SiteSetting.poll_maximum_options
poll["name"] == DEFAULT_POLL_NAME ?
self.errors.add(:base, I18n.t("poll.default_poll_must_have_less_options", max: SiteSetting.poll_maximum_options)) :
self.errors.add(:base, I18n.t("poll.named_poll_must_have_less_options", name: poll["name"], max: SiteSetting.poll_maximum_options))
return
end
# store the valid poll # store the valid poll
polls[poll["name"]] = poll polls[poll["name"]] = poll
end end

View File

@ -37,6 +37,18 @@ describe PostsController do
expect(json["errors"][0]).to eq(I18n.t("poll.default_poll_must_have_at_least_2_options")) expect(json["errors"][0]).to eq(I18n.t("poll.default_poll_must_have_at_least_2_options"))
end end
it "should have at most 'SiteSetting.poll_maximum_options' options" do
raw = "[poll]"
(SiteSetting.poll_maximum_options + 1).times { |n| raw << "\n- #{n}" }
raw << "[/poll]"
xhr :post, :create, { title: title, raw: raw }
expect(response).not_to be_success
json = ::JSON.parse(response.body)
expect(json["errors"][0]).to eq(I18n.t("poll.default_poll_must_have_less_options", max: SiteSetting.poll_maximum_options))
end
describe "edit window" do describe "edit window" do
describe "within the first 5 minutes" do describe "within the first 5 minutes" do