mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
FIX: Badge and user title interaction fixes (#8282)
* Fix user title logic when badge name customized * Fix an issue where a user's title was not considered a badge granted title when the user used a badge for their title and the badge name was customized. this affected the effectiveness of revoke_ungranted_titles! which only operates on badge_granted_titles. * When a user's title is set now it is considered a badge_granted_title if the badge name OR the badge custom name from TranslationOverride is the same as the title * When a user's badge is revoked we now also revoke their title if the user's title matches the badge name OR the badge custom name from TranslationOverride * Add a user history log when the title is revoked to remove confusion about why titles are revoked * Add granted_title_badge_id to user_profile, now when we set badge_granted_title on a user profile when updating a user's title based on a badge, we also remember which badge matched the title * When badge name (or custom text) changes update titles of users in a background job * When the name of a badge changes, or in the case of system badges when their custom translation text changes, then we need to update the title of all corresponding users who have a badge_granted_title and matching granted_title_badge_id. In the case of system badges we need to first get the proper badge ID based on the translation key e.g. badges.regular.name * Add migration to backfill all granted_title_badge_ids for both normal badge name titles and titles using custom badge text.
This commit is contained in:
@@ -196,6 +196,33 @@ describe BadgeGranter do
|
||||
expect(user.reload.title).to eq(nil)
|
||||
end
|
||||
|
||||
context 'when the badge name is customized, and the customized name is the same as the user title' do
|
||||
let(:customized_badge_name) { 'Merit Badge' }
|
||||
|
||||
before do
|
||||
TranslationOverride.upsert!(I18n.locale, Badge.i18n_key(badge.name), customized_badge_name)
|
||||
end
|
||||
|
||||
it 'revokes the badge and title and does necessary cleanup' do
|
||||
user.title = customized_badge_name; user.save!
|
||||
expect(badge.reload.grant_count).to eq(1)
|
||||
StaffActionLogger.any_instance.expects(:log_badge_revoke).with(user_badge)
|
||||
StaffActionLogger.any_instance.expects(:log_title_revoke).with(
|
||||
user,
|
||||
revoke_reason: 'user title was same as revoked badge name or custom badge name',
|
||||
previous_value: user_badge.user.title
|
||||
)
|
||||
BadgeGranter.revoke(user_badge, revoked_by: admin)
|
||||
expect(UserBadge.find_by(user: user, badge: badge)).not_to be_present
|
||||
expect(badge.reload.grant_count).to eq(0)
|
||||
expect(user.notifications.where(notification_type: Notification.types[:granted_badge])).to be_empty
|
||||
expect(user.reload.title).to eq(nil)
|
||||
end
|
||||
|
||||
after do
|
||||
TranslationOverride.revert!(I18n.locale, Badge.i18n_key(badge.name))
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "update_badges" do
|
||||
|
||||
Reference in New Issue
Block a user