forked from PluralFlux/PluralFlux
separating out enum return from method return
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -6,3 +6,4 @@ config.json
|
|||||||
coverage
|
coverage
|
||||||
log.txt
|
log.txt
|
||||||
.env
|
.env
|
||||||
|
oya.png
|
||||||
@@ -9,6 +9,13 @@ 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('MemberHelper', () => {
|
||||||
|
const authorId = "0001";
|
||||||
|
const authorFull = "author#0001";
|
||||||
|
const attachmentUrl = "../oya.png";
|
||||||
|
const attachmentExpiration = new Date('2026-01-01T00.00.00.0000Z')
|
||||||
|
|
||||||
describe('parseMemberCommand', () => {
|
describe('parseMemberCommand', () => {
|
||||||
|
|
||||||
@@ -28,34 +35,51 @@ describe('parseMemberCommand', () => {
|
|||||||
|
|
||||||
|
|
||||||
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'],
|
|
||||||
[['somePerson', 'proxy'], 'update proxy'],
|
|
||||||
[['somePerson', 'propic'], 'update propic'],
|
|
||||||
[['somePerson'], 'member info'],
|
|
||||||
])('%s returns correct values', async(args, expectedResult) => {
|
|
||||||
// Arrange
|
// Arrange
|
||||||
const authorId = '1';
|
const authorId = '1';
|
||||||
const authorFull = 'somePerson#0001';
|
const authorFull = 'somePerson#0001';
|
||||||
// Act
|
// Act
|
||||||
const result = await memberHelper.parseMemberCommand(authorId, authorFull, args);
|
memberHelper.parseMemberCommand(authorId, authorFull, args).then((result) => {
|
||||||
//
|
expect(result).toEqual(expectedResult);
|
||||||
|
expect(method).toHaveBeenCalledTimes(1);
|
||||||
|
expect(method).toHaveBeenCalledWith(passedIn)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
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);
|
expect(result).toEqual(expectedResult);
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
// restore the spy created with spyOn
|
// restore the spy created with spyOn
|
||||||
jest.restoreAllMocks();
|
jest.restoreAllMocks();
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user