mirror of
https://github.com/element-hq/element-web.git
synced 2025-12-28 07:14:20 +00:00
Some checks are pending
Build / Build on ${{ matrix.image }} (macos-14, ${{ github.event_name == 'push' && github.ref_name == 'develop' }}) (push) Waiting to run
Build / Build on ${{ matrix.image }} (ubuntu-24.04, ${{ github.event_name == 'push' && github.ref_name == 'develop' }}) (push) Waiting to run
Build / Build on ${{ matrix.image }} (windows-2022, ${{ github.event_name == 'push' && github.ref_name == 'develop' }}) (push) Waiting to run
Build and Deploy develop / Build & Deploy develop.element.io (push) Waiting to run
Deploy documentation / GitHub Pages (push) Waiting to run
Deploy documentation / deploy (push) Blocked by required conditions
Static Analysis / Typescript Syntax Check (push) Waiting to run
Static Analysis / i18n Check (push) Waiting to run
Static Analysis / Rethemendex Check (push) Waiting to run
Static Analysis / ESLint (push) Waiting to run
Static Analysis / Style Lint (push) Waiting to run
Static Analysis / Workflow Lint (push) Waiting to run
Static Analysis / Analyse Dead Code (push) Waiting to run
* Add commercial licence and update config files
* Update license in headers
* Revert "Update license in headers"
This reverts commit 7ed7949485.
* Update only spdx id
* Remove LicenseRef- from package.json
LicenseRef- no longer allowed in npm v3 package.json
This fixes the warning in the logs and failing build check.
56 lines
1.8 KiB
TypeScript
56 lines
1.8 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import { mocked } from "jest-mock";
|
|
|
|
import { SettingLevel } from "../../src/settings/SettingLevel";
|
|
import { MatrixClientPeg } from "../../src/MatrixClientPeg";
|
|
import { stubClient } from "../test-utils";
|
|
import MediaDeviceHandler from "../../src/MediaDeviceHandler";
|
|
import SettingsStore from "../../src/settings/SettingsStore";
|
|
|
|
jest.mock("../../src/settings/SettingsStore");
|
|
|
|
const SettingsStoreMock = mocked(SettingsStore);
|
|
|
|
describe("MediaDeviceHandler", () => {
|
|
beforeEach(() => {
|
|
stubClient();
|
|
});
|
|
|
|
afterEach(() => {
|
|
jest.clearAllMocks();
|
|
});
|
|
|
|
it("sets audio settings", async () => {
|
|
const expectedAudioSettings = new Map<string, boolean>([
|
|
["webrtc_audio_autoGainControl", false],
|
|
["webrtc_audio_echoCancellation", true],
|
|
["webrtc_audio_noiseSuppression", false],
|
|
]);
|
|
|
|
SettingsStoreMock.getValue.mockImplementation((settingName): any => {
|
|
return expectedAudioSettings.get(settingName);
|
|
});
|
|
|
|
await MediaDeviceHandler.setAudioAutoGainControl(false);
|
|
await MediaDeviceHandler.setAudioEchoCancellation(true);
|
|
await MediaDeviceHandler.setAudioNoiseSuppression(false);
|
|
|
|
expectedAudioSettings.forEach((value, key) => {
|
|
expect(SettingsStoreMock.setValue).toHaveBeenCalledWith(key, null, SettingLevel.DEVICE, value);
|
|
});
|
|
|
|
expect(MatrixClientPeg.safeGet().getMediaHandler().setAudioSettings).toHaveBeenCalledWith({
|
|
autoGainControl: false,
|
|
echoCancellation: true,
|
|
noiseSuppression: false,
|
|
});
|
|
});
|
|
});
|