quodolores
Version:
Monorepo for the Firebase JavaScript SDK
336 lines (291 loc) • 9.3 kB
text/typescript
/**
* @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);
});
});