BUGFIX: only redirect new users to top page once

Actually, new users will still be redirected to the top page during the first 30 seconds of their first visit.
This commit is contained in:
Régis Hanol 2014-05-05 19:00:40 +02:00
parent c680d74571
commit c21d3f41d0
8 changed files with 87 additions and 56 deletions

View file

@ -0,0 +1,11 @@
module Jobs
class UpdateTopRedirection < Jobs::Base
def execute(args)
user = User.where(id: args[:user_id]).first
user.update_column(:last_redirected_to_top_at, args[:redirected_at])
end
end
end

View file

@ -1,12 +0,0 @@
module Jobs
class UpdateUserInfo < Jobs::Base
def execute(args)
user = User.where(id: args[:user_id]).first
user.update_last_seen!
user.update_ip_address!(args[:ip_address])
end
end
end

View file

@ -586,14 +586,35 @@ class User < ActiveRecord::Base
return unless SiteSetting.top_menu =~ /top/i return unless SiteSetting.top_menu =~ /top/i
# there should be enough topics # there should be enough topics
return unless SiteSetting.has_enough_topics_to_redirect_to_top return unless SiteSetting.has_enough_topics_to_redirect_to_top
# new users
return I18n.t('redirected_to_top_reasons.new_user') if trust_level == 0 && if !seen_before? || (trust_level == 0 && !redirected_to_top_yet?)
created_at > SiteSetting.redirect_new_users_to_top_page_duration.days.ago update_last_redirected_to_top!
# long-time-no-see user return I18n.t('redirected_to_top_reasons.new_user')
return I18n.t('redirected_to_top_reasons.not_seen_in_a_month') if last_seen_at && last_seen_at < 1.month.ago elsif last_seen_at < 1.month.ago
update_last_redirected_to_top!
return I18n.t('redirected_to_top_reasons.not_seen_in_a_month')
end
# no reason
nil nil
end end
def redirected_to_top_yet?
last_redirected_to_top_at.present?
end
def update_last_redirected_to_top!
key = "user:#{id}:update_last_redirected_to_top"
delay = SiteSetting.active_user_rate_limit_secs
# only update last_redirected_to_top_at once every minute
return unless $redis.setnx(key, "1")
$redis.expire(key, delay)
# delay the update
Jobs.enqueue_in(delay / 2, :update_top_redirection, user_id: self.id, redirected_at: Time.zone.now)
end
protected protected
def cook def cook

View file

@ -66,7 +66,7 @@ class CurrentUserSerializer < BasicUserSerializer
end end
def include_redirected_to_top_reason? def include_redirected_to_top_reason?
object.should_be_redirected_to_top object.redirected_to_top_reason.present?
end end
end end

View file

@ -679,7 +679,6 @@ en:
topics_per_period_in_top_summary: "How many topics loaded on the top topics summary" topics_per_period_in_top_summary: "How many topics loaded on the top topics summary"
topics_per_period_in_top_page: "How many topics loaded on the top topics page" topics_per_period_in_top_page: "How many topics loaded on the top topics page"
redirect_users_to_top_page: "Automatically redirect new & long-time-no-see users to top page" redirect_users_to_top_page: "Automatically redirect new & long-time-no-see users to top page"
redirect_new_users_to_top_page_duration: "Number of days during which new users are automatically redirect to the top page"
enable_badges: "Enable the badge system (experimental)" enable_badges: "Enable the badge system (experimental)"

View file

@ -75,7 +75,6 @@ basic:
default: 30 default: 30
topics_per_period_in_top_summary: 20 topics_per_period_in_top_summary: 20
topics_per_period_in_top_page: 50 topics_per_period_in_top_page: 50
redirect_new_users_to_top_page_duration: 7
category_featured_topics: category_featured_topics:
client: true client: true
default: 3 default: 3

View file

@ -0,0 +1,5 @@
class AddLastRedirectedToTopAtToUsers < ActiveRecord::Migration
def change
add_column :users, :last_redirected_to_top_at, :datetime
end
end

View file

