mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 06:37:23 +01:00
* fix(profile): detect attempt to use banned words as display name. refactor profanity detection method. * fix(profile): detect attempt to use banned words in blurb. further refactor profanity detection. inform the user their chat privileges have been revoked. * refactor: add function to normalize Unicode strings and remove diacritics * fix: improve regEx to prevent false partial matches e.g. 'hello' being recognised as banned words. porting fix from #12309 * fix(profile): refactor of profanity detection for #12445 * fix(profile): add test for swear words in new profile. fix existing tests * fix(profile): show different error message for attempted slur use in username by new users. * fix(profile): remove incorrect slur test * fix(profile): fix slurs not caught at start of end of strings connect by punctuation * tests(profile): fix tests for profanity checking * remove exclusive test * 11865 - update text for slur warnings * 11865 - remove unused string from locale files * 11865 - improve naming of banned word usage locale string * 11865 - improve logic so that differentiated warnings are shown depending on whether a slur or other profanity has been used in a display name * 11865 - construct slur regexes outside the validation function in which they are used * 11865 - fix tests
67 lines
2.2 KiB
JavaScript
67 lines
2.2 KiB
JavaScript
import {
|
|
generateUser,
|
|
translate as t,
|
|
} from '../../../../helpers/api-integration/v4';
|
|
|
|
const ENDPOINT = '/user/auth/verify-display-name';
|
|
|
|
describe('POST /user/auth/verify-display-name', async () => {
|
|
let user;
|
|
|
|
beforeEach(async () => {
|
|
user = await generateUser();
|
|
});
|
|
|
|
it('successfully verifies display name including funky characters', async () => {
|
|
const newDisplayName = 'Sabé 🤬';
|
|
const response = await user.post(ENDPOINT, {
|
|
displayName: newDisplayName,
|
|
});
|
|
expect(response).to.eql({ isUsable: true });
|
|
});
|
|
|
|
context('errors', async () => {
|
|
it('errors if display name is not provided', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
})).to.eventually.be.rejected.and.eql({
|
|
code: 400,
|
|
error: 'BadRequest',
|
|
message: t('invalidReqParams'),
|
|
});
|
|
});
|
|
|
|
it('errors if display name is a slur', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
displayName: 'TESTPLACEHOLDERSLURWORDHERE',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('bannedSlurUsedInProfile')] });
|
|
});
|
|
|
|
it('errors if display name contains a slur', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
displayName: 'TESTPLACEHOLDERSLURWORDHERE_otherword',
|
|
})).to.eventually.eql({
|
|
isUsable: false,
|
|
issues: [t('displaynameIssueLength'), t('bannedSlurUsedInProfile')],
|
|
});
|
|
await expect(user.post(ENDPOINT, {
|
|
displayName: 'something_TESTPLACEHOLDERSLURWORDHERE',
|
|
})).to.eventually.eql({
|
|
isUsable: false,
|
|
issues: [t('displaynameIssueLength'), t('bannedSlurUsedInProfile')],
|
|
});
|
|
});
|
|
|
|
it('errors if display name has incorrect length', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
displayName: 'this is a very long display name over 30 characters',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('displaynameIssueLength')] });
|
|
});
|
|
|
|
it('errors if display name contains a newline', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
displayName: 'namecontainsnewline\n',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('displaynameIssueNewline')] });
|
|
});
|
|
});
|
|
});
|