Skip to content

Commit

Permalink
do not create new user if email is uppercases re #435
Browse files Browse the repository at this point in the history
  • Loading branch information
rassokhin-s committed Oct 24, 2023
1 parent 286f477 commit 89fcd14
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 1 deletion.
70 changes: 70 additions & 0 deletions common/users/index.int.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
const models = require('../../core/_models')
const { truncateNonBase } = require('../testing/sequelize')
const { findOrCreateUser } = require('./index')

const data = { email: 'curious@cat.com', guid: 'ba2d84f2-e9af-495b-943e-f4534722be6f' }
const dataUpper = { email: 'Curious@cat.com', guid: 'ba2d84f2-e9af-495b-943e-f4534722be6e' }

afterEach(async () => {
await truncateNonBase(models)
await models.User.destroy({ where: data })
await models.User.destroy({ where: dataUpper })
})

afterAll(async () => {
await models.sequelize.close()
})

describe('user service -> findOrCreateUser', () => {
test('creates new user with data', async () => {
const usersBefore = await models.User.findAll({ where: data })
expect(usersBefore.length).toBe(0)
const result = await findOrCreateUser(data)
const usersAfter = await models.User.findAll({ where: data })
expect(usersAfter.length).toBe(1)
expect(result[0].guid).toBe(data.guid)
expect(result[0].email).toBe(data.email)
})
test('returns existing user with the same guid and email', async () => {
await models.User.create(data)
const usersBefore = await models.User.findAll({ where: data })
expect(usersBefore.length).toBe(1)
const result = await findOrCreateUser(data)
const usersAfter = await models.User.findAll({ where: data })
expect(usersAfter.length).toBe(1)
expect(result[0].guid).toBe(data.guid)
expect(result[0].email).toBe(data.email)
})
test('returns existing user with the same guid and different email', async () => {
await models.User.create(data)
const newData = { ...data, email: 'small@fox.com' }
const usersBefore = await models.User.findAll({ where: { email: newData.email } })
expect(usersBefore.length).toBe(0)
const result = await findOrCreateUser(newData)
const usersAfter = await models.User.findAll({ where: { email: newData.email } })
expect(usersAfter.length).toBe(0)
expect(result[0].guid).toBe(data.guid)
expect(result[0].email).toBe(data.email)
})
test('returns existing user with the same email and different guid', async () => {
await models.User.create(data)
const newData = { ...data, guid: 'ba2d84f2-e9af-495b-943e-f4534722be6e' }
const usersBefore = await models.User.findAll({ where: { email: newData.guid } })
expect(usersBefore.length).toBe(0)
const result = await findOrCreateUser(newData)
const usersAfter = await models.User.findAll({ where: { email: newData.guid } })
expect(usersAfter.length).toBe(0)
expect(result[0].guid).toBe(data.guid)
expect(result[0].email).toBe(data.email)
})
test('does not create new user if email exists but new one is uppercased', async () => {
await models.User.create(data)
const usersBefore = await models.User.findAll({ where: dataUpper })
expect(usersBefore.length).toBe(0)
const result = await findOrCreateUser(dataUpper)
const usersAfter = await models.User.findAll({ where: dataUpper })
expect(usersAfter.length).toBe(0)
expect(result[0].guid).toBe(data.guid)
expect(result[0].email).toBe(data.email)
})
})
9 changes: 8 additions & 1 deletion common/users/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,14 @@ function fillUserData (data) {

function findOrCreateUser (defaults) {
fillUserData(defaults)
const where = { [Sequelize.Op.or]: { guid: defaults.guid, email: defaults.email } }
const where = {
[Sequelize.Op.or]: {
guid: defaults.guid,
email: {
[Sequelize.Op.iLike]: defaults.email
}
}
}
return User
.findOrCreate({ where, defaults })
.spread((user, created) => {
Expand Down

0 comments on commit 89fcd14

Please sign in to comment.