@ -1100,57 +1100,61 @@ describe User do
end end
describe "redirected_to_top_reason" do describe ".redirected_to_top_reason" do
let!(:user) { Fabricate(:user) } let!(:user) { Fabricate(:user) }
it "should have no reason when redirect_users_to_top_page is disabled" do it "should have no reason when `SiteSetting.redirect_users_to_top_page` is disabled" do
SiteSetting.expects(:redirect_users_to_top_page).returns(false) SiteSetting.expects(:redirect_users_to_top_page).returns(false)
user.redirected_to_top_reason.should == nil user.redirected_to_top_reason.should == nil
end end
context "redirect_users_to_top_page is enabled" do context "when `SiteSetting.redirect_users_to_top_page` is enabled" do
before { SiteSetting.stubs(:redirect_users_to_top_page).returns(true) } before { SiteSetting.expects(:redirect_users_to_top_page).returns(true) }
it "should have no reason when top is not in the top_menu" do it "should have no reason when top is not in the `SiteSetting.top_menu`" do
SiteSetting.expects(:top_menu).returns("latest") SiteSetting.expects(:top_menu).returns("latest")
user.redirected_to_top_reason.should == nil user.redirected_to_top_reason.should == nil
end end
it "should have no reason when there isn't enough topics" do context "and when top is in the `SiteSetting.top_menu`" do
SiteSetting.expects(:top_menu).returns("latest|top") before { SiteSetting.expects(:top_menu).returns("latest|top") }
it "should have no reason when there aren't enough topics" do
SiteSetting.expects(:has_enough_topics_to_redirect_to_top).returns(false) SiteSetting.expects(:has_enough_topics_to_redirect_to_top).returns(false)
user.redirected_to_top_reason.should == nil user.redirected_to_top_reason.should == nil
end end
describe "new users" do context "and when there are enough topics" do
before { SiteSetting.expects(:has_enough_topics_to_redirect_to_top).returns(true) }
describe "a new user" do
before do before do
user.expects(:trust_level).returns(0) user.stubs(:trust_level).returns(0)
user.stubs(:last_seen_at).returns(1.day.ago) user.stubs(:last_seen_at).returns(5.minutes.ago)
SiteSetting.expects(:top_menu).returns("latest|top")
SiteSetting.expects(:has_enough_topics_to_redirect_to_top).returns(true)
SiteSetting.expects(:redirect_new_users_to_top_page_duration).returns(7)
end end
it "should have a reason for newly created user" do it "should have a reason for the first visit" do
user.expects(:created_at).returns(5.days.ago) user.expects(:last_redirected_to_top_at).returns(nil)
user.expects(:update_last_redirected_to_top!).once
user.redirected_to_top_reason.should == I18n.t('redirected_to_top_reasons.new_user') user.redirected_to_top_reason.should == I18n.t('redirected_to_top_reasons.new_user')
end end
it "should not have a reason for newly created user" do it "should not have a reason for next visits" do
user.expects(:created_at).returns(10.days.ago) user.expects(:last_redirected_to_top_at).returns(10.minutes.ago)
user.expects(:update_last_redirected_to_top!).never
user.redirected_to_top_reason.should == nil user.redirected_to_top_reason.should == nil
end end
end end
describe "old users" do describe "an older user" do
before do before { user.stubs(:trust_level).returns(1) }
user.stubs(:trust_level).returns(1)
SiteSetting.expects(:top_menu).returns("latest|top")
SiteSetting.expects(:has_enough_topics_to_redirect_to_top).returns(true)
end
it "should have a reason for long-time-no-see users" do it "should have a reason when the user hasn't been seen in a month" do
user.last_seen_at = 2.months.ago user.last_seen_at = 2.months.ago
user.expects(:update_last_redirected_to_top!).once
user.redirected_to_top_reason.should == I18n.t('redirected_to_top_reasons.not_seen_in_a_month') user.redirected_to_top_reason.should == I18n.t('redirected_to_top_reasons.not_seen_in_a_month')
end end
end end
@ -1159,6 +1163,10 @@ describe User do
end end
end
end
describe "custom fields" do describe "custom fields" do
it "allows modification of custom fields" do it "allows modification of custom fields" do
user = Fabricate(:user) user = Fabricate(:user)