mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 16:42:46 +08:00
c9dab6fd08
It's very easy to forget to add `require 'rails_helper'` at the top of every core/plugin spec file, and omissions can cause some very confusing/sporadic errors. By setting this flag in `.rspec`, we can remove the need for `require 'rails_helper'` entirely.
72 lines
2.0 KiB
Ruby
72 lines
2.0 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'unread'
|
|
|
|
describe Unread do
|
|
|
|
let (:user) { Fabricate.build(:user, id: 1) }
|
|
let (:topic) do
|
|
Fabricate.build(:topic,
|
|
posts_count: 13,
|
|
highest_staff_post_number: 15,
|
|
highest_post_number: 13,
|
|
id: 1)
|
|
end
|
|
|
|
let (:topic_user) do
|
|
Fabricate.build(:topic_user,
|
|
notification_level: TopicUser.notification_levels[:tracking],
|
|
topic_id: topic.id,
|
|
user_id: user.id)
|
|
end
|
|
|
|
def unread
|
|
Unread.new(topic, topic_user, Guardian.new(user))
|
|
end
|
|
|
|
describe 'staff counts' do
|
|
it 'should correctly return based on staff post number' do
|
|
user.admin = true
|
|
|
|
topic_user.last_read_post_number = 13
|
|
|
|
expect(unread.unread_posts).to eq(2)
|
|
end
|
|
end
|
|
|
|
describe 'unread_posts' do
|
|
it 'should have 0 unread posts if the user has read all posts' do
|
|
topic_user.last_read_post_number = 13
|
|
expect(unread.unread_posts).to eq(0)
|
|
end
|
|
|
|
it 'returns the right unread posts for a user' do
|
|
topic_user.last_read_post_number = 10
|
|
expect(unread.unread_posts).to eq(3)
|
|
end
|
|
|
|
it 'returns the right unread posts for a staff user' do
|
|
user.admin = true
|
|
topic_user.last_read_post_number = 10
|
|
expect(unread.unread_posts).to eq(5)
|
|
end
|
|
|
|
it 'should have 0 unread posts if the user has read more posts than exist (deleted)' do
|
|
topic_user.last_read_post_number = 14
|
|
expect(unread.unread_posts).to eq(0)
|
|
end
|
|
|
|
it 'has 0 unread posts if the user has read 10 posts but is not tracking' do
|
|
topic_user.last_read_post_number = 10
|
|
topic_user.notification_level = TopicUser.notification_levels[:regular]
|
|
expect(unread.unread_posts).to eq(0)
|
|
end
|
|
|
|
it 'has 0 unread psots if the user has not seen the topic' do
|
|
topic_user.last_read_post_number = nil
|
|
expect(unread.unread_posts).to eq(0)
|
|
end
|
|
end
|
|
|
|
end
|