UNPKG

quodolores

Version:

Monorepo for the Firebase JavaScript SDK

336 lines (291 loc) 9.3 kB
/** * @license * Copyright 2020 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { expect, use } from 'chai'; import * as chaiAsPromised from 'chai-as-promised'; import { ActionCodeOperation } from '../../model/public_types'; import { FirebaseError } from '@firebase/util'; import { Endpoint, HttpHeader } from '../'; import { mockEndpoint } from '../../../test/helpers/api/helper'; import { testAuth, TestAuth } from '../../../test/helpers/mock_auth'; import * as mockFetch from '../../../test/helpers/mock_fetch'; import { ServerError } from '../errors'; import { EmailSignInRequest, PasswordResetRequest, sendEmailVerification, sendPasswordResetEmail, sendSignInLinkToEmail, signInWithPassword, verifyAndChangeEmail, VerifyAndChangeEmailRequest, VerifyEmailRequest } from './email_and_password'; use(chaiAsPromised); describe('api/authentication/signInWithPassword', () => { const request = { returnSecureToken: true, email: 'test@foo.com', password: 'my-password' }; let auth: TestAuth; beforeEach(async () => { auth = await testAuth(); mockFetch.setUp(); }); afterEach(mockFetch.tearDown); it('should POST to the correct endpoint', async () => { const mock = mockEndpoint(Endpoint.SIGN_IN_WITH_PASSWORD, { displayName: 'my-name', email: 'test@foo.com' }); auth.tenantId = 'tenant-id'; const response = await signInWithPassword(auth, request); expect(response.displayName).to.eq('my-name'); expect(response.email).to.eq('test@foo.com'); expect(mock.calls[0].request).to.eql({ ...request, tenantId: 'tenant-id' }); expect(mock.calls[0].method).to.eq('POST'); expect(mock.calls[0].headers!.get(HttpHeader.CONTENT_TYPE)).to.eq( 'application/json' ); expect(mock.calls[0].headers!.get(HttpHeader.X_CLIENT_VERSION)).to.eq( 'testSDK/0.0.0' ); }); it('should handle errors', async () => { const mock = mockEndpoint( Endpoint.SIGN_IN_WITH_PASSWORD, { error: { code: 400, message: ServerError.INVALID_PASSWORD, errors: [ { message: ServerError.INVALID_PASSWORD } ] } }, 400 ); await expect(signInWithPassword(auth, request)).to.be.rejectedWith( FirebaseError, 'Firebase: The password is invalid or the user does not have a password. (auth/wrong-password).' ); expect(mock.calls[0].request).to.eql(request); }); }); describe('api/authentication/sendEmailVerification', () => { const request: VerifyEmailRequest = { requestType: ActionCodeOperation.VERIFY_EMAIL, idToken: 'my-token' }; let auth: TestAuth; beforeEach(async () => { auth = await testAuth(); mockFetch.setUp(); }); afterEach(mockFetch.tearDown); it('should POST to the correct endpoint', async () => { const mock = mockEndpoint(Endpoint.SEND_OOB_CODE, { email: 'test@foo.com' }); auth.tenantId = 'tenant-id'; const response = await sendEmailVerification(auth, request); expect(response.email).to.eq('test@foo.com'); expect(mock.calls[0].request).to.eql({ ...request, tenantId: 'tenant-id' }); expect(mock.calls[0].method).to.eq('POST'); expect(mock.calls[0].headers!.get(HttpHeader.CONTENT_TYPE)).to.eq( 'application/json' ); expect(mock.calls[0].headers!.get(HttpHeader.X_CLIENT_VERSION)).to.eq( 'testSDK/0.0.0' ); }); it('should handle errors', async () => { const mock = mockEndpoint( Endpoint.SEND_OOB_CODE, { error: { code: 400, message: ServerError.INVALID_EMAIL, errors: [ { message: ServerError.INVALID_EMAIL } ] } }, 400 ); await expect(sendEmailVerification(auth, request)).to.be.rejectedWith( FirebaseError, 'Firebase: The email address is badly formatted. (auth/invalid-email).' ); expect(mock.calls[0].request).to.eql(request); }); }); describe('api/authentication/sendPasswordResetEmail', () => { const request: PasswordResetRequest = { requestType: ActionCodeOperation.PASSWORD_RESET, email: 'test@foo.com' }; let auth: TestAuth; beforeEach(async () => { auth = await testAuth(); mockFetch.setUp(); }); afterEach(mockFetch.tearDown); it('should POST to the correct endpoint', async () => { const mock = mockEndpoint(Endpoint.SEND_OOB_CODE, { email: 'test@foo.com' }); auth.tenantId = 'tenant-id'; const response = await sendPasswordResetEmail(auth, request); expect(response.email).to.eq('test@foo.com'); expect(mock.calls[0].request).to.eql({ ...request, tenantId: 'tenant-id' }); expect(mock.calls[0].method).to.eq('POST'); expect(mock.calls[0].headers!.get(HttpHeader.CONTENT_TYPE)).to.eq( 'application/json' ); expect(mock.calls[0].headers!.get(HttpHeader.X_CLIENT_VERSION)).to.eq( 'testSDK/0.0.0' ); }); it('should handle errors', async () => { const mock = mockEndpoint( Endpoint.SEND_OOB_CODE, { error: { code: 400, message: ServerError.INVALID_EMAIL, errors: [ { message: ServerError.INVALID_EMAIL } ] } }, 400 ); await expect(sendPasswordResetEmail(auth, request)).to.be.rejectedWith( FirebaseError, 'Firebase: The email address is badly formatted. (auth/invalid-email).' ); expect(mock.calls[0].request).to.eql(request); }); }); describe('api/authentication/sendSignInLinkToEmail', () => { const request: EmailSignInRequest = { requestType: ActionCodeOperation.EMAIL_SIGNIN, email: 'test@foo.com' }; let auth: TestAuth; beforeEach(async () => { auth = await testAuth(); mockFetch.setUp(); }); afterEach(mockFetch.tearDown); it('should POST to the correct endpoint', async () => { const mock = mockEndpoint(Endpoint.SEND_OOB_CODE, { email: 'test@foo.com' }); auth.tenantId = 'tenant-id'; const response = await sendSignInLinkToEmail(auth, request); expect(response.email).to.eq('test@foo.com'); expect(mock.calls[0].request).to.eql({ ...request, tenantId: 'tenant-id' }); expect(mock.calls[0].method).to.eq('POST'); expect(mock.calls[0].headers!.get(HttpHeader.CONTENT_TYPE)).to.eq( 'application/json' ); expect(mock.calls[0].headers!.get(HttpHeader.X_CLIENT_VERSION)).to.eq( 'testSDK/0.0.0' ); }); it('should handle errors', async () => { const mock = mockEndpoint( Endpoint.SEND_OOB_CODE, { error: { code: 400, message: ServerError.INVALID_EMAIL, errors: [ { message: ServerError.INVALID_EMAIL } ] } }, 400 ); await expect(sendSignInLinkToEmail(auth, request)).to.be.rejectedWith( FirebaseError, 'Firebase: The email address is badly formatted. (auth/invalid-email).' ); expect(mock.calls[0].request).to.eql(request); }); }); describe('api/authentication/verifyAndChangeEmail', () => { const request: VerifyAndChangeEmailRequest = { requestType: ActionCodeOperation.VERIFY_AND_CHANGE_EMAIL, idToken: 'id-token', newEmail: 'test@foo.com' }; let auth: TestAuth; beforeEach(async () => { auth = await testAuth(); mockFetch.setUp(); }); afterEach(mockFetch.tearDown); it('should POST to the correct endpoint', async () => { const mock = mockEndpoint(Endpoint.SEND_OOB_CODE, { email: 'test@foo.com' }); auth.tenantId = 'tenant-id'; const response = await verifyAndChangeEmail(auth, request); expect(response.email).to.eq('test@foo.com'); expect(mock.calls[0].request).to.eql({ ...request, tenantId: 'tenant-id' }); expect(mock.calls[0].method).to.eq('POST'); expect(mock.calls[0].headers!.get(HttpHeader.CONTENT_TYPE)).to.eq( 'application/json' ); expect(mock.calls[0].headers!.get(HttpHeader.X_CLIENT_VERSION)).to.eq( 'testSDK/0.0.0' ); }); it('should handle errors', async () => { const mock = mockEndpoint( Endpoint.SEND_OOB_CODE, { error: { code: 400, message: ServerError.INVALID_EMAIL, errors: [ { message: ServerError.INVALID_EMAIL } ] } }, 400 ); await expect(verifyAndChangeEmail(auth, request)).to.be.rejectedWith( FirebaseError, 'Firebase: The email address is badly formatted. (auth/invalid-email).' ); expect(mock.calls[0].request).to.eql(request); }); });