mirror of
https://github.com/discourse/discourse.git
synced 2024-11-26 00:23:40 +08:00
493d437e79
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
50 lines
1.4 KiB
Ruby
50 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe GivenDailyLike do
|
|
|
|
it 'no errors without a user' do
|
|
expect { GivenDailyLike.increment_for(nil) }.not_to raise_error
|
|
expect { GivenDailyLike.decrement_for(nil) }.not_to raise_error
|
|
end
|
|
|
|
context 'with a user' do
|
|
fab!(:user) { Fabricate(:user) }
|
|
|
|
def value_for(user_id, date)
|
|
GivenDailyLike.find_for(user_id, date).pluck(:likes_given)[0] || 0
|
|
end
|
|
|
|
def limit_reached_for(user_id, date)
|
|
GivenDailyLike.find_for(user_id, date).pluck(:limit_reached)[0] || false
|
|
end
|
|
|
|
it 'can be incremented and decremented' do
|
|
SiteSetting.max_likes_per_day = 2
|
|
|
|
dt = Date.today
|
|
freeze_time dt
|
|
|
|
expect(value_for(user.id, dt)).to eq(0)
|
|
expect(limit_reached_for(user.id, dt)).to eq(false)
|
|
|
|
GivenDailyLike.increment_for(user.id)
|
|
expect(value_for(user.id, dt)).to eq(1)
|
|
expect(limit_reached_for(user.id, dt)).to eq(false)
|
|
|
|
GivenDailyLike.increment_for(user.id)
|
|
expect(value_for(user.id, dt)).to eq(2)
|
|
expect(limit_reached_for(user.id, dt)).to eq(true)
|
|
|
|
GivenDailyLike.decrement_for(user.id)
|
|
expect(value_for(user.id, dt)).to eq(1)
|
|
expect(limit_reached_for(user.id, dt)).to eq(false)
|
|
|
|
GivenDailyLike.decrement_for(user.id)
|
|
expect(value_for(user.id, dt)).to eq(0)
|
|
expect(limit_reached_for(user.id, dt)).to eq(false)
|
|
end
|
|
|
|
end
|
|
|
|
end
|