mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 10:32:45 +08:00
New user education notification was off by one. Also, remove the "basic" restriction on the
"posting too often" message.
This commit is contained in:
parent
0fafe124db
commit
16dc0a7001
|
@ -21,7 +21,7 @@ class ComposerMessagesFinder
|
||||||
education_key = :education_new_reply
|
education_key = :education_new_reply
|
||||||
end
|
end
|
||||||
|
|
||||||
if count <= SiteSetting.educate_until_posts
|
if count < SiteSetting.educate_until_posts
|
||||||
education_posts_text = I18n.t('education.until_posts', count: SiteSetting.educate_until_posts)
|
education_posts_text = I18n.t('education.until_posts', count: SiteSetting.educate_until_posts)
|
||||||
return {templateName: 'composer/education',
|
return {templateName: 'composer/education',
|
||||||
wait_for_typing: true,
|
wait_for_typing: true,
|
||||||
|
@ -56,11 +56,8 @@ class ComposerMessagesFinder
|
||||||
# We only care about replies to topics
|
# We only care about replies to topics
|
||||||
return unless replying? && @details[:topic_id] &&
|
return unless replying? && @details[:topic_id] &&
|
||||||
|
|
||||||
# For users who are not new
|
|
||||||
@user.has_trust_level?(:basic) &&
|
|
||||||
|
|
||||||
# And who have posted enough
|
# And who have posted enough
|
||||||
(@user.post_count > SiteSetting.educate_until_posts) &&
|
(@user.post_count >= SiteSetting.educate_until_posts) &&
|
||||||
|
|
||||||
# And who haven't been notified about sequential replies already
|
# And who haven't been notified about sequential replies already
|
||||||
(!UserHistory.exists_for_user?(@user, :notified_about_sequential_replies))
|
(!UserHistory.exists_for_user?(@user, :notified_about_sequential_replies))
|
||||||
|
|
|
@ -28,12 +28,12 @@ describe ComposerMessagesFinder do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns a message for a user who has not posted any topics" do
|
it "returns a message for a user who has not posted any topics" do
|
||||||
user.expects(:created_topic_count).returns(10)
|
user.expects(:created_topic_count).returns(9)
|
||||||
finder.check_education_message.should be_present
|
finder.check_education_message.should be_present
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns no message when the user has posted enough topics" do
|
it "returns no message when the user has posted enough topics" do
|
||||||
user.expects(:created_topic_count).returns(11)
|
user.expects(:created_topic_count).returns(10)
|
||||||
finder.check_education_message.should be_blank
|
finder.check_education_message.should be_blank
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -46,12 +46,12 @@ describe ComposerMessagesFinder do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns a message for a user who has not posted any topics" do
|
it "returns a message for a user who has not posted any topics" do
|
||||||
user.expects(:post_count).returns(10)
|
user.expects(:post_count).returns(9)
|
||||||
finder.check_education_message.should be_present
|
finder.check_education_message.should be_present
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns no message when the user has posted enough topics" do
|
it "returns no message when the user has posted enough topics" do
|
||||||
user.expects(:post_count).returns(11)
|
user.expects(:post_count).returns(10)
|
||||||
finder.check_education_message.should be_blank
|
finder.check_education_message.should be_blank
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -129,13 +129,9 @@ describe ComposerMessagesFinder do
|
||||||
context "reply" do
|
context "reply" do
|
||||||
let(:finder) { ComposerMessagesFinder.new(user, composerAction: 'reply', topic_id: topic.id) }
|
let(:finder) { ComposerMessagesFinder.new(user, composerAction: 'reply', topic_id: topic.id) }
|
||||||
|
|
||||||
it "does not give a message to new users" do
|
|
||||||
user.trust_level = TrustLevel.levels[:newuser]
|
|
||||||
finder.check_sequential_replies.should be_blank
|
|
||||||
end
|
|
||||||
|
|
||||||
it "does not give a message to users who are still in the 'education' phase" do
|
it "does not give a message to users who are still in the 'education' phase" do
|
||||||
user.stubs(:post_count).returns(10)
|
user.stubs(:post_count).returns(9)
|
||||||
finder.check_sequential_replies.should be_blank
|
finder.check_sequential_replies.should be_blank
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user