diff --git a/services/web/app/src/Features/User/UserUpdater.js b/services/web/app/src/Features/User/UserUpdater.js index b705819e05..baf905a7e6 100644 --- a/services/web/app/src/Features/User/UserUpdater.js +++ b/services/web/app/src/Features/User/UserUpdater.js @@ -104,7 +104,7 @@ async function addEmailAddress(userId, newEmail, affiliationOptions, auditLog) { emails: { email: newEmail, createdAt: new Date(), reversedHostname }, }, } - await updateUser(userId, update) + await updateUser({ _id: userId, 'emails.email': { $ne: newEmail } }, update) } catch (error) { throw OError.tag(error, 'problem updating users emails') } diff --git a/services/web/test/unit/src/User/UserUpdaterTests.js b/services/web/test/unit/src/User/UserUpdaterTests.js index 0635abc857..641b0251b8 100644 --- a/services/web/test/unit/src/User/UserUpdaterTests.js +++ b/services/web/test/unit/src/User/UserUpdaterTests.js @@ -199,7 +199,7 @@ describe('UserUpdater', function () { it('adds the new email', function () { expect(this.db.users.updateOne).to.have.been.calledWith( - { _id: this.user._id }, + { _id: this.user._id, 'emails.email': { $ne: this.newEmail } }, { $push: { emails: sinon.match({ email: this.newEmail }), @@ -281,7 +281,7 @@ describe('UserUpdater', function () { .reverse() .join('') this.db.users.updateOne.should.have.been.calledWith( - { _id: this.user._id }, + { _id: this.user._id, 'emails.email': { $ne: this.newEmail } }, { $push: { emails: {