test: add recording access tests and update helper functions for room preferences
This commit is contained in:
parent
060243bab3
commit
209b4023fc
6
.github/workflows/wc-e2e-test.yaml
vendored
6
.github/workflows/wc-e2e-test.yaml
vendored
@ -80,8 +80,8 @@ jobs:
|
|||||||
frontend/webcomponent/test-results/*/*.webm
|
frontend/webcomponent/test-results/*/*.webm
|
||||||
retention-days: 2
|
retention-days: 2
|
||||||
|
|
||||||
webcomponent-e2e-test:
|
e2e-recording-access-test:
|
||||||
name: WebComponent E2E Tests
|
name: E2E Recording Access Tests
|
||||||
runs-on: ov-actions-runner
|
runs-on: ov-actions-runner
|
||||||
steps:
|
steps:
|
||||||
- name: Setup Node.js
|
- name: Setup Node.js
|
||||||
@ -103,7 +103,7 @@ jobs:
|
|||||||
# Install Playwright browsers
|
# Install Playwright browsers
|
||||||
mkdir -p /tmp/ms-playwright
|
mkdir -p /tmp/ms-playwright
|
||||||
PLAYWRIGHT_BROWSERS_PATH=/tmp/ms-playwright npx playwright install --with-deps chromium
|
PLAYWRIGHT_BROWSERS_PATH=/tmp/ms-playwright npx playwright install --with-deps chromium
|
||||||
npm run test:e2e
|
npm run test:e2e-recording-access
|
||||||
env:
|
env:
|
||||||
RUN_MODE: CI
|
RUN_MODE: CI
|
||||||
PLAYWRIGHT_BROWSERS_PATH: /tmp/ms-playwright
|
PLAYWRIGHT_BROWSERS_PATH: /tmp/ms-playwright
|
||||||
|
|||||||
@ -9,6 +9,7 @@
|
|||||||
"test:e2e": "playwright test",
|
"test:e2e": "playwright test",
|
||||||
"test:e2e-core": "playwright test tests/e2e/core/",
|
"test:e2e-core": "playwright test tests/e2e/core/",
|
||||||
"test:e2e-ui-features": "playwright test tests/e2e/ui-feature-preferences.test.ts",
|
"test:e2e-ui-features": "playwright test tests/e2e/ui-feature-preferences.test.ts",
|
||||||
|
"test:e2e-recording-access": "playwright test tests/e2e/recording-access.test.ts",
|
||||||
"lint": "eslint 'src/**/*.ts'"
|
"lint": "eslint 'src/**/*.ts'"
|
||||||
},
|
},
|
||||||
"keywords": [],
|
"keywords": [],
|
||||||
|
|||||||
230
frontend/webcomponent/tests/e2e/recording-access.test.ts
Normal file
230
frontend/webcomponent/tests/e2e/recording-access.test.ts
Normal file
@ -0,0 +1,230 @@
|
|||||||
|
import { test, expect } from '@playwright/test';
|
||||||
|
import {
|
||||||
|
closeMoreOptionsMenu,
|
||||||
|
createTestRoom,
|
||||||
|
deleteTestRoom,
|
||||||
|
interactWithElementInIframe,
|
||||||
|
joinRoomAs,
|
||||||
|
leaveRoom,
|
||||||
|
loginAsAdmin,
|
||||||
|
openMoreOptionsMenu,
|
||||||
|
prepareForJoiningRoom,
|
||||||
|
startStopRecording,
|
||||||
|
updateRoomPreferences,
|
||||||
|
viewRecordingsAs,
|
||||||
|
waitForElementInIframe
|
||||||
|
} from '../helpers/function-helpers';
|
||||||
|
import { MeetRecordingAccess } from '../../../../typings/src/room-preferences';
|
||||||
|
|
||||||
|
let subscribedToAppErrors = false;
|
||||||
|
let recordingCreated = false;
|
||||||
|
|
||||||
|
test.describe('Recording Access Tests', () => {
|
||||||
|
const testAppUrl = 'http://localhost:5080';
|
||||||
|
const testRoomPrefix = 'recording-access-test';
|
||||||
|
let participantName: string;
|
||||||
|
let roomId: string;
|
||||||
|
let adminCookie: string;
|
||||||
|
|
||||||
|
test.beforeAll(async () => {
|
||||||
|
adminCookie = await loginAsAdmin();
|
||||||
|
// Ensure the test room is created before running tests
|
||||||
|
roomId = await createTestRoom(testRoomPrefix, {
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test.beforeEach(async ({ page }) => {
|
||||||
|
if (!subscribedToAppErrors) {
|
||||||
|
page.on('console', (msg) => {
|
||||||
|
const type = msg.type();
|
||||||
|
const tag = type === 'error' ? 'ERROR' : type === 'warning' ? 'WARNING' : 'LOG';
|
||||||
|
console.log('[' + tag + ']', msg.text());
|
||||||
|
});
|
||||||
|
subscribedToAppErrors = true;
|
||||||
|
}
|
||||||
|
participantName = `P-${Math.random().toString(36).substring(2, 9)}`;
|
||||||
|
if (!recordingCreated) {
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await joinRoomAs('moderator', participantName, page);
|
||||||
|
|
||||||
|
await startStopRecording(page, 'start');
|
||||||
|
|
||||||
|
await page.waitForTimeout(2000);
|
||||||
|
|
||||||
|
await startStopRecording(page, 'stop');
|
||||||
|
recordingCreated = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should moderator not be able to access recording when access level is set to admin', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('moderator', page);
|
||||||
|
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'visible' });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should publisher not be able to access recording when access level is set to admin', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('publisher', page);
|
||||||
|
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'visible' });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should allow moderator to access recording when access level is set to moderator', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN_MODERATOR
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('moderator', page);
|
||||||
|
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'hidden' });
|
||||||
|
await waitForElementInIframe(page, 'app-room-recordings', { state: 'visible' });
|
||||||
|
});
|
||||||
|
test('should publisher not be able to access recording when access level is set to moderator', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN_MODERATOR
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('publisher', page);
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'visible' });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should allow moderators to access recording when access level is set to publisher', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN_MODERATOR
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('moderator', page);
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'hidden' });
|
||||||
|
await waitForElementInIframe(page, 'app-room-recordings', { state: 'visible' });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should allow publisher to access recording when access level is set to publisher', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.ADMIN_MODERATOR_PUBLISHER
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('publisher', page);
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'hidden' });
|
||||||
|
await waitForElementInIframe(page, 'app-room-recordings', { state: 'visible' });
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should allow moderators to access recording when access level is set to public', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.PUBLIC
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('moderator', page);
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'hidden' });
|
||||||
|
await waitForElementInIframe(page, 'app-room-recordings', { state: 'visible' });
|
||||||
|
});
|
||||||
|
test('should allow publisher to access recording when access level is set to public', async ({ page }) => {
|
||||||
|
await updateRoomPreferences(
|
||||||
|
roomId,
|
||||||
|
{
|
||||||
|
chatPreferences: { enabled: true },
|
||||||
|
recordingPreferences: {
|
||||||
|
enabled: true,
|
||||||
|
allowAccessTo: MeetRecordingAccess.PUBLIC
|
||||||
|
},
|
||||||
|
virtualBackgroundPreferences: { enabled: true }
|
||||||
|
},
|
||||||
|
adminCookie
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.goto(testAppUrl);
|
||||||
|
await prepareForJoiningRoom(page, testAppUrl, testRoomPrefix);
|
||||||
|
await viewRecordingsAs('publisher', page);
|
||||||
|
await waitForElementInIframe(page, 'ov-error', { state: 'hidden' });
|
||||||
|
await waitForElementInIframe(page, 'app-room-recordings', { state: 'visible' });
|
||||||
|
});
|
||||||
|
});
|
||||||
@ -126,8 +126,7 @@ export const createTestRoom = async (
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Helper function to update room preferences via REST API
|
// Helper function to update room preferences via REST API
|
||||||
export const updateRoomPreferences = async (roomId: string, preferences: any) => {
|
export const updateRoomPreferences = async (roomId: string, preferences: any, adminCookie: string) => {
|
||||||
const adminCookie = await loginAsAdmin();
|
|
||||||
const response = await fetch(`http://localhost:6080/meet/internal-api/v1/rooms/${roomId}`, {
|
const response = await fetch(`http://localhost:6080/meet/internal-api/v1/rooms/${roomId}`, {
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
headers: {
|
headers: {
|
||||||
@ -145,7 +144,7 @@ export const updateRoomPreferences = async (roomId: string, preferences: any) =>
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Helper function to login and get admin cookie
|
// Helper function to login and get admin cookie
|
||||||
const loginAsAdmin = async () => {
|
export const loginAsAdmin = async (): Promise<string> => {
|
||||||
const response = await fetch(`http://localhost:6080/meet/internal-api/v1/auth/login`, {
|
const response = await fetch(`http://localhost:6080/meet/internal-api/v1/auth/login`, {
|
||||||
method: 'POST',
|
method: 'POST',
|
||||||
headers: {
|
headers: {
|
||||||
@ -230,6 +229,14 @@ export const joinRoomAs = async (role: 'moderator' | 'publisher', pName: string,
|
|||||||
await waitForElementInIframe(page, 'ov-session', { state: 'visible' });
|
await waitForElementInIframe(page, 'ov-session', { state: 'visible' });
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const viewRecordingsAs = async (role: 'moderator' | 'publisher', page: Page) => {
|
||||||
|
await page.click('#join-as-' + role);
|
||||||
|
const component = page.locator('openvidu-meet');
|
||||||
|
await expect(component).toBeVisible();
|
||||||
|
|
||||||
|
await interactWithElementInIframe(page, '#view-recordings-btn', { action: 'click' });
|
||||||
|
};
|
||||||
|
|
||||||
export const leaveRoom = async (page: Page) => {
|
export const leaveRoom = async (page: Page) => {
|
||||||
const button = await waitForElementInIframe(page, '#leave-btn');
|
const button = await waitForElementInIframe(page, '#leave-btn');
|
||||||
await button.click();
|
await button.click();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user