- await verifyEmail(server.url, userId, verificationString)
- await login(server.url, server.client, user1)
- const resUserVerified = await getUserInformation(server.url, server.accessToken, userId)
- expect(resUserVerified.body.emailVerified).to.be.true
+ await server.users.verifyEmail({ userId, verificationString })
+
+ const body = await server.login.login({ user: user1 })
+ userAccessToken = body.access_token
+
+ const user = await server.users.get({ userId })
+ expect(user.emailVerified).to.be.true
+ })
+
+ it('Should be able to change the user email', async function () {
+ this.timeout(10000)
+
+ let updateVerificationString: string
+
+ {
+ await server.users.updateMe({
+ token: userAccessToken,
+ email: 'updated@example.com',
+ currentPassword: user1.password
+ })
+
+ await waitJobs(server)
+ expectedEmailsLength++
+ expect(emails).to.have.lengthOf(expectedEmailsLength)
+
+ const email = emails[expectedEmailsLength - 1]
+
+ const verificationStringMatches = /verificationString=([a-z0-9]+)/.exec(email['text'])
+ updateVerificationString = verificationStringMatches[1]
+ }
+
+ {
+ const me = await server.users.getMyInfo({ token: userAccessToken })
+ expect(me.email).to.equal('user_1@example.com')
+ expect(me.pendingEmail).to.equal('updated@example.com')
+ }
+
+ {
+ await server.users.verifyEmail({ userId, verificationString: updateVerificationString, isPendingEmail: true })
+
+ const me = await server.users.getMyInfo({ token: userAccessToken })
+ expect(me.email).to.equal('updated@example.com')
+ expect(me.pendingEmail).to.be.null
+ }