mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 13:17:24 +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
87 lines
3.1 KiB
JavaScript
87 lines
3.1 KiB
JavaScript
import {
|
|
generateUser,
|
|
translate as t,
|
|
} from '../../../../helpers/api-integration/v4';
|
|
|
|
const ENDPOINT = '/user/auth/verify-username';
|
|
|
|
describe('POST /user/auth/verify-username', async () => {
|
|
let user;
|
|
|
|
beforeEach(async () => {
|
|
user = await generateUser();
|
|
});
|
|
|
|
it('successfully verifies username', async () => {
|
|
const newUsername = 'new-username';
|
|
const response = await user.post(ENDPOINT, {
|
|
username: newUsername,
|
|
});
|
|
expect(response).to.eql({ isUsable: true });
|
|
});
|
|
|
|
it('successfully verifies username with allowed characters', async () => {
|
|
const newUsername = 'new-username_123';
|
|
const response = await user.post(ENDPOINT, {
|
|
username: newUsername,
|
|
});
|
|
expect(response).to.eql({ isUsable: true });
|
|
});
|
|
|
|
context('errors', async () => {
|
|
it('errors if username 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 username is a slur', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'TESTPLACEHOLDERSLURWORDHERE',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueLength'), t('usernameIssueSlur')] });
|
|
});
|
|
|
|
it('errors if username contains a slur', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'TESTPLACEHOLDERSLURWORDHERE_otherword',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueLength'), t('usernameIssueSlur')] });
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'something_TESTPLACEHOLDERSLURWORDHERE',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueLength'), t('usernameIssueSlur')] });
|
|
});
|
|
|
|
it('errors if username is not allowed', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'support',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueForbidden')] });
|
|
});
|
|
|
|
it('errors if username is not allowed regardless of casing', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'SUppORT',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueForbidden')] });
|
|
});
|
|
|
|
it('errors if username has incorrect length', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'thisisaverylongusernameover20characters',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueLength')] });
|
|
});
|
|
|
|
it('errors if username contains invalid characters', async () => {
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'Eichhörnchen',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueInvalidCharacters')] });
|
|
await expect(user.post(ENDPOINT, {
|
|
username: 'test.name',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueInvalidCharacters')] });
|
|
await expect(user.post(ENDPOINT, {
|
|
username: '🤬',
|
|
})).to.eventually.eql({ isUsable: false, issues: [t('usernameIssueInvalidCharacters')] });
|
|
});
|
|
});
|
|
});
|