mirror of
https://github.com/discourse/discourse.git
synced 2025-01-12 11:53:53 +08:00
a03f87bdbd
* DEV: Change poll_minimum_trust_level_to_create to group based setting New setting is poll_create_allowed_groups c.f. https://meta.discourse.org/t/changes-coming-to-settings-for-giving-access-to-features-from-trust-levels-to-groups/283408 * DEV: Move styleguide_admin_only to group based setting Not exactly a TL -> group change, but still part of the overall effort here: https://meta.discourse.org/t/changes-coming-to-settings-for-giving-access-to-features-from-trust-levels-to-groups/283408 New setting is styleguide_allowed_groups
93 lines
3.4 KiB
Ruby
93 lines
3.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe ::DiscoursePoll::Poll do
|
|
describe ".transform_for_user_field_override" do
|
|
it "Transforms UserField name if a matching CustomUserField is present" do
|
|
user_field_name = "Something Cool"
|
|
user_field = Fabricate(:user_field, name: user_field_name)
|
|
expect(::DiscoursePoll::Poll.transform_for_user_field_override(user_field_name)).to eq(
|
|
"user_field_#{user_field.id}",
|
|
)
|
|
end
|
|
|
|
it "does not transform UserField name if a matching CustomUserField is not present" do
|
|
user_field_name = "Something Cool"
|
|
user_field = Fabricate(:user_field, name: "Something Else!")
|
|
expect(::DiscoursePoll::Poll.transform_for_user_field_override(user_field_name)).to eq(
|
|
user_field_name,
|
|
)
|
|
end
|
|
end
|
|
|
|
describe "can see results?" do
|
|
it "everyone can see results when results setting is always" do
|
|
post = Fabricate(:post, raw: "[poll]\n- A\n- B\n[/poll]")
|
|
user = Fabricate(:user)
|
|
expect(post.polls.first.can_see_results?(user)).to eq(true)
|
|
end
|
|
|
|
it "users who voted can see results when results setting is on_vote" do
|
|
post = Fabricate(:post, raw: "[poll results=on_vote]\n- A\n- B\n[/poll]")
|
|
user = Fabricate(:user)
|
|
poll = post.polls.first
|
|
option = poll.poll_options.first
|
|
|
|
expect(poll.can_see_results?(user)).to eq(false)
|
|
poll.poll_votes.create!(poll_option_id: option.id, user_id: user.id)
|
|
expect(poll.can_see_results?(user)).to eq(true)
|
|
end
|
|
|
|
it "author can see results when results setting is on_vote" do
|
|
author = Fabricate(:user, refresh_auto_groups: true)
|
|
post = Fabricate(:post, user: author, raw: "[poll results=on_vote]\n- A\n- B\n[/poll]")
|
|
poll = post.polls.first
|
|
option = poll.poll_options.first
|
|
|
|
expect(poll.can_see_results?(author)).to eq(true)
|
|
poll.poll_votes.create!(poll_option_id: option.id, user_id: author.id)
|
|
expect(poll.can_see_results?(author)).to eq(true)
|
|
end
|
|
|
|
it "everyone can see results when results setting is on_vote and poll is closed" do
|
|
post = Fabricate(:post, raw: "[poll results=on_vote]\n- A\n- B\n[/poll]")
|
|
user = Fabricate(:user)
|
|
poll = post.polls.first
|
|
|
|
expect(poll.can_see_results?(user)).to eq(false)
|
|
poll.update(close_at: Date.yesterday)
|
|
expect(poll.can_see_results?(user)).to eq(true)
|
|
end
|
|
|
|
it "only staff members can see results when results setting is staff_only" do
|
|
post = Fabricate(:post, raw: "[poll results=staff_only]\n- A\n- B\n[/poll]")
|
|
user = Fabricate(:user, refresh_auto_groups: true)
|
|
poll = post.polls.first
|
|
option = poll.poll_options.first
|
|
|
|
expect(poll.can_see_results?(user)).to eq(false)
|
|
poll.poll_votes.create!(poll_option_id: option.id, user_id: user.id)
|
|
expect(poll.can_see_results?(user)).to eq(false)
|
|
user.update!(moderator: true)
|
|
expect(poll.can_see_results?(user)).to eq(true)
|
|
end
|
|
end
|
|
|
|
describe "when post is trashed" do
|
|
it "maintains the association" do
|
|
user = Fabricate(:user, refresh_auto_groups: true)
|
|
post = Fabricate(:post, raw: "[poll results=staff_only]\n- A\n- B\n[/poll]", user: user)
|
|
poll = post.polls.first
|
|
|
|
post.trash!
|
|
poll.reload
|
|
|
|
expect(poll.post).to eq(post)
|
|
end
|
|
end
|
|
|
|
it "is not throwing an error when double save" do
|
|
post = Fabricate(:post, raw: "[poll]\n- A\n- B\n[/poll]")
|
|
expect { post.save! }.not_to raise_error
|
|
end
|
|
end
|