FIX: Same user record being saved twice causing validation to fail.

This commit is contained in:
Guo Xiang Tan 2017-01-16 16:40:05 +08:00
parent 3ed5fe2f6c
commit 63954c1b33
2 changed files with 29 additions and 4 deletions

View File

@ -90,13 +90,13 @@ class User < ActiveRecord::Base
after_create :create_user_option after_create :create_user_option
after_create :create_user_profile after_create :create_user_profile
after_create :ensure_in_trust_level_group after_create :ensure_in_trust_level_group
after_create :automatic_group_membership
after_create :set_default_categories_preferences after_create :set_default_categories_preferences
after_create :trigger_user_created_event after_create :trigger_user_created_event
before_save :update_username_lower before_save :update_username_lower
before_save :ensure_password_is_hashed before_save :ensure_password_is_hashed
after_save :automatic_group_membership
after_save :clear_global_notice_if_needed after_save :clear_global_notice_if_needed
after_save :refresh_avatar after_save :refresh_avatar
after_save :badge_grant after_save :badge_grant
@ -935,10 +935,13 @@ class User < ActiveRecord::Base
Group.where(automatic: false) Group.where(automatic: false)
.where("LENGTH(COALESCE(automatic_membership_email_domains, '')) > 0") .where("LENGTH(COALESCE(automatic_membership_email_domains, '')) > 0")
.each do |group| .each do |group|
domains = group.automatic_membership_email_domains.gsub('.', '\.') domains = group.automatic_membership_email_domains.gsub('.', '\.')
if self.email =~ Regexp.new("@(#{domains})$", true) && !group.users.include?(self) user = User.find(self.id)
group.add(self)
GroupActionLogger.new(Discourse.system_user, group).log_add_user_to_group(self) if user.reload.email =~ Regexp.new("@(#{domains})$", true) && !group.users.include?(user)
group.add(user)
GroupActionLogger.new(Discourse.system_user, group).log_add_user_to_group(user)
end end
end end
end end

View File

@ -1196,6 +1196,28 @@ describe User do
expect(group_history.target_user).to eq(user) expect(group_history.target_user).to eq(user)
end end
it "get attributes from the group" do
group = Fabricate(:group,
automatic_membership_email_domains: "bar.com|wat.com",
grant_trust_level: 1,
title: "bars and wats",
primary_group: true
)
user = Fabricate.build(:user,
trust_level: 0,
email: "foo@bar.com",
password: "strongpassword4Uguys"
)
user.password_required!
user.save!
user.reload
expect(user.title).to eq("bars and wats")
expect(user.trust_level).to eq(1)
expect(user.trust_level_locked).to eq(true)
end
end end
describe "number_of_flags_given" do describe "number_of_flags_given" do