106 lines
3.2 KiB
TypeScript
106 lines
3.2 KiB
TypeScript
|
/*
|
||
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
||
|
|
||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
you may not use this file except in compliance with the License.
|
||
|
You may obtain a copy of the License at
|
||
|
|
||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
|
||
|
Unless required by applicable law or agreed to in writing, software
|
||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
See the License for the specific language governing permissions and
|
||
|
limitations under the License.
|
||
|
*/
|
||
|
|
||
|
import { VoiceRecording } from "../../src/audio/VoiceRecording";
|
||
|
|
||
|
/**
|
||
|
* The tests here are heavily using access to private props.
|
||
|
* While this is not so great, we can at lest test some behaviour easily this way.
|
||
|
*/
|
||
|
describe("VoiceRecording", () => {
|
||
|
let recording: VoiceRecording;
|
||
|
let recorderSecondsSpy: jest.SpyInstance;
|
||
|
|
||
|
const itShouldNotCallStop = () => {
|
||
|
it("should not call stop", () => {
|
||
|
expect(recording.stop).not.toHaveBeenCalled();
|
||
|
});
|
||
|
};
|
||
|
|
||
|
const simulateUpdate = (recorderSeconds: number) => {
|
||
|
beforeEach(() => {
|
||
|
recorderSecondsSpy.mockReturnValue(recorderSeconds);
|
||
|
// @ts-ignore
|
||
|
recording.processAudioUpdate(recorderSeconds);
|
||
|
});
|
||
|
};
|
||
|
|
||
|
beforeEach(() => {
|
||
|
recording = new VoiceRecording();
|
||
|
// @ts-ignore
|
||
|
recording.observable = {
|
||
|
update: jest.fn(),
|
||
|
};
|
||
|
jest.spyOn(recording, "stop").mockImplementation();
|
||
|
recorderSecondsSpy = jest.spyOn(recording, "recorderSeconds", "get");
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
jest.resetAllMocks();
|
||
|
});
|
||
|
|
||
|
describe("when recording", () => {
|
||
|
beforeEach(() => {
|
||
|
// @ts-ignore
|
||
|
recording.recording = true;
|
||
|
});
|
||
|
|
||
|
describe("and there is an audio update and time left", () => {
|
||
|
simulateUpdate(42);
|
||
|
itShouldNotCallStop();
|
||
|
});
|
||
|
|
||
|
describe("and there is an audio update and time is up", () => {
|
||
|
// one second above the limit
|
||
|
simulateUpdate(901);
|
||
|
|
||
|
it("should call stop", () => {
|
||
|
expect(recording.stop).toHaveBeenCalled();
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe("and the max length limit has been disabled", () => {
|
||
|
beforeEach(() => {
|
||
|
recording.disableMaxLength();
|
||
|
});
|
||
|
|
||
|
describe("and there is an audio update and time left", () => {
|
||
|
simulateUpdate(42);
|
||
|
itShouldNotCallStop();
|
||
|
});
|
||
|
|
||
|
describe("and there is an audio update and time is up", () => {
|
||
|
// one second above the limit
|
||
|
simulateUpdate(901);
|
||
|
itShouldNotCallStop();
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe("when not recording", () => {
|
||
|
describe("and there is an audio update and time left", () => {
|
||
|
simulateUpdate(42);
|
||
|
itShouldNotCallStop();
|
||
|
});
|
||
|
|
||
|
describe("and there is an audio update and time is up", () => {
|
||
|
// one second above the limit
|
||
|
simulateUpdate(901);
|
||
|
itShouldNotCallStop();
|
||
|
});
|
||
|
});
|
||
|
});
|