forked from PluralFlux/PluralFlux
separating out enum return from method return
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@@ -5,4 +5,5 @@ package-lock.json
|
||||
config.json
|
||||
coverage
|
||||
log.txt
|
||||
.env
|
||||
.env
|
||||
oya.png
|
||||
@@ -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();
|
||||
});
|
||||
})
|
||||
})
|
||||
|
||||
|
||||
Reference in New Issue
Block a user