-
Notifications
You must be signed in to change notification settings - Fork 6.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(tests): Adds chat panel and codec selection tests. (#15416)
* fix(tests): Another attempt to fix Firefox excludes. Drawback is that it will be a little bit slow. * feat(tests): Adds chatPanel tests. * feat(tests): Adds codec selection tests.
- Loading branch information
Showing
11 changed files
with
274 additions
and
16 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
import BasePageObject from './BasePageObject'; | ||
|
||
/** | ||
* Chat panel elements. | ||
*/ | ||
export default class ChatPanel extends BasePageObject { | ||
/** | ||
* Is chat panel open. | ||
*/ | ||
async isOpen() { | ||
return await this.participant.driver.$('#sideToolbarContainer').isExisting(); | ||
} | ||
|
||
/** | ||
* Presses the "chat" keyboard shortcut which opens or closes the chat | ||
* panel. | ||
*/ | ||
async pressShortcut() { | ||
await this.participant.driver.$('body').click(); | ||
await this.participant.driver.keys([ 'c' ]); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
import { ensureOneParticipant, ensureThreeParticipants, ensureTwoParticipants } from '../../helpers/participants'; | ||
|
||
describe('Codec selection - ', () => { | ||
it('asymmetric codecs', async () => { | ||
await ensureOneParticipant(ctx, { | ||
configOverwrite: { | ||
videoQuality: { | ||
codecPreferenceOrder: [ 'VP9', 'VP8', 'AV1' ] | ||
} | ||
} | ||
}); | ||
|
||
await ensureTwoParticipants(ctx, { | ||
configOverwrite: { | ||
videoQuality: { | ||
codecPreferenceOrder: [ 'VP8', 'VP9', 'AV1' ] | ||
} | ||
} | ||
}); | ||
const { p1, p2 } = ctx; | ||
|
||
// Check if media is playing on both endpoints. | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLargeVideoReceived())).toBe(true); | ||
expect(await p2.driver.execute(() => JitsiMeetJS.app.testing.isLargeVideoReceived())).toBe(true); | ||
|
||
// Check if p1 is sending VP9 and p2 is sending VP8 as per their codec preferences. | ||
// Except on Firefox because it doesn't support VP9 encode. | ||
if (p1.driver.isFirefox) { | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
} else { | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9())).toBe(true); | ||
} | ||
|
||
expect(await p2.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
}); | ||
|
||
it('asymmetric codecs with AV1', async () => { | ||
await ensureThreeParticipants(ctx, { | ||
configOverwrite: { | ||
videoQuality: { | ||
codecPreferenceOrder: [ 'AV1', 'VP9', 'VP8' ] | ||
} | ||
} | ||
}); | ||
const { p1, p2, p3 } = ctx; | ||
|
||
// Check if media is playing on p3. | ||
expect(await p3.driver.execute(() => JitsiMeetJS.app.testing.isLargeVideoReceived())).toBe(true); | ||
|
||
// Check if p1 is encoding in VP9, p2 in VP8 and p3 in AV1 as per their codec preferences. | ||
// Except on Firefox because it doesn't support AV1/VP9 encode and AV1 decode. | ||
if (p1.driver.isFirefox) { | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
} else { | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9())).toBe(true); | ||
} | ||
|
||
expect(await p2.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
|
||
// If there is a Firefox ep in the call, all other eps will switch to VP9. | ||
if (p1.driver.isFirefox) { | ||
expect(await p3.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9())).toBe(true); | ||
} else { | ||
expect(await p3.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingAv1())).toBe(true); | ||
} | ||
}); | ||
|
||
it('codec switch over', async () => { | ||
await Promise.all([ ctx.p1.hangup(), ctx.p2.hangup(), ctx.p3.hangup() ]); | ||
|
||
await ensureTwoParticipants(ctx, { | ||
configOverwrite: { | ||
videoQuality: { | ||
codecPreferenceOrder: [ 'VP9', 'VP8', 'AV1' ] | ||
} | ||
} | ||
}); | ||
const { p1, p2 } = ctx; | ||
|
||
// Disable this test on Firefox because it doesn't support VP9 encode. | ||
if (p1.driver.isFirefox) { | ||
return; | ||
} | ||
|
||
// Check if p1 and p2 are encoding in VP9 which is the default codec. | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9())).toBe(true); | ||
expect(await p2.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9())).toBe(true); | ||
|
||
await ensureThreeParticipants(ctx, { | ||
configOverwrite: { | ||
videoQuality: { | ||
codecPreferenceOrder: [ 'VP8' ] | ||
} | ||
} | ||
}); | ||
const { p3 } = ctx; | ||
|
||
// Check if all three participants are encoding in VP8 now. | ||
expect(await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
expect(await p2.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
expect(await p3.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp8())).toBe(true); | ||
|
||
await p3.hangup(); | ||
|
||
// Check of p1 and p2 have switched to VP9. | ||
await p1.driver.waitUntil( | ||
async () => await p1.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9()), | ||
{ | ||
timeout: 10000, | ||
timeoutMsg: 'p1 did not switch back to VP9' | ||
} | ||
); | ||
await p2.driver.waitUntil( | ||
async () => await p2.driver.execute(() => JitsiMeetJS.app.testing.isLocalCameraEncodingVp9()), | ||
{ | ||
timeout: 10000, | ||
timeoutMsg: 'p1 did not switch back to VP9' | ||
} | ||
); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import { ensureOneParticipant } from '../../helpers/participants'; | ||
|
||
describe('Chat Panel - ', () => { | ||
it('join participant', async () => { | ||
await ensureOneParticipant(ctx); | ||
}); | ||
it('start closed', async () => { | ||
expect(await ctx.p1.getChatPanel().isOpen()).toBe(false); | ||
}); | ||
it('open', async () => { | ||
const { p1 } = ctx; | ||
|
||
await p1.getToolbar().clickChatButton(); | ||
expect(await p1.getChatPanel().isOpen()).toBe(true); | ||
}); | ||
it('use shortcut to close', async () => { | ||
const chatPanel = ctx.p1.getChatPanel(); | ||
|
||
await chatPanel.pressShortcut(); | ||
expect(await chatPanel.isOpen()).toBe(false); | ||
}); | ||
it('use shortcut to open', async () => { | ||
const chatPanel = ctx.p1.getChatPanel(); | ||
|
||
await chatPanel.pressShortcut(); | ||
expect(await chatPanel.isOpen()).toBe(true); | ||
}); | ||
it('use button to open', async () => { | ||
const { p1 } = ctx; | ||
|
||
await p1.getToolbar().clickCloseChatButton(); | ||
expect(await p1.getChatPanel().isOpen()).toBe(false); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.