mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 21:27:23 +01:00
Added tests for Facebook auth
This commit is contained in:
@@ -13,6 +13,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
api = requester();
|
api = requester();
|
||||||
user = await generateUser();
|
user = await generateUser();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('success with username', async () => {
|
it('success with username', async () => {
|
||||||
let response = await api.post(endpoint, {
|
let response = await api.post(endpoint, {
|
||||||
username: user.auth.local.username,
|
username: user.auth.local.username,
|
||||||
@@ -20,6 +21,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
});
|
});
|
||||||
expect(response.apiToken).to.eql(user.apiToken);
|
expect(response.apiToken).to.eql(user.apiToken);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('success with email', async () => {
|
it('success with email', async () => {
|
||||||
let response = await api.post(endpoint, {
|
let response = await api.post(endpoint, {
|
||||||
username: user.auth.local.email,
|
username: user.auth.local.email,
|
||||||
@@ -27,6 +29,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
});
|
});
|
||||||
expect(response.apiToken).to.eql(user.apiToken);
|
expect(response.apiToken).to.eql(user.apiToken);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('user is blocked', async () => {
|
it('user is blocked', async () => {
|
||||||
await user.update({ 'auth.blocked': 1 });
|
await user.update({ 'auth.blocked': 1 });
|
||||||
await expect(api.post(endpoint, {
|
await expect(api.post(endpoint, {
|
||||||
@@ -38,6 +41,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
message: t('accountSuspended', { userId: user._id }),
|
message: t('accountSuspended', { userId: user._id }),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('wrong password', async () => {
|
it('wrong password', async () => {
|
||||||
await expect(api.post(endpoint, {
|
await expect(api.post(endpoint, {
|
||||||
username: user.auth.local.username,
|
username: user.auth.local.username,
|
||||||
@@ -48,6 +52,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
message: t('invalidLoginCredentialsLong'),
|
message: t('invalidLoginCredentialsLong'),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('missing username', async () => {
|
it('missing username', async () => {
|
||||||
await expect(api.post(endpoint, {
|
await expect(api.post(endpoint, {
|
||||||
password: 'wrong-password',
|
password: 'wrong-password',
|
||||||
@@ -57,6 +62,7 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
message: t('invalidReqParams'),
|
message: t('invalidReqParams'),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('missing password', async () => {
|
it('missing password', async () => {
|
||||||
await expect(api.post(endpoint, {
|
await expect(api.post(endpoint, {
|
||||||
username: user.auth.local.username,
|
username: user.auth.local.username,
|
||||||
|
|||||||
@@ -0,0 +1,59 @@
|
|||||||
|
import {
|
||||||
|
generateUser,
|
||||||
|
requester,
|
||||||
|
translate as t,
|
||||||
|
} from '../../../../../helpers/api-integration/v3';
|
||||||
|
import passport from 'passport';
|
||||||
|
|
||||||
|
describe('POST /user/auth/social', () => {
|
||||||
|
let api;
|
||||||
|
let user;
|
||||||
|
let endpoint = '/user/auth/social';
|
||||||
|
let randomAccessToken = '123456';
|
||||||
|
let facebookId = 'facebookId';
|
||||||
|
let network = 'facebook';
|
||||||
|
|
||||||
|
before(async () => {
|
||||||
|
api = requester();
|
||||||
|
user = await generateUser();
|
||||||
|
|
||||||
|
let expectedResult = {id: facebookId};
|
||||||
|
let passportFacebookProfile = sinon.stub(passport._strategies.facebook, 'userProfile');
|
||||||
|
passportFacebookProfile.yields(null, expectedResult);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('fails if network is not facebook', async () => {
|
||||||
|
await expect(api.post(endpoint, {
|
||||||
|
authResponse: {access_token: randomAccessToken},
|
||||||
|
network: 'NotFacebook',
|
||||||
|
})).to.eventually.be.rejected.and.eql({
|
||||||
|
code: 401,
|
||||||
|
error: 'NotAuthorized',
|
||||||
|
message: t('onlyFbSupported'),
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('registers a new user', async () => {
|
||||||
|
let response = await api.post(endpoint, {
|
||||||
|
authResponse: {access_token: randomAccessToken},
|
||||||
|
network,
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(response.apiToken).to.exist;
|
||||||
|
expect(response.id).to.exist;
|
||||||
|
expect(response.newUser).to.be.true;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('logs an existing user in', async () => {
|
||||||
|
await user.update({ 'auth.facebook.id': facebookId });
|
||||||
|
|
||||||
|
let response = await api.post(endpoint, {
|
||||||
|
authResponse: {access_token: randomAccessToken},
|
||||||
|
network,
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(response.apiToken).to.eql(user.apiToken);
|
||||||
|
expect(response.id).to.eql(user._id);
|
||||||
|
expect(response.newUser).to.be.false;
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -162,10 +162,8 @@ api.registerLocal = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
function _loginRes (user, req, res) {
|
function _loginRes (user, req, res) {
|
||||||
var newUser = false;
|
|
||||||
if (user.newUser) newUser = true;
|
|
||||||
if (user.auth.blocked) throw new NotAuthorized(res.t('accountSuspended', {userId: user._id}));
|
if (user.auth.blocked) throw new NotAuthorized(res.t('accountSuspended', {userId: user._id}));
|
||||||
return res.respond(200, {id: user._id, apiToken: user.apiToken, newUser});
|
return res.respond(200, {id: user._id, apiToken: user.apiToken, newUser: user.newUser || false});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user