From 97568e74703737617982db817a0ab585e79edd8b Mon Sep 17 00:00:00 2001 From: Nico De Cleyre Date: Mon, 19 Jun 2023 19:03:14 +0200 Subject: [PATCH 1/3] first commit --- src/m365/todo/commands/task/task-get.spec.ts | 10 +-- src/m365/todo/commands/task/task-list.spec.ts | 36 ++++---- src/m365/todo/commands/task/task-list.ts | 18 ++-- .../todo/commands/task/task-remove.spec.ts | 76 ++++++++-------- src/m365/todo/commands/task/task-remove.ts | 88 +++++++++--------- src/m365/todo/commands/task/task-set.spec.ts | 40 ++++----- src/m365/todo/commands/task/task-set.ts | 18 ++-- .../accesstoken/accesstoken-get.spec.ts | 12 +-- .../connections-app-create.spec.ts | 90 ++++++++++--------- .../yammer/commands/group/group-list.spec.ts | 24 ++--- .../commands/group/group-user-add.spec.ts | 32 +++---- .../commands/group/group-user-remove.spec.ts | 32 +++---- .../commands/group/group-user-remove.ts | 54 +++++------ .../commands/message/message-add.spec.ts | 22 ++--- 14 files changed, 277 insertions(+), 275 deletions(-) diff --git a/src/m365/todo/commands/task/task-get.spec.ts b/src/m365/todo/commands/task/task-get.spec.ts index 43cb711d577..5dc5a156b80 100644 --- a/src/m365/todo/commands/task/task-get.spec.ts +++ b/src/m365/todo/commands/task/task-get.spec.ts @@ -42,10 +42,10 @@ describe(commands.TASK_GET, () => { before(() => { cli = Cli.getInstance(); - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -81,7 +81,7 @@ describe(commands.TASK_GET, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.TASK_GET), true); + assert.strictEqual(command.name, commands.TASK_GET); }); it('has a description', () => { diff --git a/src/m365/todo/commands/task/task-list.spec.ts b/src/m365/todo/commands/task/task-list.spec.ts index ca3b49df55d..d30b16bd48c 100644 --- a/src/m365/todo/commands/task/task-list.spec.ts +++ b/src/m365/todo/commands/task/task-list.spec.ts @@ -22,10 +22,10 @@ describe(commands.TASK_LIST, () => { before(() => { cli = Cli.getInstance(); - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -61,7 +61,7 @@ describe(commands.TASK_LIST, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.TASK_LIST), true); + assert.strictEqual(command.name, commands.TASK_LIST); }); it('has a description', () => { @@ -91,11 +91,11 @@ describe(commands.TASK_LIST, () => { }); it('fails to get ToDo Task list when the specified task list does not exist', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if ((opts.url as string).indexOf(`/me/todo/lists?$filter=displayName eq '`) > -1) { - return Promise.resolve({ value: [] }); + return { value: [] }; } - return Promise.reject('The specified task list does not exist'); + throw 'The specified task list does not exist'; }); await assert.rejects(command.action(logger, { options: { listName: 'Tasks List' } } as any), new CommandError('The specified task list does not exist')); @@ -120,9 +120,9 @@ describe(commands.TASK_LIST, () => { }); it('lists To Do tasks using listId in JSON output mode', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if ((opts.url as string).indexOf(`/tasks`) > -1) { - return Promise.resolve({ + return { value: [ { "importance": "normal", @@ -151,10 +151,10 @@ describe(commands.TASK_LIST, () => { } } ] - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { @@ -196,9 +196,9 @@ describe(commands.TASK_LIST, () => { }); it('lists To Do tasks using listName', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if ((opts.url as string).indexOf(`/me/todo/lists?$filter=displayName eq '`) > -1) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('e1251b10-1ba4-49e3-b35a-933e3f21772b')/todo/lists", "value": [ { @@ -210,11 +210,11 @@ describe(commands.TASK_LIST, () => { "id": "AQMkAGYzNjMxYTU4LTJjZjYtNDlhMi1iMzQ2LWVmMTU3YmUzOGM5MAAuAAADMN-7V4K8g0q_adetip1DygEAxMBBaLl1lk_dAn8KkjfXKQABF-BAgwAAAA==" } ] - }); + }; } if ((opts.url as string).indexOf(`/tasks`) > -1) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('e1251b10-1ba4-49e3-b35a-933e3f21772b')/todo/lists('AQMkAGYzNjMxYTU4LTJjZjYtNDlhMi1iMzQ2LWVmMTU3YmUzOGM5MAAuAAADMN-7V4K8g0q_adetip1DygEAxMBBaLl1lk_dAn8KkjfXKQABF-BAgwAAAA%3D%3D')/tasks", "value": [ { @@ -232,10 +232,10 @@ describe(commands.TASK_LIST, () => { "lastModifiedDateTime": "2020-11-01T17:13:13.1037095Z" } ] - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { diff --git a/src/m365/todo/commands/task/task-list.ts b/src/m365/todo/commands/task/task-list.ts index a3ad4e212dc..b7a35e27af5 100644 --- a/src/m365/todo/commands/task/task-list.ts +++ b/src/m365/todo/commands/task/task-list.ts @@ -61,9 +61,9 @@ class TodoTaskListCommand extends GraphCommand { this.optionSets.push({ options: ['listId', 'listName'] }); } - private getTodoListId(args: CommandArgs): Promise { + private async getTodoListId(args: CommandArgs): Promise { if (args.options.listId) { - return Promise.resolve(args.options.listId); + return args.options.listId; } const requestOptions: any = { @@ -74,16 +74,14 @@ class TodoTaskListCommand extends GraphCommand { responseType: 'json' }; - return request.get<{ value: [{ id: string }] }>(requestOptions) - .then(response => { - const taskList: { id: string } | undefined = response.value[0]; + const response: any = await request.get<{ value: [{ id: string }] }>(requestOptions); + const taskList: { id: string } | undefined = response.value[0]; - if (!taskList) { - return Promise.reject(`The specified task list does not exist`); - } + if (!taskList) { + throw `The specified task list does not exist`; + } - return Promise.resolve(taskList.id); - }); + return taskList.id; } public async commandAction(logger: Logger, args: CommandArgs): Promise { diff --git a/src/m365/todo/commands/task/task-remove.spec.ts b/src/m365/todo/commands/task/task-remove.spec.ts index f5f57f99fde..460e8084fcd 100644 --- a/src/m365/todo/commands/task/task-remove.spec.ts +++ b/src/m365/todo/commands/task/task-remove.spec.ts @@ -22,10 +22,10 @@ describe(commands.TASK_REMOVE, () => { before(() => { cli = Cli.getInstance(); - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; sinon.stub(Cli, 'prompt').callsFake(async (options) => { promptOptions = options; @@ -64,7 +64,7 @@ describe(commands.TASK_REMOVE, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.TASK_REMOVE), true); + assert.strictEqual(command.name, commands.TASK_REMOVE); }); it('has a description', () => { @@ -72,9 +72,9 @@ describe(commands.TASK_REMOVE, () => { }); it('removes a To Do task by task id and task list name', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'Tasks'`) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('eded3a2a-8f01-40aa-998a-e4f02ec693ba')/todo/lists", "value": [ { @@ -86,18 +86,18 @@ describe(commands.TASK_REMOVE, () => { "id": "BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=" } ] - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); - sinon.stub(request, 'delete').callsFake((opts) => { + sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=/tasks/AAMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhAAA=`) { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { @@ -110,9 +110,9 @@ describe(commands.TASK_REMOVE, () => { }); it('removes a To Do task by task id and task list name when confirm option is passed', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'Tasks'`) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('eded3a2a-8f01-40aa-998a-e4f02ec693ba')/todo/lists", "value": [ { @@ -124,17 +124,17 @@ describe(commands.TASK_REMOVE, () => { "id": "BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=" } ] - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); - sinon.stub(request, 'delete').callsFake((opts) => { + sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=/tasks/AAMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhAAA=`) { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { @@ -148,9 +148,9 @@ describe(commands.TASK_REMOVE, () => { }); it('removes a To Do task by task id and task list id', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=`) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('eded3a2a-8f01-40aa-998a-e4f02ec693ba')/todo/lists/$entity", "@odata.etag": "W/\"tPAryi+qT0uvQKa/pHXU5AAAQchLxw==\"", "displayName": "Tasks", @@ -158,17 +158,17 @@ describe(commands.TASK_REMOVE, () => { "isShared": false, "wellknownListName": "defaultList", "id": "BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=" - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); - sinon.stub(request, 'delete').callsFake((opts) => { + sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=/tasks/AAMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhAAA=`) { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { @@ -181,9 +181,9 @@ describe(commands.TASK_REMOVE, () => { }); it('handles error correctly', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'FooList'`) { - return Promise.resolve({ + return { "error": { "code": "invalidRequest", "message": "The list FooList cannot be found", @@ -195,13 +195,13 @@ describe(commands.TASK_REMOVE, () => { "client-request-id": "085a2508-e115-63b6-fcc9-05acc2133231" } } - }); + }; } - return Promise.reject('The list FooList cannot be found'); + throw 'The list FooList cannot be found'; }); sinon.stub(request, 'delete').callsFake(() => { - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await assert.rejects(command.action(logger, { @@ -214,9 +214,9 @@ describe(commands.TASK_REMOVE, () => { }); it('prompts before removing the To Do task when confirm option not passed', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'Tasks'`) { - return Promise.resolve({ + return { "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('eded3a2a-8f01-40aa-998a-e4f02ec693ba')/todo/lists", "value": [ { @@ -228,17 +228,17 @@ describe(commands.TASK_REMOVE, () => { "id": "BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=" } ] - }); + }; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); - sinon.stub(request, 'delete').callsFake((opts) => { + sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/BBMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhBBB=/tasks/AAMkAGI3NDhlZmQzLWQxYjAtNGJjNy04NmYwLWQ0M2IzZTNlMDUwNAAuAAAAAACQ1l2jfH6VSZraktP8Z7auAQCbV93BagWITZhL3J6BMqhjAAD9pHIhAAA=`) { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); sinonUtil.restore(Cli.prompt); diff --git a/src/m365/todo/commands/task/task-remove.ts b/src/m365/todo/commands/task/task-remove.ts index 9e20cb07ebb..b24f575700a 100644 --- a/src/m365/todo/commands/task/task-remove.ts +++ b/src/m365/todo/commands/task/task-remove.ts @@ -65,49 +65,8 @@ class TodoTaskRemoveCommand extends GraphCommand { } public async commandAction(logger: Logger, args: CommandArgs): Promise { - const getToDoListId = async (): Promise => { - if (args.options.listName) { - // Search list by its name - const requestOptions: any = { - url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(args.options.listName)}'`, - headers: { - accept: "application/json;odata.metadata=none" - }, - responseType: 'json' - }; - const response: { value: { id: string }[] } = await request.get<{ value: { id: string }[] }>(requestOptions); - - return response.value && response.value.length === 1 ? response.value[0].id : undefined; - } - - return Promise.resolve(args.options.listId as string); - }; - - const removeToDoTask = async (): Promise => { - try { - const toDoListId: string | undefined = await getToDoListId(); - - if (!toDoListId) { - throw `The list ${args.options.listName} cannot be found`; - } - - const requestOptions: any = { - url: `${this.resource}/v1.0/me/todo/lists/${toDoListId}/tasks/${args.options.id}`, - headers: { - accept: "application/json;odata.metadata=none" - }, - responseType: 'json' - }; - - await request.delete(requestOptions); - } - catch (err: any) { - this.handleRejectedODataJsonPromise(err); - } - }; - - if (args.options.force) { - await removeToDoTask(); + if (args.options.confirm) { + await this.removeToDoTask(args); } else { const result = await Cli.prompt<{ continue: boolean }>({ @@ -118,10 +77,51 @@ class TodoTaskRemoveCommand extends GraphCommand { }); if (result.continue) { - await removeToDoTask(); + await this.removeToDoTask(args); } } } + + private async getToDoListId(args: CommandArgs): Promise { + if (args.options.listName) { + // Search list by its name + const requestOptions: any = { + url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(args.options.listName)}'`, + headers: { + accept: "application/json;odata.metadata=none" + }, + responseType: 'json' + }; + const response: { value: { id: string }[] } = await request.get<{ value: { id: string }[] }>(requestOptions); + + return response.value && response.value.length === 1 ? response.value[0].id : undefined; + } + + return args.options.listId as string; + } + + private async removeToDoTask(args: CommandArgs): Promise { + try { + const toDoListId: string | undefined = await this.getToDoListId(args); + + if (!toDoListId) { + throw `The list ${args.options.listName} cannot be found`; + } + + const requestOptions: any = { + url: `${this.resource}/v1.0/me/todo/lists/${toDoListId}/tasks/${args.options.id}`, + headers: { + accept: "application/json;odata.metadata=none" + }, + responseType: 'json' + }; + + await request.delete(requestOptions); + } + catch (err: any) { + this.handleRejectedODataJsonPromise(err); + } + } } export default new TodoTaskRemoveCommand(); \ No newline at end of file diff --git a/src/m365/todo/commands/task/task-set.spec.ts b/src/m365/todo/commands/task/task-set.spec.ts index 82f67e5ec6b..8ca89ce84c9 100644 --- a/src/m365/todo/commands/task/task-set.spec.ts +++ b/src/m365/todo/commands/task/task-set.spec.ts @@ -49,10 +49,10 @@ describe(commands.TASK_SET, () => { before(() => { cli = Cli.getInstance(); - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -71,19 +71,19 @@ describe(commands.TASK_SET, () => { } }; (command as any).items = []; - patchStub = sinon.stub(request, 'patch').callsFake((opts: any) => { + patchStub = sinon.stub(request, 'patch').callsFake(async (opts: any) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists/AQMkADlhMTRkOGEzLWQ1M2QtNGVkNS04NjdmLWU0NzJhMjZmZWNmMwAuAAADKvwNgAMNPE_zFNRJXVrU1wEAhHKQZHItDEOVCn8U3xuA2AABmQeVPwAAAA==/tasks/abc`) { - return Promise.resolve(patchRequestData); + return patchRequestData; } - return Promise.reject(); + throw null; }); - sinon.stub(request, 'get').callsFake((opts: any) => { + sinon.stub(request, 'get').callsFake(async (opts: any) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'Tasks%20List'`) { - return Promise.resolve(getRequestData); + return getRequestData; } - return Promise.reject(); + throw null; }); sinon.stub(cli, 'getSettingWithDefaultValue').callsFake(((settingName, defaultValue) => defaultValue)); @@ -104,7 +104,7 @@ describe(commands.TASK_SET, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.TASK_SET), true); + assert.strictEqual(command.name, commands.TASK_SET); }); it('has a description', () => { @@ -257,16 +257,14 @@ describe(commands.TASK_SET, () => { it('rejects if no tasks list is found with the specified list name', async () => { sinonUtil.restore(request.get); - sinon.stub(request, 'get').callsFake((opts: any) => { + sinon.stub(request, 'get').callsFake(async (opts: any) => { if (opts.url === `https://graph.microsoft.com/v1.0/me/todo/lists?$filter=displayName eq 'Tasks%20List'`) { - return Promise.resolve( - { - "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('4cb2b035-ad76-406c-bdc4-6c72ad403a22')/todo/lists", - "value": [] - } - ); + return { + "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('4cb2b035-ad76-406c-bdc4-6c72ad403a22')/todo/lists", + "value": [] + }; } - return Promise.reject(); + throw null; }); await assert.rejects(command.action(logger, { @@ -281,9 +279,7 @@ describe(commands.TASK_SET, () => { it('handles error correctly', async () => { sinonUtil.restore(request.patch); - sinon.stub(request, 'patch').callsFake(() => { - return Promise.reject('An error has occurred'); - }); + sinon.stub(request, 'patch').rejects(new Error('An error has occurred')); await assert.rejects(command.action(logger, { options: { diff --git a/src/m365/todo/commands/task/task-set.ts b/src/m365/todo/commands/task/task-set.ts index 01de10603ed..8fb5e0346e7 100644 --- a/src/m365/todo/commands/task/task-set.ts +++ b/src/m365/todo/commands/task/task-set.ts @@ -179,9 +179,9 @@ class TodoTaskSetCommand extends GraphCommand { } } - private getTodoListId(args: CommandArgs): Promise { + private async getTodoListId(args: CommandArgs): Promise { if (args.options.listId) { - return Promise.resolve(args.options.listId); + return args.options.listId; } const requestOptions: any = { @@ -192,16 +192,14 @@ class TodoTaskSetCommand extends GraphCommand { responseType: 'json' }; - return request.get<{ value: [{ id: string }] }>(requestOptions) - .then(response => { - const taskList: { id: string } | undefined = response.value[0]; + const response: any = await request.get<{ value: [{ id: string }] }>(requestOptions); + const taskList: { id: string } | undefined = response.value[0]; - if (!taskList) { - return Promise.reject(`The specified task list does not exist`); - } + if (!taskList) { + throw `The specified task list does not exist`; + } - return Promise.resolve(taskList.id); - }); + return taskList.id; } private getDateTimeTimeZone(dateTime: string): { dateTime: string, timeZone: string } { diff --git a/src/m365/util/commands/accesstoken/accesstoken-get.spec.ts b/src/m365/util/commands/accesstoken/accesstoken-get.spec.ts index d3769ac087b..fb18f334dec 100644 --- a/src/m365/util/commands/accesstoken/accesstoken-get.spec.ts +++ b/src/m365/util/commands/accesstoken/accesstoken-get.spec.ts @@ -16,10 +16,10 @@ describe(commands.ACCESSTOKEN_GET, () => { let loggerLogSpy: sinon.SinonSpy; before(() => { - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; }); @@ -52,7 +52,7 @@ describe(commands.ACCESSTOKEN_GET, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.ACCESSTOKEN_GET), true); + assert.strictEqual(command.name, commands.ACCESSTOKEN_GET); }); it('has a description', () => { @@ -85,7 +85,7 @@ describe(commands.ACCESSTOKEN_GET, () => { }); it('correctly handles error when retrieving access token', async () => { - sinon.stub(auth, 'ensureAccessToken').callsFake(() => Promise.reject('An error has occurred')); + sinon.stub(auth, 'ensureAccessToken').rejects(new Error('An error has occurred')); await assert.rejects(command.action(logger, { options: { resource: 'https://graph.microsoft.com' } } as any), new CommandError('An error has occurred')); }); diff --git a/src/m365/viva/commands/connections/connections-app-create.spec.ts b/src/m365/viva/commands/connections/connections-app-create.spec.ts index 98df4076889..5412c021a62 100644 --- a/src/m365/viva/commands/connections/connections-app-create.spec.ts +++ b/src/m365/viva/commands/connections/connections-app-create.spec.ts @@ -66,7 +66,7 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.CONNECTIONS_APP_CREATE), true); + assert.strictEqual(command.name, commands.CONNECTIONS_APP_CREATE); }); it('has a description', () => { @@ -74,13 +74,15 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it('creates app package for the specified communication site (root site)', async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.resolve({ - stdout: JSON.stringify({ - Configuration: 0, - WebTemplate: 'SITEPAGEPUBLISHING' - }), - stderr: '' - })); + sinon.stub(Cli, 'executeCommandWithOutput').callsFake(async () => { + return { + stdout: JSON.stringify({ + Configuration: 0, + WebTemplate: 'SITEPAGEPUBLISHING' + }), + stderr: '' + }; + }); const admZipMockAddFileSpy = sinon.spy(admZipMock, 'addFile'); const admZipMockAddLocalFileSpy = sinon.spy(admZipMock, 'addLocalFile'); const admZipMockWriteZipSpy = sinon.spy(admZipMock, 'writeZip'); @@ -104,13 +106,15 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it('creates app package for the specified communication site (/sites)', async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.resolve({ - stdout: JSON.stringify({ - Configuration: 0, - WebTemplate: 'SITEPAGEPUBLISHING' - }), - stderr: '' - })); + sinon.stub(Cli, 'executeCommandWithOutput').callsFake(async () => { + return { + stdout: JSON.stringify({ + Configuration: 0, + WebTemplate: 'SITEPAGEPUBLISHING' + }), + stderr: '' + }; + }); const admZipMockAddFileSpy = sinon.spy(admZipMock, 'addFile'); const admZipMockAddLocalFileSpy = sinon.spy(admZipMock, 'addLocalFile'); const admZipMockWriteZipSpy = sinon.spy(admZipMock, 'writeZip'); @@ -135,13 +139,15 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it('creates app package for the specified communication site (/teams + query string)', async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.resolve({ - stdout: JSON.stringify({ - Configuration: 0, - WebTemplate: 'SITEPAGEPUBLISHING' - }), - stderr: '' - })); + sinon.stub(Cli, 'executeCommandWithOutput').callsFake(async () => { + return { + stdout: JSON.stringify({ + Configuration: 0, + WebTemplate: 'SITEPAGEPUBLISHING' + }), + stderr: '' + }; + }); const admZipMockAddFileSpy = sinon.spy(admZipMock, 'addFile'); const admZipMockAddLocalFileSpy = sinon.spy(admZipMock, 'addLocalFile'); const admZipMockWriteZipSpy = sinon.spy(admZipMock, 'writeZip'); @@ -165,10 +171,10 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it(`fails with an error if the specified site doesn't exist`, async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.reject({ + sinon.stub(Cli, 'executeCommandWithOutput').rejects({ error: '404 - FILE NOT FOUND', stderr: '404 - FILE NOT FOUND' - })); + }); const admZipMockWriteZipSpy = sinon.spy(admZipMock, 'writeZip'); await assert.rejects(command.action(logger, { @@ -187,10 +193,10 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it(`fails with an error if the specified site doesn't exist (debug)`, async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.reject({ + sinon.stub(Cli, 'executeCommandWithOutput').rejects({ error: '404 - FILE NOT FOUND', stderr: '404 - FILE NOT FOUND stderr' - })); + }); await assert.rejects(command.action(logger, { options: { @@ -208,13 +214,15 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it('fails with an error if the specified site is not a communication site', async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.resolve({ - stdout: JSON.stringify({ - Configuration: 0, - WebTemplate: 'TEAM' - }), - stderr: '' - })); + sinon.stub(Cli, 'executeCommandWithOutput').callsFake(async () => { + return { + stdout: JSON.stringify({ + Configuration: 0, + WebTemplate: 'TEAM' + }), + stderr: '' + }; + }); await assert.rejects(command.action(logger, { options: { @@ -232,13 +240,15 @@ describe(commands.CONNECTIONS_APP_CREATE, () => { }); it(`fails with an error if creating the zip file failed`, async () => { - sinon.stub(Cli, 'executeCommandWithOutput').callsFake(() => Promise.resolve({ - stdout: JSON.stringify({ - Configuration: 0, - WebTemplate: 'SITEPAGEPUBLISHING' - }), - stderr: '' - })); + sinon.stub(Cli, 'executeCommandWithOutput').callsFake(async () => { + return { + stdout: JSON.stringify({ + Configuration: 0, + WebTemplate: 'SITEPAGEPUBLISHING' + }), + stderr: '' + }; + }); sinon.stub(admZipMock, 'writeZip').callsFake(() => { throw new Error('An error has occurred'); }); diff --git a/src/m365/yammer/commands/group/group-list.spec.ts b/src/m365/yammer/commands/group/group-list.spec.ts index bb181ba69fb..e91aa9e624c 100644 --- a/src/m365/yammer/commands/group/group-list.spec.ts +++ b/src/m365/yammer/commands/group/group-list.spec.ts @@ -184,10 +184,10 @@ describe(commands.GROUP_LIST, () => { }]; before(() => { - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -221,7 +221,7 @@ describe(commands.GROUP_LIST, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.GROUP_LIST), true); + assert.strictEqual(command.name, commands.GROUP_LIST); }); it('has a description', () => { @@ -234,11 +234,11 @@ describe(commands.GROUP_LIST, () => { it('correctly handles error', async () => { sinon.stub(request, 'get').callsFake(() => { - return Promise.reject({ + throw { "error": { "base": "An error has occurred." } - }); + }; }); await assert.rejects(command.action(logger, { options: {} } as any), new CommandError('An error has occurred.')); @@ -267,9 +267,9 @@ describe(commands.GROUP_LIST, () => { it('returns groups without more results', async () => { sinon.stub(request, 'get').callsFake((opts) => { if (opts.url === 'https://www.yammer.com/api/v1/groups.json?page=1') { - return Promise.resolve(groupsSecondBatchList); + return groupsSecondBatchList; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: {} } as any); @@ -314,7 +314,7 @@ describe(commands.GROUP_LIST, () => { it('returns groups with a specific limit', async () => { sinon.stub(request, 'get').callsFake(() => { - return Promise.resolve(groupsFirstBatchList); + return groupsFirstBatchList; }); await command.action(logger, { options: { limit: 1, output: 'json' } } as any); @@ -325,9 +325,9 @@ describe(commands.GROUP_LIST, () => { it('handles correct parameters userId', async () => { sinon.stub(request, 'get').callsFake((opts) => { if (opts.url === 'https://www.yammer.com/api/v1/groups/for_user/10123190123128.json?page=1') { - return Promise.resolve(groupsSecondBatchList); + return groupsSecondBatchList; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { userId: 10123190123128, output: 'json' } } as any); diff --git a/src/m365/yammer/commands/group/group-user-add.spec.ts b/src/m365/yammer/commands/group/group-user-add.spec.ts index b5d17a2f279..643946aeace 100644 --- a/src/m365/yammer/commands/group/group-user-add.spec.ts +++ b/src/m365/yammer/commands/group/group-user-add.spec.ts @@ -19,10 +19,10 @@ describe(commands.GROUP_USER_ADD, () => { let commandInfo: CommandInfo; before(() => { - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -55,7 +55,7 @@ describe(commands.GROUP_USER_ADD, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.GROUP_USER_ADD), true); + assert.strictEqual(command.name, commands.GROUP_USER_ADD); }); it('has a description', () => { @@ -64,11 +64,11 @@ describe(commands.GROUP_USER_ADD, () => { it('correctly handles error', async () => { sinon.stub(request, 'post').callsFake(() => { - return Promise.reject({ + throw { "error": { "base": "An error has occurred." } - }); + }; }); await assert.rejects(command.action(logger, { options: {} } as any), new CommandError('An error has occurred.')); @@ -90,11 +90,11 @@ describe(commands.GROUP_USER_ADD, () => { }); it('calls the service if the current user is added to the group', async () => { - const requestPostedStub = sinon.stub(request, 'post').callsFake((opts) => { + const requestPostedStub = sinon.stub(request, 'post').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); sinon.stub(Cli, 'prompt').callsFake(async () => ( @@ -107,11 +107,11 @@ describe(commands.GROUP_USER_ADD, () => { }); it('calls the service if the user 989998789 is added to the group 1231231', async () => { - const requestPostedStub = sinon.stub(request, 'post').callsFake((opts) => { + const requestPostedStub = sinon.stub(request, 'post').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { debug: true, groupId: 1231231, id: 989998789 } }); @@ -120,11 +120,11 @@ describe(commands.GROUP_USER_ADD, () => { }); it('calls the service if the user suzy@contoso.com is added to the group 1231231', async () => { - const requestPostedStub = sinon.stub(request, 'post').callsFake((opts) => { + const requestPostedStub = sinon.stub(request, 'post').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { debug: true, groupId: 1231231, email: "suzy@contoso.com" } }); diff --git a/src/m365/yammer/commands/group/group-user-remove.spec.ts b/src/m365/yammer/commands/group/group-user-remove.spec.ts index fa25f6386f0..da2e24962b1 100644 --- a/src/m365/yammer/commands/group/group-user-remove.spec.ts +++ b/src/m365/yammer/commands/group/group-user-remove.spec.ts @@ -20,10 +20,10 @@ describe(commands.GROUP_USER_REMOVE, () => { let commandInfo: CommandInfo; before(() => { - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -57,7 +57,7 @@ describe(commands.GROUP_USER_REMOVE, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.GROUP_USER_REMOVE), true); + assert.strictEqual(command.name, commands.GROUP_USER_REMOVE); }); it('has a description', () => { @@ -66,11 +66,11 @@ describe(commands.GROUP_USER_REMOVE, () => { it('correctly handles error', async () => { sinon.stub(request, 'delete').callsFake(() => { - return Promise.reject({ + throw { "error": { "base": "An error has occurred." } - }); + }; }); sinon.stub(Cli, 'prompt').callsFake(async () => ( @@ -96,11 +96,11 @@ describe(commands.GROUP_USER_REMOVE, () => { }); it('calls the service if the current user is removed from the group', async () => { - const requestDeleteStub = sinon.stub(request, 'delete').callsFake((opts) => { + const requestDeleteStub = sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); sinon.stub(Cli, 'prompt').callsFake(async () => ( @@ -113,11 +113,11 @@ describe(commands.GROUP_USER_REMOVE, () => { }); it('calls the service if the user 989998789 is removed from the group 1231231 with the confirm command', async () => { - const requestDeleteStub = sinon.stub(request, 'delete').callsFake((opts) => { + const requestDeleteStub = sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { debug: true, groupId: 1231231, id: 989998789, force: true } }); @@ -126,11 +126,11 @@ describe(commands.GROUP_USER_REMOVE, () => { }); it('calls the service if the user 989998789 is removed from the group 1231231', async () => { - const requestDeleteStub = sinon.stub(request, 'delete').callsFake((opts) => { + const requestDeleteStub = sinon.stub(request, 'delete').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/group_memberships.json') { - return Promise.resolve(); + return; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); sinon.stub(Cli, 'prompt').callsFake(async () => ( diff --git a/src/m365/yammer/commands/group/group-user-remove.ts b/src/m365/yammer/commands/group/group-user-remove.ts index 903047c00c7..5e9c891dd6a 100644 --- a/src/m365/yammer/commands/group/group-user-remove.ts +++ b/src/m365/yammer/commands/group/group-user-remove.ts @@ -72,32 +72,8 @@ class YammerGroupUserRemoveCommand extends YammerCommand { } public async commandAction(logger: Logger, args: CommandArgs): Promise { - const executeRemoveAction: () => Promise = async (): Promise => { - const endpoint = `${this.resource}/v1/group_memberships.json`; - - const requestOptions: any = { - url: endpoint, - headers: { - accept: 'application/json;odata.metadata=none', - 'content-type': 'application/json;odata=nometadata' - }, - responseType: 'json', - data: { - group_id: args.options.groupId, - user_id: args.options.id - } - }; - - try { - await request.delete(requestOptions); - } - catch (err: any) { - this.handleRejectedODataJsonPromise(err); - } - }; - - if (args.options.force) { - await executeRemoveAction(); + if (args.options.confirm) { + await this.executeRemoveAction(args); } else { let messagePrompt: string = `Are you sure you want to leave group ${args.options.groupId}?`; @@ -113,10 +89,34 @@ class YammerGroupUserRemoveCommand extends YammerCommand { }); if (result.continue) { - await executeRemoveAction(); + await this.executeRemoveAction(args); } } } + + private async executeRemoveAction(args: CommandArgs): Promise { + const endpoint = `${this.resource}/v1/group_memberships.json`; + + const requestOptions: any = { + url: endpoint, + headers: { + accept: 'application/json;odata.metadata=none', + 'content-type': 'application/json;odata=nometadata' + }, + responseType: 'json', + data: { + group_id: args.options.groupId, + user_id: args.options.id + } + }; + + try { + await request.delete(requestOptions); + } + catch (err: any) { + this.handleRejectedODataJsonPromise(err); + } + } } export default new YammerGroupUserRemoveCommand(); \ No newline at end of file diff --git a/src/m365/yammer/commands/message/message-add.spec.ts b/src/m365/yammer/commands/message/message-add.spec.ts index 4c19938fe01..575518b8068 100644 --- a/src/m365/yammer/commands/message/message-add.spec.ts +++ b/src/m365/yammer/commands/message/message-add.spec.ts @@ -21,10 +21,10 @@ describe(commands.MESSAGE_ADD, () => { const firstMessage: any = { messages: [{ "id": 470839661887488, "sender_id": 1496550646, "replied_to_id": null, "created_at": "2019/12/22 17:20:30 +0000", "network_id": 801445, "message_type": "update", "sender_type": "user", "url": "https://www.yammer.com/api/v1/messages/470839661887488", "web_url": "https://www.yammer.com/nubo.eu/messages/470839661887488", "group_id": 13114941440, "body": { "parsed": "send a letter to me", "plain": "send a letter to me", "rich": "send a letter to me" }, "thread_id": 470839661887488, "client_type": "O365 Api Auth", "client_url": "https://api.yammer.com", "system_message": false, "direct_message": false, "chat_client_sequence": null, "language": null, "notified_user_ids": [], "privacy": "public", "attachments": [], "liked_by": { "count": 0, "names": [] }, "content_excerpt": "send a letter to me", "group_created_id": 13114941440 }] }; before(() => { - sinon.stub(auth, 'restoreAuth').callsFake(() => Promise.resolve()); - sinon.stub(telemetry, 'trackEvent').callsFake(() => { }); - sinon.stub(pid, 'getProcessName').callsFake(() => ''); - sinon.stub(session, 'getId').callsFake(() => ''); + sinon.stub(auth, 'restoreAuth').resolves(); + sinon.stub(telemetry, 'trackEvent').returns(); + sinon.stub(pid, 'getProcessName').returns(''); + sinon.stub(session, 'getId').returns(''); auth.service.connected = true; commandInfo = Cli.getCommandInfo(command); }); @@ -57,7 +57,7 @@ describe(commands.MESSAGE_ADD, () => { }); it('has correct name', () => { - assert.strictEqual(command.name.startsWith(commands.MESSAGE_ADD), true); + assert.strictEqual(command.name, commands.MESSAGE_ADD); }); it('has a description', () => { @@ -106,9 +106,9 @@ describe(commands.MESSAGE_ADD, () => { it('posts a message', async () => { sinon.stub(request, 'post').callsFake((opts) => { if (opts.url === 'https://www.yammer.com/api/v1/messages.json') { - return Promise.resolve(firstMessage); + return firstMessage; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { body: "send a letter to me", groupId: 13114941440, debug: true } } as any); @@ -119,9 +119,9 @@ describe(commands.MESSAGE_ADD, () => { it('posts a message handling json', async () => { sinon.stub(request, 'post').callsFake((opts) => { if (opts.url === 'https://www.yammer.com/api/v1/messages.json') { - return Promise.resolve(firstMessage); + return firstMessage; } - return Promise.reject('Invalid request'); + throw 'Invalid request'; }); await command.action(logger, { options: { body: "send a letter to me", groupId: 13114941440, debug: true, output: "json" } } as any); @@ -131,11 +131,11 @@ describe(commands.MESSAGE_ADD, () => { it('correctly handles error', async () => { sinon.stub(request, 'post').callsFake(() => { - return Promise.reject({ + throw { "error": { "base": "An error has occurred." } - }); + }; }); await assert.rejects(command.action(logger, { options: {} } as any), new CommandError('An error has occurred.')); From cb5336ff143e2443613a339d2a36defcd78ecb5d Mon Sep 17 00:00:00 2001 From: Nico De Cleyre Date: Fri, 1 Sep 2023 19:49:20 +0200 Subject: [PATCH 2/3] Fix --- src/m365/todo/commands/task/task-remove.ts | 2 +- src/m365/yammer/commands/group/group-user-remove.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/m365/todo/commands/task/task-remove.ts b/src/m365/todo/commands/task/task-remove.ts index b24f575700a..fae8cf7032f 100644 --- a/src/m365/todo/commands/task/task-remove.ts +++ b/src/m365/todo/commands/task/task-remove.ts @@ -65,7 +65,7 @@ class TodoTaskRemoveCommand extends GraphCommand { } public async commandAction(logger: Logger, args: CommandArgs): Promise { - if (args.options.confirm) { + if (args.options.force) { await this.removeToDoTask(args); } else { diff --git a/src/m365/yammer/commands/group/group-user-remove.ts b/src/m365/yammer/commands/group/group-user-remove.ts index 5e9c891dd6a..879115cbc78 100644 --- a/src/m365/yammer/commands/group/group-user-remove.ts +++ b/src/m365/yammer/commands/group/group-user-remove.ts @@ -72,7 +72,7 @@ class YammerGroupUserRemoveCommand extends YammerCommand { } public async commandAction(logger: Logger, args: CommandArgs): Promise { - if (args.options.confirm) { + if (args.options.force) { await this.executeRemoveAction(args); } else { From 69074f6d2b6f4a05bebed2289bceef0dc0d1b999 Mon Sep 17 00:00:00 2001 From: Nico De Cleyre Date: Fri, 1 Sep 2023 19:56:28 +0200 Subject: [PATCH 3/3] Changes --- src/m365/todo/commands/task/task-remove.ts | 16 ++++++++-------- src/m365/todo/commands/task/task-set.ts | 12 ++++++------ .../yammer/commands/group/group-list.spec.ts | 8 ++++---- .../commands/group/group-user-add.spec.ts | 2 +- .../commands/group/group-user-remove.spec.ts | 2 +- .../yammer/commands/group/group-user-remove.ts | 18 ++++++++---------- .../commands/message/message-add.spec.ts | 6 +++--- 7 files changed, 31 insertions(+), 33 deletions(-) diff --git a/src/m365/todo/commands/task/task-remove.ts b/src/m365/todo/commands/task/task-remove.ts index fae8cf7032f..d6410123603 100644 --- a/src/m365/todo/commands/task/task-remove.ts +++ b/src/m365/todo/commands/task/task-remove.ts @@ -1,7 +1,7 @@ import { Cli } from '../../../../cli/Cli.js'; import { Logger } from '../../../../cli/Logger.js'; import GlobalOptions from '../../../../GlobalOptions.js'; -import request from '../../../../request.js'; +import request, { CliRequestOptions } from '../../../../request.js'; import GraphCommand from '../../../base/GraphCommand.js'; import commands from '../../commands.js'; @@ -82,11 +82,11 @@ class TodoTaskRemoveCommand extends GraphCommand { } } - private async getToDoListId(args: CommandArgs): Promise { - if (args.options.listName) { + private async getToDoListId(options: GlobalOptions): Promise { + if (options.listName) { // Search list by its name - const requestOptions: any = { - url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(args.options.listName)}'`, + const requestOptions: CliRequestOptions = { + url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(options.listName)}'`, headers: { accept: "application/json;odata.metadata=none" }, @@ -97,18 +97,18 @@ class TodoTaskRemoveCommand extends GraphCommand { return response.value && response.value.length === 1 ? response.value[0].id : undefined; } - return args.options.listId as string; + return options.listId as string; } private async removeToDoTask(args: CommandArgs): Promise { try { - const toDoListId: string | undefined = await this.getToDoListId(args); + const toDoListId: string | undefined = await this.getToDoListId(args.options); if (!toDoListId) { throw `The list ${args.options.listName} cannot be found`; } - const requestOptions: any = { + const requestOptions: CliRequestOptions = { url: `${this.resource}/v1.0/me/todo/lists/${toDoListId}/tasks/${args.options.id}`, headers: { accept: "application/json;odata.metadata=none" diff --git a/src/m365/todo/commands/task/task-set.ts b/src/m365/todo/commands/task/task-set.ts index 8fb5e0346e7..82a685c3a21 100644 --- a/src/m365/todo/commands/task/task-set.ts +++ b/src/m365/todo/commands/task/task-set.ts @@ -160,7 +160,7 @@ class TodoTaskSetCommand extends GraphCommand { const data = this.mapRequestBody(args.options); try { - const listId: string = await this.getTodoListId(args); + const listId: string = await this.getTodoListId(args.options); const requestOptions: CliRequestOptions = { url: `${endpoint}/me/todo/lists/${listId}/tasks/${formatting.encodeQueryParameter(args.options.id)}`, headers: { @@ -179,20 +179,20 @@ class TodoTaskSetCommand extends GraphCommand { } } - private async getTodoListId(args: CommandArgs): Promise { - if (args.options.listId) { - return args.options.listId; + private async getTodoListId(options: GlobalOptions): Promise { + if (options.listId) { + return options.listId; } const requestOptions: any = { - url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(args.options.listName as string)}'`, + url: `${this.resource}/v1.0/me/todo/lists?$filter=displayName eq '${escape(options.listName as string)}'`, headers: { accept: 'application/json;odata.metadata=none' }, responseType: 'json' }; - const response: any = await request.get<{ value: [{ id: string }] }>(requestOptions); + const response = await request.get<{ value: [{ id: string }] }>(requestOptions); const taskList: { id: string } | undefined = response.value[0]; if (!taskList) { diff --git a/src/m365/yammer/commands/group/group-list.spec.ts b/src/m365/yammer/commands/group/group-list.spec.ts index e91aa9e624c..ec56a159d6d 100644 --- a/src/m365/yammer/commands/group/group-list.spec.ts +++ b/src/m365/yammer/commands/group/group-list.spec.ts @@ -233,7 +233,7 @@ describe(commands.GROUP_LIST, () => { }); it('correctly handles error', async () => { - sinon.stub(request, 'get').callsFake(() => { + sinon.stub(request, 'get').callsFake(async () => { throw { "error": { "base": "An error has occurred." @@ -265,7 +265,7 @@ describe(commands.GROUP_LIST, () => { }); it('returns groups without more results', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/groups.json?page=1') { return groupsSecondBatchList; } @@ -313,7 +313,7 @@ describe(commands.GROUP_LIST, () => { }); it('returns groups with a specific limit', async () => { - sinon.stub(request, 'get').callsFake(() => { + sinon.stub(request, 'get').callsFake(async () => { return groupsFirstBatchList; }); @@ -323,7 +323,7 @@ describe(commands.GROUP_LIST, () => { }); it('handles correct parameters userId', async () => { - sinon.stub(request, 'get').callsFake((opts) => { + sinon.stub(request, 'get').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/groups/for_user/10123190123128.json?page=1') { return groupsSecondBatchList; } diff --git a/src/m365/yammer/commands/group/group-user-add.spec.ts b/src/m365/yammer/commands/group/group-user-add.spec.ts index 643946aeace..fcb0eec8123 100644 --- a/src/m365/yammer/commands/group/group-user-add.spec.ts +++ b/src/m365/yammer/commands/group/group-user-add.spec.ts @@ -63,7 +63,7 @@ describe(commands.GROUP_USER_ADD, () => { }); it('correctly handles error', async () => { - sinon.stub(request, 'post').callsFake(() => { + sinon.stub(request, 'post').callsFake(async () => { throw { "error": { "base": "An error has occurred." diff --git a/src/m365/yammer/commands/group/group-user-remove.spec.ts b/src/m365/yammer/commands/group/group-user-remove.spec.ts index da2e24962b1..7b849ef75c6 100644 --- a/src/m365/yammer/commands/group/group-user-remove.spec.ts +++ b/src/m365/yammer/commands/group/group-user-remove.spec.ts @@ -65,7 +65,7 @@ describe(commands.GROUP_USER_REMOVE, () => { }); it('correctly handles error', async () => { - sinon.stub(request, 'delete').callsFake(() => { + sinon.stub(request, 'delete').callsFake(async () => { throw { "error": { "base": "An error has occurred." diff --git a/src/m365/yammer/commands/group/group-user-remove.ts b/src/m365/yammer/commands/group/group-user-remove.ts index 879115cbc78..08c91c9ed0f 100644 --- a/src/m365/yammer/commands/group/group-user-remove.ts +++ b/src/m365/yammer/commands/group/group-user-remove.ts @@ -1,7 +1,7 @@ import { Cli } from '../../../../cli/Cli.js'; import { Logger } from '../../../../cli/Logger.js'; import GlobalOptions from '../../../../GlobalOptions.js'; -import request from '../../../../request.js'; +import request, { CliRequestOptions } from '../../../../request.js'; import YammerCommand from "../../../base/YammerCommand.js"; import commands from '../../commands.js'; @@ -73,7 +73,7 @@ class YammerGroupUserRemoveCommand extends YammerCommand { public async commandAction(logger: Logger, args: CommandArgs): Promise { if (args.options.force) { - await this.executeRemoveAction(args); + await this.executeRemoveAction(args.options); } else { let messagePrompt: string = `Are you sure you want to leave group ${args.options.groupId}?`; @@ -89,24 +89,22 @@ class YammerGroupUserRemoveCommand extends YammerCommand { }); if (result.continue) { - await this.executeRemoveAction(args); + await this.executeRemoveAction(args.options); } } } - private async executeRemoveAction(args: CommandArgs): Promise { - const endpoint = `${this.resource}/v1/group_memberships.json`; - - const requestOptions: any = { - url: endpoint, + private async executeRemoveAction(options: GlobalOptions): Promise { + const requestOptions: CliRequestOptions = { + url: `${this.resource}/v1/group_memberships.json`, headers: { accept: 'application/json;odata.metadata=none', 'content-type': 'application/json;odata=nometadata' }, responseType: 'json', data: { - group_id: args.options.groupId, - user_id: args.options.id + group_id: options.groupId, + user_id: options.id } }; diff --git a/src/m365/yammer/commands/message/message-add.spec.ts b/src/m365/yammer/commands/message/message-add.spec.ts index 575518b8068..420f8026482 100644 --- a/src/m365/yammer/commands/message/message-add.spec.ts +++ b/src/m365/yammer/commands/message/message-add.spec.ts @@ -104,7 +104,7 @@ describe(commands.MESSAGE_ADD, () => { }); it('posts a message', async () => { - sinon.stub(request, 'post').callsFake((opts) => { + sinon.stub(request, 'post').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/messages.json') { return firstMessage; } @@ -117,7 +117,7 @@ describe(commands.MESSAGE_ADD, () => { }); it('posts a message handling json', async () => { - sinon.stub(request, 'post').callsFake((opts) => { + sinon.stub(request, 'post').callsFake(async (opts) => { if (opts.url === 'https://www.yammer.com/api/v1/messages.json') { return firstMessage; } @@ -130,7 +130,7 @@ describe(commands.MESSAGE_ADD, () => { }); it('correctly handles error', async () => { - sinon.stub(request, 'post').callsFake(() => { + sinon.stub(request, 'post').callsFake(async () => { throw { "error": { "base": "An error has occurred."