diff options
Diffstat (limited to 'spec/models/concerns/awardable_spec.rb')
-rw-r--r-- | spec/models/concerns/awardable_spec.rb | 84 |
1 files changed, 42 insertions, 42 deletions
diff --git a/spec/models/concerns/awardable_spec.rb b/spec/models/concerns/awardable_spec.rb index b80b6ec95e2..fcd0d0c05f4 100644 --- a/spec/models/concerns/awardable_spec.rb +++ b/spec/models/concerns/awardable_spec.rb @@ -3,64 +3,64 @@ require 'spec_helper' RSpec.describe Awardable do - let!(:issue) { create(:issue) } - let!(:award_emoji) { create(:award_emoji, :downvote, awardable: issue) } + let!(:note) { create(:note) } + let!(:award_emoji) { create(:award_emoji, :downvote, awardable: note) } describe "Associations" do - subject { build(:issue) } + subject { build(:note) } it { is_expected.to have_many(:award_emoji).dependent(:destroy) } end describe "ClassMethods" do - let!(:issue2) { create(:issue) } - let!(:award_emoji2) { create(:award_emoji, awardable: issue2) } + let!(:note2) { create(:note) } + let!(:award_emoji2) { create(:award_emoji, awardable: note2) } describe "orders" do it "orders on upvotes" do - expect(Issue.order_upvotes_desc.to_a).to eq [issue2, issue] + expect(Note.order_upvotes_desc.to_a).to eq [note2, note] end it "orders on downvotes" do - expect(Issue.order_downvotes_desc.to_a).to eq [issue, issue2] + expect(Note.order_downvotes_desc.to_a).to eq [note, note2] end end describe "#awarded" do it "filters by user and emoji name" do - expect(Issue.awarded(award_emoji.user, "thumbsup")).to be_empty - expect(Issue.awarded(award_emoji.user, "thumbsdown")).to eq [issue] - expect(Issue.awarded(award_emoji2.user, "thumbsup")).to eq [issue2] - expect(Issue.awarded(award_emoji2.user, "thumbsdown")).to be_empty + expect(Note.awarded(award_emoji.user, "thumbsup")).to be_empty + expect(Note.awarded(award_emoji.user, "thumbsdown")).to eq [note] + expect(Note.awarded(award_emoji2.user, "thumbsup")).to eq [note2] + expect(Note.awarded(award_emoji2.user, "thumbsdown")).to be_empty end it "filters by user and any emoji" do - issue3 = create(:issue) - create(:award_emoji, awardable: issue3, name: "star", user: award_emoji.user) - create(:award_emoji, awardable: issue3, name: "star", user: award_emoji2.user) + note3 = create(:note) + create(:award_emoji, awardable: note3, name: "star", user: award_emoji.user) + create(:award_emoji, awardable: note3, name: "star", user: award_emoji2.user) - expect(Issue.awarded(award_emoji.user)).to contain_exactly(issue, issue3) - expect(Issue.awarded(award_emoji2.user)).to contain_exactly(issue2, issue3) + expect(Note.awarded(award_emoji.user)).to contain_exactly(note, note3) + expect(Note.awarded(award_emoji2.user)).to contain_exactly(note2, note3) end end describe "#not_awarded" do - it "returns issues not awarded by user" do - expect(Issue.not_awarded(award_emoji.user)).to eq [issue2] - expect(Issue.not_awarded(award_emoji2.user)).to eq [issue] + it "returns notes not awarded by user" do + expect(Note.not_awarded(award_emoji.user)).to eq [note2] + expect(Note.not_awarded(award_emoji2.user)).to eq [note] end end end describe "#upvotes" do it "counts the number of upvotes" do - expect(issue.upvotes).to be 0 + expect(note.upvotes).to be 0 end end describe "#downvotes" do it "counts the number of downvotes" do - expect(issue.downvotes).to be 1 + expect(note.downvotes).to be 1 end end @@ -68,67 +68,67 @@ RSpec.describe Awardable do let(:user) { create(:user) } before do - issue.project.add_guest(user) + note.project.add_guest(user) end it 'is truthy when the user is allowed to award emoji' do - expect(issue.user_can_award?(user)).to be_truthy + expect(note.user_can_award?(user)).to be_truthy end it 'is falsy when the project is archived' do - issue.project.update!(archived: true) + note.project.update!(archived: true) - expect(issue.user_can_award?(user)).to be_falsy + expect(note.user_can_award?(user)).to be_falsy end end describe 'querying award_emoji on an Awardable' do - let(:issue) { create(:issue) } + let(:note) { create(:note) } it 'sorts in ascending fashion' do - create_list(:award_emoji, 3, awardable: issue) + create_list(:award_emoji, 3, awardable: note) - expect(issue.award_emoji).to eq issue.award_emoji.sort_by(&:id) + expect(note.award_emoji).to eq note.award_emoji.sort_by(&:id) end end describe "#grouped_awards" do context 'default award emojis' do - let(:issue_without_downvote) { create(:issue) } - let(:issue_with_downvote) do - issue_with_downvote = create(:issue) - create(:award_emoji, :downvote, awardable: issue_with_downvote) - issue_with_downvote + let(:note_without_downvote) { create(:note) } + let(:note_with_downvote) do + note_with_downvote = create(:note) + create(:award_emoji, :downvote, awardable: note_with_downvote) + note_with_downvote end it "includes unused thumbs buttons by default" do - expect(issue_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup) + expect(note_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup) end it "doesn't include unused thumbs buttons when disabled in project" do - issue_without_downvote.project.show_default_award_emojis = false + note_without_downvote.project.show_default_award_emojis = false - expect(issue_without_downvote.grouped_awards.keys.sort).to be_empty + expect(note_without_downvote.grouped_awards.keys.sort).to be_empty end it "includes unused thumbs buttons when enabled in project" do - issue_without_downvote.project.show_default_award_emojis = true + note_without_downvote.project.show_default_award_emojis = true - expect(issue_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup) + expect(note_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup) end it "doesn't include unused thumbs buttons in summary" do - expect(issue_without_downvote.grouped_awards(with_thumbs: false).keys).to be_empty + expect(note_without_downvote.grouped_awards(with_thumbs: false).keys).to be_empty end it "includes used thumbs buttons when disabled in project" do - issue_with_downvote.project.show_default_award_emojis = false + note_with_downvote.project.show_default_award_emojis = false - expect(issue_with_downvote.grouped_awards.keys).to eq %w(thumbsdown) + expect(note_with_downvote.grouped_awards.keys).to eq %w(thumbsdown) end it "includes used thumbs buttons in summary" do - expect(issue_with_downvote.grouped_awards(with_thumbs: false).keys).to eq %w(thumbsdown) + expect(note_with_downvote.grouped_awards(with_thumbs: false).keys).to eq %w(thumbsdown) end end end |