debian-mirror-gitlab/spec/models/concerns/awardable_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

136 lines
4.1 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Awardable do
2021-09-30 23:02:18 +05:30
let!(:note) { create(:note) }
let!(:award_emoji) { create(:award_emoji, :downvote, awardable: note) }
describe "Associations" do
2021-09-30 23:02:18 +05:30
subject { build(:note) }
2017-08-17 22:00:37 +05:30
it { is_expected.to have_many(:award_emoji).dependent(:destroy) }
end
describe "ClassMethods" do
2021-09-30 23:02:18 +05:30
let!(:note2) { create(:note) }
let!(:award_emoji2) { create(:award_emoji, awardable: note2) }
2018-03-17 18:26:18 +05:30
describe "orders" do
it "orders on upvotes" do
2021-09-30 23:02:18 +05:30
expect(Note.order_upvotes_desc.to_a).to eq [note2, note]
2018-03-17 18:26:18 +05:30
end
2018-03-17 18:26:18 +05:30
it "orders on downvotes" do
2021-09-30 23:02:18 +05:30
expect(Note.order_downvotes_desc.to_a).to eq [note, note2]
2018-03-17 18:26:18 +05:30
end
end
2018-12-13 13:39:08 +05:30
describe "#awarded" do
2018-03-17 18:26:18 +05:30
it "filters by user and emoji name" do
2021-09-30 23:02:18 +05:30
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
2018-03-17 18:26:18 +05:30
end
2018-12-13 13:39:08 +05:30
it "filters by user and any emoji" do
2021-09-30 23:02:18 +05:30
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)
2018-12-13 13:39:08 +05:30
2021-09-30 23:02:18 +05:30
expect(Note.awarded(award_emoji.user)).to contain_exactly(note, note3)
expect(Note.awarded(award_emoji2.user)).to contain_exactly(note2, note3)
2018-12-13 13:39:08 +05:30
end
end
describe "#not_awarded" do
2021-09-30 23:02:18 +05:30
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]
2018-12-13 13:39:08 +05:30
end
end
end
describe "#upvotes" do
it "counts the number of upvotes" do
2021-09-30 23:02:18 +05:30
expect(note.upvotes).to be 0
end
end
describe "#downvotes" do
it "counts the number of downvotes" do
2021-09-30 23:02:18 +05:30
expect(note.downvotes).to be 1
end
end
2018-05-09 12:01:36 +05:30
describe '#user_can_award?' do
let(:user) { create(:user) }
before do
2021-09-30 23:02:18 +05:30
note.project.add_guest(user)
2018-05-09 12:01:36 +05:30
end
it 'is truthy when the user is allowed to award emoji' do
2021-09-30 23:02:18 +05:30
expect(note.user_can_award?(user)).to be_truthy
2018-05-09 12:01:36 +05:30
end
it 'is falsy when the project is archived' do
2021-09-30 23:02:18 +05:30
note.project.update!(archived: true)
2018-05-09 12:01:36 +05:30
2021-09-30 23:02:18 +05:30
expect(note.user_can_award?(user)).to be_falsy
2018-05-09 12:01:36 +05:30
end
end
2016-09-29 09:46:39 +05:30
describe 'querying award_emoji on an Awardable' do
2021-09-30 23:02:18 +05:30
let(:note) { create(:note) }
2016-09-29 09:46:39 +05:30
it 'sorts in ascending fashion' do
2021-09-30 23:02:18 +05:30
create_list(:award_emoji, 3, awardable: note)
2016-09-29 09:46:39 +05:30
2021-09-30 23:02:18 +05:30
expect(note.award_emoji).to eq note.award_emoji.sort_by(&:id)
2016-09-29 09:46:39 +05:30
end
end
2020-05-24 23:13:21 +05:30
describe "#grouped_awards" do
context 'default award emojis' do
2021-09-30 23:02:18 +05:30
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
2020-05-24 23:13:21 +05:30
end
it "includes unused thumbs buttons by default" do
2021-09-30 23:02:18 +05:30
expect(note_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup)
2020-05-24 23:13:21 +05:30
end
it "doesn't include unused thumbs buttons when disabled in project" do
2021-09-30 23:02:18 +05:30
note_without_downvote.project.show_default_award_emojis = false
2020-05-24 23:13:21 +05:30
2021-09-30 23:02:18 +05:30
expect(note_without_downvote.grouped_awards.keys.sort).to be_empty
2020-05-24 23:13:21 +05:30
end
it "includes unused thumbs buttons when enabled in project" do
2021-09-30 23:02:18 +05:30
note_without_downvote.project.show_default_award_emojis = true
2020-05-24 23:13:21 +05:30
2021-09-30 23:02:18 +05:30
expect(note_without_downvote.grouped_awards.keys.sort).to eq %w(thumbsdown thumbsup)
2020-05-24 23:13:21 +05:30
end
it "doesn't include unused thumbs buttons in summary" do
2021-09-30 23:02:18 +05:30
expect(note_without_downvote.grouped_awards(with_thumbs: false).keys).to be_empty
2020-05-24 23:13:21 +05:30
end
it "includes used thumbs buttons when disabled in project" do
2021-09-30 23:02:18 +05:30
note_with_downvote.project.show_default_award_emojis = false
2020-05-24 23:13:21 +05:30
2021-09-30 23:02:18 +05:30
expect(note_with_downvote.grouped_awards.keys).to eq %w(thumbsdown)
2020-05-24 23:13:21 +05:30
end
it "includes used thumbs buttons in summary" do
2021-09-30 23:02:18 +05:30
expect(note_with_downvote.grouped_awards(with_thumbs: false).keys).to eq %w(thumbsdown)
2020-05-24 23:13:21 +05:30
end
end
end
end