/* * Wire * Copyright (C) 2020 Wire Swiss GmbH * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see http://www.gnu.org/licenses/. * */ import {render, fireEvent} from '@testing-library/react'; import {VIDEO_STATE} from '@wireapp/avs'; import {GroupVideoGrid, GroupVideoGripProps} from './GroupVideoGrid'; import {Participant} from '../../calling/Participant'; import {User} from '../../entity/User'; const createMockParticipant = ( userId: string, clientId: string, {isMuted = false, isAudioEstablished = true}: {isMuted?: boolean; isAudioEstablished?: boolean}, ) => { const user = new User(userId); const participant = new Participant(user, clientId); participant.isMuted(isMuted); participant.isAudioEstablished(isAudioEstablished); return participant; }; describe('GroupVideoGrid', () => { it('renders video grids', async () => { const selfParticipant = createMockParticipant('selfUser', 'selfClient', {isMuted: true}); selfParticipant.user.name('Anton Bertha'); const participant = createMockParticipant('userId', 'clientId', {isMuted: true}); participant.user.name('Anot Heruser'); const props: GroupVideoGripProps = { grid: { grid: [selfParticipant, participant], thumbnail: null, }, maximizedParticipant: null, minimized: false, selfParticipant: selfParticipant, setMaximizedParticipant: jest.fn(), }; const {getByTestId} = render(); const groupVideoGrid = getByTestId('grids-wrapper'); expect(groupVideoGrid.children.length).toBe(2); }); it('maximizes a grid on double click', async () => { const participant = createMockParticipant('user1', 'clientId1', {}); participant.user.name('Testing User One'); const participant2 = createMockParticipant('user2', 'clientId2', {}); participant2.user.name('Testing User Two'); const props: GroupVideoGripProps = { grid: { grid: [participant, participant2], thumbnail: null, }, maximizedParticipant: null, minimized: false, selfParticipant: participant, setMaximizedParticipant: jest.fn(), }; const {getByTestId} = render(); const groupVideoGrid = getByTestId('grids-wrapper'); expect(groupVideoGrid.children.length).toBe(2); const gridFirstChild = groupVideoGrid.children[0]; fireEvent.doubleClick(gridFirstChild); expect(props.setMaximizedParticipant).toHaveBeenCalledWith(participant); }); it('renders a grid with paused video', async () => { const participant = createMockParticipant('userId', 'clientId', {isMuted: true}); participant.user.name('Anton Bertha'); participant.videoState(VIDEO_STATE.PAUSED); const props: GroupVideoGripProps = { grid: { grid: [participant], thumbnail: null, }, maximizedParticipant: null, minimized: false, selfParticipant: participant, setMaximizedParticipant: jest.fn(), }; const {queryByTestId} = render(); expect(queryByTestId('status-video-paused')).not.toBeNull(); }); it('renders thumbnail', async () => { const participant = createMockParticipant('userId', 'clientId', {isMuted: true}); participant.user.name('Anton Bertha'); const props: GroupVideoGripProps = { grid: { grid: [], thumbnail: participant, }, maximizedParticipant: null, minimized: false, selfParticipant: participant, setMaximizedParticipant: jest.fn(), }; const {getAllByTestId} = render(); const thumbnailElements = getAllByTestId('self-video-thumbnail-wrapper'); const thumbnailMutedIcons = getAllByTestId('status-call-audio-muted'); expect(thumbnailElements).not.toHaveLength(0); expect(thumbnailMutedIcons).not.toHaveLength(0); }); it('does not render muted thumbnail when un-muted', async () => { const participant = createMockParticipant('userId', 'clientId', {}); const props: GroupVideoGripProps = { grid: { grid: [], thumbnail: participant, }, maximizedParticipant: null, minimized: false, selfParticipant: participant, setMaximizedParticipant: jest.fn(), }; const {queryByTestId} = render(); const thumbnailMutedIcon = queryByTestId('status-call-audio-muted'); expect(thumbnailMutedIcon).toBeNull(); }); it('Does render "connecting..." text for users that are in non established audio state', async () => { const participant = createMockParticipant('user1', 'clientId1', {}); const participant2 = createMockParticipant('user2', 'clientId2', {isAudioEstablished: false}); const participant3 = createMockParticipant('user3', 'clientId3', {isAudioEstablished: false}); const props: GroupVideoGripProps = { grid: { grid: [participant, participant2, participant3], thumbnail: participant, }, maximizedParticipant: null, minimized: false, selfParticipant: participant, setMaximizedParticipant: jest.fn(), }; const {getAllByText} = render(); expect(getAllByText('videoCallParticipantConnecting')).toHaveLength(2); }); });