fix(core): Fix user-management:reset command (#3403)

* 🐛 Fix `email` setting

* 🧪 Add test

* 🧪 Add expectation for user email

*  Replace request with helper
This commit is contained in:
Iván Ovejero 2022-06-03 17:44:34 +02:00 committed by GitHub
parent a5d2ddfa26
commit 58ecadf53c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 1 deletions

View file

@ -133,7 +133,7 @@ export class User {
@BeforeInsert() @BeforeInsert()
@BeforeUpdate() @BeforeUpdate()
preUpsertHook(): void { preUpsertHook(): void {
this.email = this.email?.toLowerCase(); this.email = this.email?.toLowerCase() ?? null;
this.updatedAt = new Date(); this.updatedAt = new Date();
} }

View file

@ -0,0 +1,44 @@
import { execSync } from 'child_process';
import express from 'express';
import path from 'path';
import { Db } from '../../../src';
import * as utils from '../shared/utils';
import type { Role } from '../../../src/databases/entities/Role';
import * as testDb from '../shared/testDb';
import { randomEmail, randomName, randomValidPassword } from '../shared/random';
let app: express.Application;
let testDbName = '';
let globalOwnerRole: Role;
beforeAll(async () => {
app = utils.initTestServer({ endpointGroups: ['owner'], applyAuth: true });
const initResult = await testDb.init();
testDbName = initResult.testDbName;
globalOwnerRole = await testDb.getGlobalOwnerRole();
});
afterAll(async () => {
await testDb.terminate(testDbName);
});
test('user-management:reset should reset DB to default user state', async () => {
await testDb.createUser({ globalRole: globalOwnerRole });
const command = [path.join('bin', 'n8n'), 'user-management:reset'].join(' ');
execSync(command);
const user = await Db.collections.User.findOne();
expect(user?.email).toBeNull();
expect(user?.firstName).toBeNull();
expect(user?.lastName).toBeNull();
expect(user?.password).toBeNull();
expect(user?.resetPasswordToken).toBeNull();
expect(user?.resetPasswordTokenExpiration).toBeNull();
expect(user?.personalizationAnswers).toBeNull();
});