Add shared example for RankedTrend
concern (#33125)
This commit is contained in:
parent
75ecc6df06
commit
3cd308523a
3 changed files with 59 additions and 26 deletions
|
@ -3,20 +3,9 @@
|
|||
require 'rails_helper'
|
||||
|
||||
RSpec.describe PreviewCardTrend do
|
||||
include_examples 'RankedTrend'
|
||||
|
||||
describe 'Associations' do
|
||||
it { is_expected.to belong_to(:preview_card).required }
|
||||
end
|
||||
|
||||
describe '.locales' do
|
||||
before do
|
||||
Fabricate :preview_card_trend, language: 'en'
|
||||
Fabricate :preview_card_trend, language: 'en'
|
||||
Fabricate :preview_card_trend, language: 'es'
|
||||
end
|
||||
|
||||
it 'returns unique set of languages' do
|
||||
expect(described_class.locales)
|
||||
.to eq(['en', 'es'])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -3,21 +3,10 @@
|
|||
require 'rails_helper'
|
||||
|
||||
RSpec.describe StatusTrend do
|
||||
include_examples 'RankedTrend'
|
||||
|
||||
describe 'Associations' do
|
||||
it { is_expected.to belong_to(:account).required }
|
||||
it { is_expected.to belong_to(:status).required }
|
||||
end
|
||||
|
||||
describe '.locales' do
|
||||
before do
|
||||
Fabricate :status_trend, language: 'en'
|
||||
Fabricate :status_trend, language: 'en'
|
||||
Fabricate :status_trend, language: 'es'
|
||||
end
|
||||
|
||||
it 'returns unique set of languages' do
|
||||
expect(described_class.locales)
|
||||
.to eq(['en', 'es'])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
55
spec/support/examples/models/concerns/ranked_trend.rb
Normal file
55
spec/support/examples/models/concerns/ranked_trend.rb
Normal file
|
@ -0,0 +1,55 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
RSpec.shared_examples 'RankedTrend' do
|
||||
describe 'Scopes' do
|
||||
describe '.by_rank' do
|
||||
let!(:lower_rank) { Fabricate factory_name, rank: 5 }
|
||||
let!(:higher_rank) { Fabricate factory_name, rank: 50 }
|
||||
|
||||
it 'returns records ordered by rank' do
|
||||
expect(described_class.by_rank)
|
||||
.to eq([higher_rank, lower_rank])
|
||||
end
|
||||
end
|
||||
|
||||
describe '.ranked_below' do
|
||||
let!(:low_rank) { Fabricate factory_name, rank: 5 }
|
||||
let!(:med_rank) { Fabricate factory_name, rank: 50 }
|
||||
let!(:high_rank) { Fabricate factory_name, rank: 500 }
|
||||
|
||||
it 'returns records ordered by rank' do
|
||||
expect(described_class.ranked_below(100))
|
||||
.to include(low_rank)
|
||||
.and include(med_rank)
|
||||
.and not_include(high_rank)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe '.locales' do
|
||||
before do
|
||||
Fabricate.times 2, factory_name, language: 'en'
|
||||
Fabricate factory_name, language: 'es'
|
||||
end
|
||||
|
||||
it 'returns unique set of languages' do
|
||||
expect(described_class.locales)
|
||||
.to eq(['en', 'es'])
|
||||
end
|
||||
end
|
||||
|
||||
describe '.recalculate_ordered_rank' do
|
||||
let!(:low_score) { Fabricate factory_name, score: 5, rank: 123 }
|
||||
let!(:high_score) { Fabricate factory_name, score: 10, rank: 456 }
|
||||
|
||||
it 'ranks records based on their score' do
|
||||
expect { described_class.recalculate_ordered_rank }
|
||||
.to change { low_score.reload.rank }.to(2)
|
||||
.and change { high_score.reload.rank }.to(1)
|
||||
end
|
||||
end
|
||||
|
||||
def factory_name
|
||||
described_class.name.underscore.to_sym
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue