FIX: send new email activation token if the original token expired

This commit is contained in:
Arpit Jalan 2015-08-24 11:51:34 +05:30
parent 94f05a40de
commit 10b8e43a92
2 changed files with 35 additions and 1 deletions

View File

@ -43,10 +43,13 @@ end
class EmailActivator < UserActivator class EmailActivator < UserActivator
def activate def activate
email_token = user.email_tokens.unconfirmed.active.first
email_token = user.email_tokens.create(email: user.email) if email_token.nil?
Jobs.enqueue(:user_email, Jobs.enqueue(:user_email,
type: :signup, type: :signup,
user_id: user.id, user_id: user.id,
email_token: user.email_tokens.first.token email_token: email_token.token
) )
I18n.t("login.activate_email", email: user.email) I18n.t("login.activate_email", email: user.email)
end end

View File

@ -0,0 +1,31 @@
require 'spec_helper'
describe UserActivator do
describe 'email_activator' do
it 'does not create new email token unless required' do
SiteSetting.email_token_valid_hours = 24
user = Fabricate(:user)
activator = EmailActivator.new(user, nil, nil, nil)
Jobs.expects(:enqueue).with(:user_email, has_entries(type: :signup, email_token: user.email_tokens.first.token))
activator.activate
end
it 'creates and send new email token if the existing token expired' do
SiteSetting.email_token_valid_hours = 24
user = Fabricate(:user)
email_token = user.email_tokens.first
email_token.update_column(:created_at, 48.hours.ago)
activator = EmailActivator.new(user, nil, nil, nil)
Jobs.expects(:enqueue).with(:user_email, has_entries(type: :signup))
Jobs.expects(:enqueue).with(:user_email, has_entries(type: :signup, email_token: email_token.token)).never
activator.activate
user.reload
expect(user.email_tokens.last.created_at).to be_within_one_second_of(Time.zone.now)
end
end
end