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

3
.gitignore vendored
View File

@@ -5,4 +5,5 @@ package-lock.json
config.json
coverage
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('sequelize', () => jest.fn());
const { EmbedBuilder } = await import ("@fluxerjs/core");
const { database } = await import('../../src/db.js');
const { EmptyResultError, Op } = await import ('sequelize');
import { enums } from "../../src/enums.js";
import { memberHelper } from "../../src/helpers/memberHelper.js";
const {EmbedBuilder} = await import ("@fluxerjs/core");
const {database} = await import('../../src/db.js');
const {EmptyResultError, Op} = await import ('sequelize');
import {enums} from "../../src/enums.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(() => {
jest.resetModules();
jest.clearAllMocks();
jest.spyOn(memberHelper, 'getMemberInfo').mockResolvedValue("member info");
jest.spyOn(memberHelper, 'addNewMember').mockResolvedValue("new member");
jest.spyOn(memberHelper, 'removeMember').mockResolvedValue("remove member");
jest.spyOn(memberHelper, 'getAllMembersInfo').mockResolvedValue("all member info");
jest.spyOn(memberHelper, 'updateName').mockResolvedValue("update name");
jest.spyOn(memberHelper, 'updateDisplayName').mockResolvedValue("update display name");
jest.spyOn(memberHelper, 'updateProxy').mockResolvedValue("update proxy");
jest.spyOn(memberHelper, 'updatePropic').mockResolvedValue("update propic");
jest.spyOn(memberHelper, 'getProxyByMember').mockResolvedValue("update proxy");
});
describe('parseMemberCommand', () => {
beforeEach(() => {
jest.resetModules();
jest.clearAllMocks();
jest.spyOn(memberHelper, 'getMemberInfo').mockResolvedValue("member info");
jest.spyOn(memberHelper, 'addNewMember').mockResolvedValue("new member");
jest.spyOn(memberHelper, 'removeMember').mockResolvedValue("remove member");
jest.spyOn(memberHelper, 'getAllMembersInfo').mockResolvedValue("all member info");
jest.spyOn(memberHelper, 'updateName').mockResolvedValue("update name");
jest.spyOn(memberHelper, 'updateDisplayName').mockResolvedValue("update display name");
jest.spyOn(memberHelper, 'updateProxy').mockResolvedValue("update proxy");
jest.spyOn(memberHelper, 'updatePropic').mockResolvedValue("update propic");
jest.spyOn(memberHelper, 'getProxyByMember').mockResolvedValue("update proxy");
});
test.each([
[['--help'], enums.help.MEMBER],
[['new'], 'new member'],
[['remove'], 'remove member'],
[['name'], enums.help.NAME],
[['displayname'], enums.help.DISPLAY_NAME],
[['proxy'], enums.help.PROXY],
[['propic'], enums.help.PROPIC],
[['list'], 'all member info'],
[[''], enums.help.MEMBER],
[['somePerson', 'new'], enums.help.NEW],
[['somePerson', 'name'], 'update name'],
[['somePerson', 'displayname'], 'update display name'],
[['somePerson', 'proxy'], 'update proxy'],
[['somePerson', 'propic'], 'update propic'],
[['somePerson'], 'member info'],
])('%s returns correct values', async(args, expectedResult) => {
// Arrange
const authorId = '1';
const authorFull = 'somePerson#0001';
// Act
const result = await memberHelper.parseMemberCommand(authorId, authorFull, args);
//
expect(result).toEqual(expectedResult);
});
test.each([
// [['--help'], enums.help.MEMBER],
[['new'], 'new member', memberHelper.addNewMember, [authorId, ['new']]],
[['remove'], 'remove member', memberHelper.removeMember, [authorId, ['remove']]],
[['list'], 'all member info', memberHelper.getAllMembersInfo, [authorId, ['list']]],
[['somePerson', 'name'], 'update name', memberHelper.updateName, [authorId, ['somePerson', 'name']]],
[['somePerson', 'displayname'], 'update display name', memberHelper.updateDisplayName, [authorId, ['somePerson', 'displayname']]],
[['somePerson', 'proxy'], 'update proxy', memberHelper.addNewMember, [authorId, 'somePerson']],
[['somePerson', 'proxy', 'test'], 'update proxy', memberHelper.addNewMember, [authorId, ['somePerson', 'proxy', 'test']]],
[['somePerson', 'propic'], 'update propic', memberHelper.updatePropic, [authorId, ['somePerson', 'propic']]],
[['somePerson'], 'member info', memberHelper.getMemberInfo, [authorId, 'somePerson']],
])('%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);
expect(method).toHaveBeenCalledTimes(1);
expect(method).toHaveBeenCalledWith(passedIn)
});
});
afterEach(() => {
// restore the spy created with spyOn
jest.restoreAllMocks();
});
test.each([
[['--help'], enums.help.MEMBER],
[['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();
});
})
})