separating out enum return from method return

This commit is contained in:
Aster Fialla
2026-02-17 19:36:14 -05:00
parent ba9552b4aa
commit 4fcb53482c
2 changed files with 74 additions and 49 deletions

1
.gitignore vendored
View File

@@ -6,3 +6,4 @@ config.json
coverage coverage
log.txt log.txt
.env .env
oya.png

View File

@@ -4,58 +4,82 @@ jest.unstable_mockModule('@fluxerjs/core', () => jest.fn());
jest.unstable_mockModule('../../src/db.js', () => jest.fn()); jest.unstable_mockModule('../../src/db.js', () => jest.fn());
jest.unstable_mockModule('sequelize', () => jest.fn()); jest.unstable_mockModule('sequelize', () => jest.fn());
const { EmbedBuilder } = await import ("@fluxerjs/core"); const {EmbedBuilder} = await import ("@fluxerjs/core");
const { database } = await import('../../src/db.js'); const {database} = await import('../../src/db.js');
const { EmptyResultError, Op } = await import ('sequelize'); const {EmptyResultError, Op} = await import ('sequelize');
import { enums } from "../../src/enums.js"; import {enums} from "../../src/enums.js";
import { memberHelper } from "../../src/helpers/memberHelper.js"; import {memberHelper} from "../../src/helpers/memberHelper.js";
import * as test from "node:test";
describe('parseMemberCommand', () => { describe('MemberHelper', () => {
const authorId = "0001";
const authorFull = "author#0001";
const attachmentUrl = "../oya.png";
const attachmentExpiration = new Date('2026-01-01T00.00.00.0000Z')
beforeEach(() => { describe('parseMemberCommand', () => {
jest.resetModules();
jest.clearAllMocks(); beforeEach(() => {
jest.spyOn(memberHelper, 'getMemberInfo').mockResolvedValue("member info"); jest.resetModules();
jest.spyOn(memberHelper, 'addNewMember').mockResolvedValue("new member"); jest.clearAllMocks();
jest.spyOn(memberHelper, 'removeMember').mockResolvedValue("remove member"); jest.spyOn(memberHelper, 'getMemberInfo').mockResolvedValue("member info");
jest.spyOn(memberHelper, 'getAllMembersInfo').mockResolvedValue("all member info"); jest.spyOn(memberHelper, 'addNewMember').mockResolvedValue("new member");
jest.spyOn(memberHelper, 'updateName').mockResolvedValue("update name"); jest.spyOn(memberHelper, 'removeMember').mockResolvedValue("remove member");
jest.spyOn(memberHelper, 'updateDisplayName').mockResolvedValue("update display name"); jest.spyOn(memberHelper, 'getAllMembersInfo').mockResolvedValue("all member info");
jest.spyOn(memberHelper, 'updateProxy').mockResolvedValue("update proxy"); jest.spyOn(memberHelper, 'updateName').mockResolvedValue("update name");
jest.spyOn(memberHelper, 'updatePropic').mockResolvedValue("update propic"); jest.spyOn(memberHelper, 'updateDisplayName').mockResolvedValue("update display name");
jest.spyOn(memberHelper, 'getProxyByMember').mockResolvedValue("update proxy"); jest.spyOn(memberHelper, 'updateProxy').mockResolvedValue("update proxy");
}); jest.spyOn(memberHelper, 'updatePropic').mockResolvedValue("update propic");
jest.spyOn(memberHelper, 'getProxyByMember').mockResolvedValue("update proxy");
});
test.each([ test.each([
[['--help'], enums.help.MEMBER], // [['--help'], enums.help.MEMBER],
[['new'], 'new member'], [['new'], 'new member', memberHelper.addNewMember, [authorId, ['new']]],
[['remove'], 'remove member'], [['remove'], 'remove member', memberHelper.removeMember, [authorId, ['remove']]],
[['name'], enums.help.NAME], [['list'], 'all member info', memberHelper.getAllMembersInfo, [authorId, ['list']]],
[['displayname'], enums.help.DISPLAY_NAME], [['somePerson', 'name'], 'update name', memberHelper.updateName, [authorId, ['somePerson', 'name']]],
[['proxy'], enums.help.PROXY], [['somePerson', 'displayname'], 'update display name', memberHelper.updateDisplayName, [authorId, ['somePerson', 'displayname']]],
[['propic'], enums.help.PROPIC], [['somePerson', 'proxy'], 'update proxy', memberHelper.addNewMember, [authorId, 'somePerson']],
[['list'], 'all member info'], [['somePerson', 'proxy', 'test'], 'update proxy', memberHelper.addNewMember, [authorId, ['somePerson', 'proxy', 'test']]],
[[''], enums.help.MEMBER], [['somePerson', 'propic'], 'update propic', memberHelper.updatePropic, [authorId, ['somePerson', 'propic']]],
[['somePerson', 'new'], enums.help.NEW], [['somePerson'], 'member info', memberHelper.getMemberInfo, [authorId, 'somePerson']],
[['somePerson', 'name'], 'update name'], ])('%s returns correct values', async (args, expectedResult, method, passedIn) => {
[['somePerson', 'displayname'], 'update display name'], // Arrange
[['somePerson', 'proxy'], 'update proxy'], const authorId = '1';
[['somePerson', 'propic'], 'update propic'], const authorFull = 'somePerson#0001';
[['somePerson'], 'member info'], // Act
])('%s returns correct values', async(args, expectedResult) => { memberHelper.parseMemberCommand(authorId, authorFull, args).then((result) => {
// Arrange expect(result).toEqual(expectedResult);
const authorId = '1'; expect(method).toHaveBeenCalledTimes(1);
const authorFull = 'somePerson#0001'; expect(method).toHaveBeenCalledWith(passedIn)
// Act });
const result = await memberHelper.parseMemberCommand(authorId, authorFull, args); });
//
expect(result).toEqual(expectedResult);
});
afterEach(() => { test.each([
// restore the spy created with spyOn [['--help'], enums.help.MEMBER],
jest.restoreAllMocks(); [['name'], enums.help.NAME],
}); [['displayname'], enums.help.DISPLAY_NAME],
[['proxy'], enums.help.PROXY],
[['propic'], enums.help.PROPIC],
[['list', '--help'], enums.help.LIST],
[[''], enums.help.MEMBER],
])('%s returns correct values', async (args, expectedResult, method, passedIn) => {
// Arrange
const authorId = '1';
const authorFull = 'somePerson#0001';
// Act
memberHelper.parseMemberCommand(authorId, authorFull, args).then((result) => {
expect(result).toEqual(expectedResult);
});
});
afterEach(() => {
// restore the spy created with spyOn
jest.restoreAllMocks();
});
})
}) })