fix: Group membership count off after suspending users in groups (#1670)
* fix: Clear group memberships when suspending a user Refactor to command * test * test
This commit is contained in:
57
server/commands/userSuspender.test.js
Normal file
57
server/commands/userSuspender.test.js
Normal file
@@ -0,0 +1,57 @@
|
||||
/* eslint-disable flowtype/require-valid-file-annotation */
|
||||
import { GroupUser } from "../models";
|
||||
import { buildGroup, buildUser } from "../test/factories";
|
||||
import { flushdb } from "../test/support";
|
||||
import userSuspender from "./userSuspender";
|
||||
|
||||
beforeEach(() => flushdb());
|
||||
|
||||
describe("userSuspender", () => {
|
||||
const ip = "127.0.0.1";
|
||||
|
||||
it("should not suspend self", async () => {
|
||||
const user = await buildUser();
|
||||
let error;
|
||||
|
||||
try {
|
||||
await userSuspender({
|
||||
actorId: user.id,
|
||||
user,
|
||||
ip,
|
||||
});
|
||||
} catch (err) {
|
||||
error = err;
|
||||
}
|
||||
|
||||
expect(error.message).toEqual("Unable to suspend the current user");
|
||||
});
|
||||
|
||||
it("should suspend the user", async () => {
|
||||
const admin = await buildUser({ isAdmin: true });
|
||||
const user = await buildUser({ teamId: admin.teamId });
|
||||
await userSuspender({
|
||||
actorId: admin.id,
|
||||
user,
|
||||
ip,
|
||||
});
|
||||
expect(user.suspendedAt).toBeTruthy();
|
||||
expect(user.suspendedById).toEqual(admin.id);
|
||||
});
|
||||
|
||||
it("should remove group memberships", async () => {
|
||||
const admin = await buildUser({ isAdmin: true });
|
||||
const user = await buildUser({ teamId: admin.teamId });
|
||||
const group = await buildGroup({ teamId: user.teamId });
|
||||
|
||||
await group.addUser(user, { through: { createdById: user.id } });
|
||||
|
||||
await userSuspender({
|
||||
actorId: admin.id,
|
||||
user,
|
||||
ip,
|
||||
});
|
||||
expect(user.suspendedAt).toBeTruthy();
|
||||
expect(user.suspendedById).toEqual(admin.id);
|
||||
expect(await GroupUser.count()).toEqual(0);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user