fix: valid username lowercase (#42172)
* fix: valid username lowercase * test: add test in the validate for reject uppercase characters * test: add test in the cypress for check on uppercase characters and reject it.
This commit is contained in:
@ -102,6 +102,7 @@
|
|||||||
"contains invalid characters": "Username \"{{username}}\" contains invalid characters",
|
"contains invalid characters": "Username \"{{username}}\" contains invalid characters",
|
||||||
"is too short": "Username \"{{username}}\" is too short",
|
"is too short": "Username \"{{username}}\" is too short",
|
||||||
"is a reserved error code": "Username \"{{username}}\" is a reserved error code",
|
"is a reserved error code": "Username \"{{username}}\" is a reserved error code",
|
||||||
|
"must be lowercase": "Username \"{{username}}\" must be lowercase",
|
||||||
"unavailable": "Username not available",
|
"unavailable": "Username not available",
|
||||||
"validating": "Validating username...",
|
"validating": "Validating username...",
|
||||||
"available": "Username is available",
|
"available": "Username is available",
|
||||||
|
@ -98,7 +98,7 @@ class UsernameSettings extends Component {
|
|||||||
handleChange(e) {
|
handleChange(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
const { username, validateUsername } = this.props;
|
const { username, validateUsername } = this.props;
|
||||||
const newValue = e.target.value.toLowerCase();
|
const newValue = e.target.value;
|
||||||
return this.setState(
|
return this.setState(
|
||||||
{
|
{
|
||||||
formValue: newValue,
|
formValue: newValue,
|
||||||
|
@ -121,7 +121,7 @@ describe('Username input field', () => {
|
|||||||
.clear({ force: true })
|
.clear({ force: true })
|
||||||
.type('Quincy Larson', { force: true });
|
.type('Quincy Larson', { force: true });
|
||||||
|
|
||||||
cy.contains('Username "quincy larson" contains invalid characters')
|
cy.contains('Username "Quincy Larson" contains invalid characters')
|
||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.should('have.attr', 'role', 'alert')
|
.should('have.attr', 'role', 'alert')
|
||||||
// We are checking for classes here to check for proper styling
|
// We are checking for classes here to check for proper styling
|
||||||
@ -198,4 +198,22 @@ describe('Username input field', () => {
|
|||||||
|
|
||||||
cy.resetUsername();
|
cy.resetUsername();
|
||||||
});
|
});
|
||||||
|
it('Should show warning if username includes uppercase characters', () => {
|
||||||
|
cy.get('@usernameInput')
|
||||||
|
.clear({ force: true })
|
||||||
|
.type('QuincyLarson', { force: true });
|
||||||
|
|
||||||
|
cy.contains('Username "QuincyLarson" must be lowercase')
|
||||||
|
.should('be.visible')
|
||||||
|
.should('have.attr', 'role', 'alert')
|
||||||
|
.should('have.class', 'alert alert-danger');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('Should not be able to click the `Save` button if username includes uppercase characters', () => {
|
||||||
|
cy.get('@usernameInput')
|
||||||
|
.clear({ force: true })
|
||||||
|
.type('QuincyLarson', { force: true });
|
||||||
|
|
||||||
|
cy.get('@usernameForm').contains('Save').should('be.disabled');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@ -8,15 +8,20 @@ const usernameIsHttpStatusCode = {
|
|||||||
valid: false,
|
valid: false,
|
||||||
error: 'is a reserved error code'
|
error: 'is a reserved error code'
|
||||||
};
|
};
|
||||||
|
const usernameUpperCase = { valid: false, error: 'must be lowercase' };
|
||||||
|
|
||||||
const isNumeric = num => !isNaN(num);
|
const isNumeric = num => !isNaN(num);
|
||||||
const validCharsRE = /^[a-zA-Z0-9\-_+]*$/;
|
const validCharsRE = /^[a-zA-Z0-9\-_+]*$/;
|
||||||
const isHttpStatusCode = str =>
|
const isHttpStatusCode = str =>
|
||||||
isNumeric(str) && parseInt(str, 10) >= 100 && parseInt(str, 10) <= 599;
|
isNumeric(str) && parseInt(str, 10) >= 100 && parseInt(str, 10) <= 599;
|
||||||
|
const isUsernameLowercase = str => {
|
||||||
|
return str === str.toLowerCase();
|
||||||
|
};
|
||||||
const isValidUsername = str => {
|
const isValidUsername = str => {
|
||||||
if (!validCharsRE.test(str)) return invalidCharError;
|
if (!validCharsRE.test(str)) return invalidCharError;
|
||||||
if (str.length < 3) return usernameTooShort;
|
if (str.length < 3) return usernameTooShort;
|
||||||
if (isHttpStatusCode(str)) return usernameIsHttpStatusCode;
|
if (isHttpStatusCode(str)) return usernameIsHttpStatusCode;
|
||||||
|
if (!isUsernameLowercase(str)) return usernameUpperCase;
|
||||||
return validationSuccess;
|
return validationSuccess;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -24,8 +29,10 @@ module.exports = {
|
|||||||
isNumeric,
|
isNumeric,
|
||||||
isHttpStatusCode,
|
isHttpStatusCode,
|
||||||
isValidUsername,
|
isValidUsername,
|
||||||
|
isUsernameLowercase,
|
||||||
validationSuccess,
|
validationSuccess,
|
||||||
usernameTooShort,
|
usernameTooShort,
|
||||||
usernameIsHttpStatusCode,
|
usernameIsHttpStatusCode,
|
||||||
invalidCharError
|
invalidCharError,
|
||||||
|
usernameUpperCase
|
||||||
};
|
};
|
||||||
|
@ -5,7 +5,8 @@ const {
|
|||||||
usernameTooShort,
|
usernameTooShort,
|
||||||
validationSuccess,
|
validationSuccess,
|
||||||
usernameIsHttpStatusCode,
|
usernameIsHttpStatusCode,
|
||||||
invalidCharError
|
invalidCharError,
|
||||||
|
usernameUpperCase
|
||||||
} = require('./validate');
|
} = require('./validate');
|
||||||
|
|
||||||
function inRange(num, range) {
|
function inRange(num, range) {
|
||||||
@ -38,6 +39,9 @@ describe('isValidUsername', () => {
|
|||||||
expect(isValidUsername('a-b')).toStrictEqual(validationSuccess);
|
expect(isValidUsername('a-b')).toStrictEqual(validationSuccess);
|
||||||
expect(isValidUsername('a_b')).toStrictEqual(validationSuccess);
|
expect(isValidUsername('a_b')).toStrictEqual(validationSuccess);
|
||||||
});
|
});
|
||||||
|
it('rejects uppercase characters', () => {
|
||||||
|
expect(isValidUsername('Quincy')).toStrictEqual(usernameUpperCase);
|
||||||
|
});
|
||||||
|
|
||||||
it('rejects all other ASCII characters', () => {
|
it('rejects all other ASCII characters', () => {
|
||||||
const allowedCharactersList = ['-', '_', '+'];
|
const allowedCharactersList = ['-', '_', '+'];
|
||||||
@ -52,7 +56,7 @@ describe('isValidUsername', () => {
|
|||||||
let expected = invalidCharError;
|
let expected = invalidCharError;
|
||||||
if (allowedCharactersList.includes(char)) expected = validationSuccess;
|
if (allowedCharactersList.includes(char)) expected = validationSuccess;
|
||||||
if (inRange(code, numbers)) expected = validationSuccess;
|
if (inRange(code, numbers)) expected = validationSuccess;
|
||||||
if (inRange(code, upperCase)) expected = validationSuccess;
|
if (inRange(code, upperCase)) expected = usernameUpperCase;
|
||||||
if (inRange(code, lowerCase)) expected = validationSuccess;
|
if (inRange(code, lowerCase)) expected = validationSuccess;
|
||||||
expect(isValidUsername(base + char)).toStrictEqual(expected);
|
expect(isValidUsername(base + char)).toStrictEqual(expected);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user