From 8b13ba225b798502f89bd01dde66516fe642ab04 Mon Sep 17 00:00:00 2001 From: durui Date: Fri, 28 Jul 2023 19:37:24 +0800 Subject: [PATCH] =?UTF-8?q?audio=E6=96=B0=E5=A2=9E=E6=8E=A5=E5=8F=A3?= =?UTF-8?q?=E7=94=A8=E4=BE=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: durui --- .../audio_js_standard/AudioCapturer/Test.json | 5 +- .../js/test/AudioPlaybackCapturer.test.js | 420 ++++++++++++++++++ .../src/main/js/test/List.test.js | 2 + .../src/main/js/test/AudioEffect.test.js | 4 +- 4 files changed, 428 insertions(+), 3 deletions(-) create mode 100644 multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/AudioPlaybackCapturer.test.js diff --git a/multimedia/audio/audio_js_standard/AudioCapturer/Test.json b/multimedia/audio/audio_js_standard/AudioCapturer/Test.json index 535ea2ed4..27d693989 100644 --- a/multimedia/audio/audio_js_standard/AudioCapturer/Test.json +++ b/multimedia/audio/audio_js_standard/AudioCapturer/Test.json @@ -21,7 +21,9 @@ "run-command": [ "power-shell wakeup", "uinput -T -d 300 600 -m 300 600 300 100 -u 300 100", - "power-shell setmode 602" + "power-shell setmode 602", + "mkdir -p /data/app/el2/100/base/ohos.acts.multimedia.audio.audiocapturer/haps/entry/files", + "chmod 777 -R /data/app/el2/100/base/ohos.acts.multimedia.audio.audiocapturer/haps/entry" ], "teardown-command":[ "power-shell setmode 600" @@ -32,6 +34,7 @@ "type": "PushKit", "pre-push": [], "push": [ + "./resource/media/audioplayer/wav/pcm_48ksr_32kbr_2ch.wav ->/data/app/el2/100/base/ohos.acts.multimedia.audio.audiocapturer/haps/entry/files/" ] } ] diff --git a/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/AudioPlaybackCapturer.test.js b/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/AudioPlaybackCapturer.test.js new file mode 100644 index 000000000..4284138e5 --- /dev/null +++ b/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/AudioPlaybackCapturer.test.js @@ -0,0 +1,420 @@ +/* + * Copyright (C) 2021 Huawei Device Co., Ltd. + * 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 audio from '@ohos.multimedia.audio'; +import fileio from '@ohos.fileio'; +import featureAbility from '@ohos.ability.featureAbility'; +import resourceManager from '@ohos.resourceManager'; +import { afterAll, afterEach, beforeAll, beforeEach, describe, expect, it } from '@ohos/hypium'; +import { UiDriver, BY } from '@ohos.UiTest' +export default function audioCapturer() { + + describe('AudioPlaybackCapturer', function () { + let Tag = 'AudioPlaybackCapturerTest'; + let fdRead; + let readPath; + let fdPath; + let filePath; + let dirPath; + const LE24 = -1; + const LE32 = -1; + function sleep(ms) { + return new Promise(resolve => setTimeout(resolve, ms)); + } + async function getPermission() { + let permissions = ['ohos.permission.MICROPHONE']; + featureAbility.getContext().requestPermissionsFromUser(permissions, 0, (data) => { + console.info("request success" + JSON.stringify(data)); + }) + } + async function driveFn() { + console.info(`come in driveFn`); + let driver = await UiDriver.create(); + console.info(`driver is ${JSON.stringify(driver)}`); + await sleep(100); + console.info(`UiDriver start`); + let button = await driver.findComponent(BY.text('允许')); + console.info(`button is ${JSON.stringify(button)}`); + await sleep(100); + await button.click(); + } + beforeAll(async function () { + await getPermission(); + await driveFn(); + console.info('TestLog: Start Testing AudioPlaybackCapturer Interfaces'); + }) + + beforeEach(async function () { + console.info(`${Tag} AudioFrameworkTest: beforeEach: Prerequisites at the test case level`); + await sleep(1000); + }) + + afterEach(function () { + console.info(`${Tag} AudioFrameworkTest: afterEach: Test case-level clearance conditions`); + }) + + afterAll(function () { + console.info(`${Tag} AudioFrameworkTest: afterAll: Test suite-level cleanup condition`); + }) + async function closeFileDescriptor(fileName) { + await resourceManager.getResourceManager().then(async (mgr) => { + await mgr.closeRawFileDescriptor(fileName).then(value => { + console.log(`${Tag}:case closeRawFileDescriptor success for file:${fileName}`); + }).catch(error => { + console.log(`${Tag}:case closeRawFileDescriptor err: ${error}`); + }); + }); + } + async function getFd(fileName) { + let context = await featureAbility.getContext(); + await context.getFilesDir().then((data) => { + dirPath = data + '/' + fileName; + console.info(`${Tag} case2 dirPath is ${JSON.stringify(dirPath)}`); + }) + } + + async function getFdRead(pathName, done) { + let context = await featureAbility.getContext(); + console.info(`case0 context is : ${context}`); + await context.getFilesDir().then((data) => { + console.info(`case1 getFilesDir is path : ${data}`); + filePath = data + '/' + pathName; + console.info(`case4 filePath is : ${filePath}`); + + }) + fdPath = 'fd://'; + await fileio.open(filePath).then((fdNumber) => { + fdPath = fdPath + '' + fdNumber; + fdRead = fdNumber; + console.info(`[fileIO]case open fd success,fdPath is : ${fdPath}`); + console.info(`[fileIO]case open fd success,fdRead is : ${fdRead}`); + + }, (err) => { + console.info(`[fileIO]case open fd failed : ${err}`); + }).catch((error) => { + console.info(`[fileIO]case catch open fd error : ${error}`); + }); + } + async function playbackPromise(AudioRendererOptions, pathName) { + let resultFlag = false; + let audioRen; + let isPass = false; + await audio.createAudioRenderer(AudioRendererOptions).then((data) => { + audioRen = data; + console.info(`${Tag}: AudioRender Created : Success : Stream Type: SUCCESS`); + }).catch((err) => { + console.info(`${Tag}: AudioRender Created : ERROR : ${err.message}`); + resultFlag = false; + }); + console.log(`isPass: ${isPass}`); + if (isPass) { + resultFlag = true; + return resultFlag; + } + console.info(`${Tag}: AudioRenderer : STATE : ${audioRen.state}`); + + await audioRen.start().then(() => { + console.info(`${Tag}: renderInstant started :SUCCESS`); + }).catch((err) => { + console.info(`${Tag}: renderInstant start :ERROR : ${err.message}`); + resultFlag = false; + }); + + console.info(`${Tag}: AudioRenderer : STATE : ${audioRen.state}`); + + let bufferSize; + await audioRen.getBufferSize().then((data) => { + console.info(`${Tag}: getBufferSize :SUCCESS ${data}`); + bufferSize = data; + }).catch((err) => { + console.info(`${Tag}: getBufferSize :ERROR : ${err.message}`); + resultFlag = false; + }); + + let ss = fileio.fdopenStreamSync(fdRead, 'r'); + console.info(`${Tag}:case 2:AudioFrameworkRenderLog: File Path: ${ss}`); + let discardHeader = new ArrayBuffer(44); + console.info(`${Tag}:case 2-1:AudioFrameworkRenderLog: File Path: `); + ss.readSync(discardHeader); + console.info(`${Tag}:case 2-2:AudioFrameworkRenderLog: File Path: `); + let totalSize = fileio.fstatSync(fdRead).size; + console.info(`${Tag}:case 3 : AudioFrameworkRenderLog: File totalSize size: ${totalSize}`); + totalSize = totalSize - 44; + console.info(`${Tag}: File size : Removing header: ${totalSize}`); + let rlen = 0; + while (rlen < totalSize / 4) { + let buf = new ArrayBuffer(bufferSize); + rlen += ss.readSync(buf); + console.info(`${Tag}:BufferAudioFramework: bytes read from file: ${rlen}`); + await audioRen.write(buf); + } + + console.info(`${Tag}: Renderer after read`); + + await audioRen.drain().then(() => { + console.info(`${Tag}: Renderer drained : SUCCESS`); + }).catch((err) => { + console.error(`${Tag}: Renderer drain: ERROR : ${err.message}`); + }); + + console.info(`${Tag}: AudioRenderer : STATE : ${audioRen.state}`); + + await audioRen.stop().then(() => { + console.info(`${Tag}: Renderer stopped : SUCCESS`); + }).catch((err) => { + console.info(`${Tag}: Renderer stop:ERROR : ${err.message}`); + }); + + console.info(`${Tag}: AudioRenderer : STATE : ${audioRen.state}`); + + await audioRen.release().then(() => { + console.info(`${Tag}: Renderer release : SUCCESS`); + }).catch((err) => { + console.info(`${Tag}: Renderer release :ERROR : ${err.message}`); + }); + + console.info(`${Tag}: AudioRenderer : STATE : ${audioRen.state}`); + return resultFlag; + } + async function recPromise(AudioCapturerOptions,AudioRendererOptions, pathName,done) { + let audioCap; + try { + audioCap = await audio.createAudioCapturer(AudioCapturerOptions); + console.info(`${Tag} AudioFrameworkRecLog: AudioCapturer Created : Success : Stream Type: success`); + } catch (err) { + console.info(`${Tag} AudioFrameworkRecLog: AudioCapturer Created : ERROR : ${JSON.stringify(err.message)}`); + LE24 = audio.AudioSampleFormat.SAMPLE_FORMAT_S24LE; + LE32 = audio.AudioSampleFormat.SAMPLE_FORMAT_S32LE; + let sampleFormat = AudioCapturerOptions.streamInfo.sampleFormat; + if ((sampleFormat == LE24 || sampleFormat == LE32) && err.code == 202) { + done(); + return; + } + expect(false).assertTrue(); + done(); + return; + } + + try { + let audioParamsGet = await audioCap.getStreamInfo(); + if (audioParamsGet != undefined && audioParamsGet != null) { + console.info(`${Tag} AudioFrameworkRecLog: Capturer getStreamInfo:${JSON.stringify(audioParamsGet)}`); + } else { + console.info(`${Tag} AudioFrameworkRecLog: audioParamsGet are incorrect,is : ${JSON.stringify(audioParamsGet)}`); + expect(false).assertTrue(); + } + } catch (err) { + console.log(`${Tag} AudioFrameworkRecLog: getStreamInfo :ERROR: ${JSON.stringify(err.message)}`); + expect(false).assertTrue(); + } + + try { + let audioParamsGet = await audioCap.getCapturerInfo(); + if (audioParamsGet != undefined) { + console.info(`${Tag} AudioFrameworkRecLog: Capturer CapturerInfo: ${JSON.stringify(audioParamsGet)}`); + } else { + console.info(`${Tag} AudioFrameworkRecLog: audioParamsGet are incorrect , is : ${JSON.stringify(audioParamsGet)}`); + expect(false).assertTrue(); + } + } catch (err) { + console.log(`${Tag} AudioFrameworkRecLog: CapturerInfo :ERROR: ${JSON.stringify(err.message)}`); + expect(false).assertTrue(); + } + + try { + await audioCap.start(); + console.log(`${Tag} start ok`); + await playbackPromise(AudioRendererOptions, pathName); + + let bufferSize = await audioCap.getBufferSize(); + console.log(`${Tag} bufferSize: ${JSON.stringify(bufferSize)} , dirPath: ${JSON.stringify(dirPath)}`); + let fd = fileio.openSync(dirPath, 0o102, 0o777); + console.log(`${Tag} fd: ${JSON.stringify(fd)}`); + if (fd !== null) { + console.info(`${Tag} AudioFrameworkRecLog: file fd created`); + } + else { + console.info(`${Tag} AudioFrameworkRecLog: Capturer start : ERROR `); + expect(false).assertTrue(); + } + + fd = fileio.openSync(dirPath, 0o2002, 0o666); + console.log(`${Tag} fd-re: ${JSON.stringify(fd)}`); + if (fd !== null) { + console.info(`${Tag} AudioFrameworkRecLog: file fd opened : Append Mode :PASS`); + } + else { + console.info(`${Tag} AudioFrameworkRecLog: file fd Open: Append Mode : FAILED`); + expect(false).assertTrue(); + } + + let numBuffersToCapture = 45; + while (numBuffersToCapture) { + console.info(`${Tag} AudioFrameworkRecLog: ---------READ BUFFER---------`); + let buffer = await audioCap.read(bufferSize, true); + console.info(`${Tag} AudioFrameworkRecLog: ---------WRITE BUFFER---------`); + let number = fileio.writeSync(fd, buffer); + console.info(`${Tag} AudioFrameworkRecLog:BufferRecLog: data written: ${JSON.stringify(number)}`); + numBuffersToCapture--; + } + console.log(`${Tag} read ok`); + await audioCap.stop(); + console.log(`${Tag} stop ok`); + } catch (err) { + console.log(`${Tag} start-read-stop err: ${JSON.stringify(err)}`); + expect(false).assertTrue(); + } + try { + await audioCap.release(); + console.log(`${Tag} release ok`); + } catch (err) { + console.log(`${Tag} release err: ${JSON.stringify(err)}`); + expect(false).assertTrue(); + } + done(); + } + /** + *@tc.number : SUB_MULTIMEDIA_AUDIO_INNER_CAPTURER_PROMISE_0100 + *@tc.name : SOURCE_TYPE_PLAYBACK_CAPTURER_PRIVACY_TYPE_PUBLIC + *@tc.desc : SOURCE_TYPE_PLAYBACK_CAPTURER_PRIVACY_TYPE_PUBLIC + *@tc.size : MEDIUM + *@tc.type : Function + *@tc.level : Level 2 + */ + it('SUB_MULTIMEDIA_AUDIO_INNER_CAPTURER_PROMISE_0100', 2, async function (done) { + let audioStreamInfo = { + samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_48000, + channels: audio.AudioChannel.CHANNEL_2, + sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S32LE, + encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW, + } + let audioCapturerInfo = { + source: audio.SourceType.SOURCE_TYPE_PLAYBACK_CAPTURE, + capturerFlags: 0 + } + let playbackCaptureConfig = { + CaptureFilterOptions: [ + { + usage: audio.StreamUsage.STREAM_USAGE_MEDIA + } + ] + } + let audioCapturerOptions = { + streamInfo: audioStreamInfo, + capturerInfo: audioCapturerInfo, + playbackCaptureConfig: playbackCaptureConfig, + } + + let AudioStreamInfo = { + samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_48000, + channels: audio.AudioChannel.CHANNEL_2, + sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S32LE, + encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW + } + + let AudioRendererInfo = { + + usage: audio.StreamUsage.STREAM_USAGE_MEDIA, + rendererFlags: 0 + } + let AudioPrivacyType = { + privacyType:audio.AudioPrivacyType.PRIVACY_TYPE_PUBLIC + } + + let AudioRendererOptions = { + streamInfo: AudioStreamInfo, + rendererInfo: AudioRendererInfo, + privacyType : AudioPrivacyType + } + readPath = 'pcm_48ksr_32kbr_2ch.wav' + await getFdRead(readPath, done); + await getFd("capture_js-48000-2C-1S32LE.pcm"); + await recPromise(audioCapturerOptions,AudioRendererOptions,filePath,done); + await sleep(100); + await closeFileDescriptor(readPath); + done(); + }) + + /** + *@tc.number : SUB_MULTIMEDIA_AUDIO_INNER_CAPTURER_PROMISE_0200 + *@tc.name : SOURCE_TYPE_PLAYBACK_CAPTURER_PRIVACY_TYPE_PUBLIC + *@tc.desc : SOURCE_TYPE_PLAYBACK_CAPTURER_PRIVACY_TYPE_PUBLIC + *@tc.size : MEDIUM + *@tc.type : Function + *@tc.level : Level 2 + */ + it('SUB_MULTIMEDIA_AUDIO_INNER_CAPTURER_PROMISE_0200', 2, async function (done) { + let audioStreamInfo = { + samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_44100, + channels: audio.AudioChannel.CHANNEL_2, + sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S32LE, + encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW, + } + let audioCapturerInfo = { + source: audio.SourceType.SOURCE_TYPE_PLAYBACK_CAPTURE, + capturerFlags: 0 + } + let playbackCaptureConfig = { + CaptureFilterOptions: [ + { + usage: audio.StreamUsage.STREAM_USAGE_MOVIE + } + ] + } + let audioCapturerOptions = { + streamInfo: audioStreamInfo, + capturerInfo: audioCapturerInfo, + playbackCaptureConfig: playbackCaptureConfig, + } + + let AudioStreamInfo = { + samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_48000, + channels: audio.AudioChannel.CHANNEL_2, + sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S32LE, + encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW + } + + let AudioRendererInfo = { + + usage: audio.StreamUsage.STREAM_USAGE_MOVIE, + rendererFlags: 0 + } + let AudioPrivacyType = { + privacyType:audio.AudioPrivacyType.PRIVACY_TYPE_PRIVATE + } + + let AudioRendererOptions = { + streamInfo: AudioStreamInfo, + rendererInfo: AudioRendererInfo, + privacyType : AudioPrivacyType + } + readPath = 'pcm_48ksr_32kbr_2ch.wav' + await getFdRead(readPath, done); + await getFd("capture_js-44100-2C-1S32LE.pcm"); + await recPromise(audioCapturerOptions,AudioRendererOptions,filePath,done); + await sleep(100); + await closeFileDescriptor(readPath); + done(); + }) + + + + + + + + }) + +} diff --git a/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/List.test.js b/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/List.test.js index a086d3f20..b0c27843c 100644 --- a/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/List.test.js +++ b/multimedia/audio/audio_js_standard/AudioCapturer/src/main/js/test/List.test.js @@ -15,10 +15,12 @@ import audioCapturer from './AudioCapturer.test.js' import AudioCapturerInterruptUnitTest from './AudioCapturerInterrupt.test.js' + import AudioPlaybackCapturer from './AudioPlaybackCapturer.test.js' export default function testsuite() { audioCapturer() AudioCapturerInterruptUnitTest() + AudioPlaybackCapturer() } diff --git a/multimedia/audio/audio_js_standard/audioRenderer/src/main/js/test/AudioEffect.test.js b/multimedia/audio/audio_js_standard/audioRenderer/src/main/js/test/AudioEffect.test.js index ed9415511..eff378e85 100644 --- a/multimedia/audio/audio_js_standard/audioRenderer/src/main/js/test/AudioEffect.test.js +++ b/multimedia/audio/audio_js_standard/audioRenderer/src/main/js/test/AudioEffect.test.js @@ -406,7 +406,7 @@ describe('AudioEffect', function () { /** * @tc.number : SUB_MULTIMEDIA_AUDIO_GET_AUDIOEFFECTINFOARRY_0100 * @tc.name : GET_AUDIOEFFECTINFOARRY - UNKNOWN - Promise - * @tc.desc : GET_AUDIOEFFECTINFOARRY - UNKNOWN - UNKNOWN & UNKNOWN + * @tc.desc : GET_AUDIOEFFECTINFOARRY - UNKNOWN * @tc.size : MEDIUM * @tc.type : Function * @tc.level : Level 2 @@ -520,7 +520,7 @@ describe('AudioEffect', function () { */ it('SUB_MULTIMEDIA_AUDIO_GET_AUDIOEFFECTINFOARRY_0500', 2, async function (done) { try { - audioStreamManager.getAudioEffectInfoArray(audio.StreamUsage.STREAM_USAGE_MEDIA).then((audioEffectInfoArray) => { + audioStreamManager.getAudioEffectInfoArray(audio.StreamUsage.STREAM_USAGE_MOVIE).then((audioEffectInfoArray) => { expect(audioEffectInfoArray[0]).assertEqual(0); expect(audioEffectInfoArray[1]).assertEqual(1); console.log(`${TAG} getAudioEffectInfoArray success:${JSON.stringify(audioEffectInfoArray)}`); -- GitLab