From f0de9b8e5d2b1a6924d2f57351dc95343a944e19 Mon Sep 17 00:00:00 2001 From: Arash Koushkebaghi Date: Mon, 9 Dec 2019 11:59:38 -0800 Subject: [PATCH] feat(MeetingAdapter): implement createMeeting method --- src/MeetingsSDKAdapter.js | 32 ++++++++++-------- src/MeetingsSDKAdapter.test.js | 61 ++++++++++++++++++++++++++-------- src/__mocks__/sdk.js | 1 + 3 files changed, 68 insertions(+), 26 deletions(-) diff --git a/src/MeetingsSDKAdapter.js b/src/MeetingsSDKAdapter.js index babefe0f..f3b80e8f 100644 --- a/src/MeetingsSDKAdapter.js +++ b/src/MeetingsSDKAdapter.js @@ -109,19 +109,25 @@ export default class MeetingsSDKAdapter extends MeetingsAdapter { */ createMeeting(target) { return from(this.datasource.meetings.create(target)).pipe( - map(({id, destination, sipuri}) => { - this.meetings[id] = { - ID: id, - title: destination || sipuri, - localVideo: null, - localAudio: null, - localShare: null, - remoteStream: null, - remoteShare: null, - }; - - return this.meetings[id]; - }) + map( + ({id, destination, sipuri}) => { + this.meetings[id] = { + ID: id, + title: destination || sipuri, + localVideo: null, + localAudio: null, + localShare: null, + remoteStream: null, + remoteShare: null, + }; + + return this.meetings[id]; + }, + (error) => { + // eslint-disable-next-line no-console + console.error(`Unable to create a meeting with "${target}"`, error); + } + ) ); } diff --git a/src/MeetingsSDKAdapter.test.js b/src/MeetingsSDKAdapter.test.js index a27465c3..e64f2f48 100644 --- a/src/MeetingsSDKAdapter.test.js +++ b/src/MeetingsSDKAdapter.test.js @@ -1,10 +1,11 @@ import * as rxjs from 'rxjs'; +import {flatMap} from 'rxjs/operators'; import MeetingSDKAdapter from './MeetingsSDKAdapter'; import createMockSDK from './__mocks__/sdk'; describe('Meetings SDK Adapter', () => { - let meetingSDKAdapter, mockSDK, meetingID, meeting; + let meetingSDKAdapter, mockSDK, meetingID, meeting, target; beforeEach(() => { mockSDK = createMockSDK(); @@ -20,6 +21,7 @@ describe('Meetings SDK Adapter', () => { remoteStream: null, title: 'my meeting', }; + target = 'target'; }); afterEach(() => { @@ -28,6 +30,7 @@ describe('Meetings SDK Adapter', () => { mockSDK = null; meetingSDKAdapter = null; meetingID = null; + target = null; }); describe('attachMedia()', () => { @@ -59,16 +62,45 @@ describe('Meetings SDK Adapter', () => { }); }); - describe('getMeeting()', () => { - test('returns a meeting in a proper shape', (done) => { - meetingSDKAdapter.getMeeting(meetingID).subscribe((getMeeting) => { - expect(getMeeting).toMatchObject(meeting); + describe('createMeeting()', () => { + test('returns a new meeting in a proper shape', (done) => { + meetingSDKAdapter.createMeeting(target).subscribe((newMeeting) => { + expect(newMeeting).toMatchObject(meeting); done(); }); }); + test('throws error on failed meeting push request', (done) => { + const wrongTarget = 'wrongTarget'; + const errorMessage = `Unable to create a meeting "${wrongTarget}"`; + + meetingSDKAdapter.datasource.meetings.create = jest.fn(() => Promise.reject(errorMessage)); + meetingSDKAdapter.createMeeting(target).subscribe( + () => {}, + (error) => { + expect(error).toBe(errorMessage); + done(); + } + ); + }); + }); + + describe('getMeeting()', () => { + test('returns a meeting in a proper shape', (done) => { + meetingSDKAdapter + .createMeeting(target) + .pipe(flatMap(() => meetingSDKAdapter.getMeeting(meetingID))) + .subscribe((getMeeting) => { + expect(getMeeting).toMatchObject(meeting); + done(); + }); + }); + test('stops listening to events when unsubscribing', () => { - const subscription = meetingSDKAdapter.getMeeting(meetingID).subscribe(); + const subscription = meetingSDKAdapter + .createMeeting(target) + .pipe(flatMap(() => meetingSDKAdapter.getMeeting(meetingID))) + .subscribe(); subscription.unsubscribe(); expect(meetingSDKAdapter.getMeetingObservables).toEqual({}); @@ -78,13 +110,16 @@ describe('Meetings SDK Adapter', () => { meetingID = 'invalid meetingID'; const errorMessage = `Could not find meeting with ID "${meetingID}"`; - meetingSDKAdapter.getMeeting(meetingID).subscribe( - () => {}, - (error) => { - expect(error.message).toBe(errorMessage); - done(); - } - ); + meetingSDKAdapter + .createMeeting(target) + .pipe(flatMap(() => meetingSDKAdapter.getMeeting(meetingID))) + .subscribe( + () => {}, + (error) => { + expect(error.message).toBe(errorMessage); + done(); + } + ); }); }); }); diff --git a/src/__mocks__/sdk.js b/src/__mocks__/sdk.js index 4863e17d..56f74905 100644 --- a/src/__mocks__/sdk.js +++ b/src/__mocks__/sdk.js @@ -55,6 +55,7 @@ export default function createMockSDK() { get: jest.fn(() => Promise.resolve(mockSDKPerson)), }, meetings: { + create: jest.fn(() => Promise.resolve(mockSDKMeeting)), getMeetingByType: jest.fn((_, ID) => (ID === 'meetingID' ? mockSDKMeeting : undefined)), }, };