mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 21:27:23 +01:00
Add test case for user that uses social authentication
This commit is contained in:
@@ -110,4 +110,22 @@ describe('POST /user/auth/local/login', () => {
|
|||||||
let isValidPassword = await bcryptCompare(textPassword, user.auth.local.hashed_password);
|
let isValidPassword = await bcryptCompare(textPassword, user.auth.local.hashed_password);
|
||||||
expect(isValidPassword).to.equal(true);
|
expect(isValidPassword).to.equal(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('user uses social authentication and has no password', async () => {
|
||||||
|
await user.unset({
|
||||||
|
'auth.local.hashed_password': 1,
|
||||||
|
});
|
||||||
|
|
||||||
|
await user.sync();
|
||||||
|
expect(user.auth.local.hashed_password).to.be.undefined;
|
||||||
|
|
||||||
|
await expect(api.post(endpoint, {
|
||||||
|
username: user.auth.local.username,
|
||||||
|
password: 'any-password',
|
||||||
|
})).to.eventually.be.rejected.and.eql({
|
||||||
|
code: 401,
|
||||||
|
error: 'NotAuthorized',
|
||||||
|
message: t('invalidLoginCredentialsLong'),
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import { requester } from './requester';
|
|||||||
import {
|
import {
|
||||||
getDocument as getDocumentFromMongo,
|
getDocument as getDocumentFromMongo,
|
||||||
updateDocument as updateDocumentInMongo,
|
updateDocument as updateDocumentInMongo,
|
||||||
|
unsetDocument as unsetDocumentInMongo,
|
||||||
} from '../mongo';
|
} from '../mongo';
|
||||||
import {
|
import {
|
||||||
assign,
|
assign,
|
||||||
@@ -29,6 +30,18 @@ class ApiObject {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async unset (options) {
|
||||||
|
if (isEmpty(options)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await unsetDocumentInMongo(this._docType, this, options);
|
||||||
|
|
||||||
|
_updateLocalParameters((this, options));
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
async sync () {
|
async sync () {
|
||||||
let updatedDoc = await getDocumentFromMongo(this._docType, this);
|
let updatedDoc = await getDocumentFromMongo(this._docType, this);
|
||||||
|
|
||||||
|
|||||||
@@ -98,6 +98,19 @@ export async function updateDocument (collectionName, doc, update) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Unset a property in the database.
|
||||||
|
// Useful for testing.
|
||||||
|
export async function unsetDocument (collectionName, doc, update) {
|
||||||
|
let collection = mongoose.connection.db.collection(collectionName);
|
||||||
|
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
collection.updateOne({ _id: doc._id }, { $unset: update }, (updateErr) => {
|
||||||
|
if (updateErr) throw new Error(`Error updating ${collectionName}: ${updateErr}`);
|
||||||
|
resolve();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
export async function getDocument (collectionName, doc) {
|
export async function getDocument (collectionName, doc) {
|
||||||
let collection = mongoose.connection.db.collection(collectionName);
|
let collection = mongoose.connection.db.collection(collectionName);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user