mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 07:52:45 +08:00
FIX: always trigger the ':user_updated' event
We don't always use the UserUpdated class to update a user's record
This commit is contained in:
parent
ecbeaed0bc
commit
519b70ea46
|
@ -103,6 +103,7 @@ class User < ActiveRecord::Base
|
||||||
after_save :expire_old_email_tokens
|
after_save :expire_old_email_tokens
|
||||||
after_save :index_search
|
after_save :index_search
|
||||||
after_commit :trigger_user_created_event, on: :create
|
after_commit :trigger_user_created_event, on: :create
|
||||||
|
after_commit :trigger_user_updated_event, on: :update
|
||||||
|
|
||||||
before_destroy do
|
before_destroy do
|
||||||
# These tables don't have primary keys, so destroying them with activerecord is tricky:
|
# These tables don't have primary keys, so destroying them with activerecord is tricky:
|
||||||
|
@ -1092,6 +1093,11 @@ class User < ActiveRecord::Base
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def trigger_user_updated_event
|
||||||
|
DiscourseEvent.trigger(:user_updated, self)
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# == Schema Information
|
# == Schema Information
|
||||||
|
|
|
@ -121,7 +121,6 @@ class UserUpdater
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
DiscourseEvent.trigger(:user_updated, user) if saved
|
|
||||||
saved
|
saved
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -90,12 +90,15 @@ describe User do
|
||||||
user.approve(admin)
|
user.approve(admin)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'triggers a extensibility event' do
|
it 'triggers extensibility events' do
|
||||||
user && admin # bypass the user_created event
|
user && admin # bypass the user_created event
|
||||||
event = DiscourseEvent.track_events { user.approve(admin) }.first
|
user_updated_event, user_approved_event = DiscourseEvent.track_events { user.approve(admin) }
|
||||||
|
|
||||||
expect(event[:event_name]).to eq(:user_approved)
|
expect(user_updated_event[:event_name]).to eq(:user_updated)
|
||||||
expect(event[:params].first).to eq(user)
|
expect(user_updated_event[:params].first).to eq(user)
|
||||||
|
|
||||||
|
expect(user_approved_event[:event_name]).to eq(:user_approved)
|
||||||
|
expect(user_approved_event[:params].first).to eq(user)
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'after approval' do
|
context 'after approval' do
|
||||||
|
|
Loading…
Reference in New Issue
Block a user