提交 9a7fdcca 编写于 作者: N NOBUGGERS

audioplayer base Signed-off-by: NOBUGGERS <ruanmeng@huawei.com>

Signed-off-by: NNOBUGGERS <ruanmeng@huawei.com>
上级 c5dfb00a
/*
* Copyright (C) 2022 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 media from '@ohos.multimedia.media'
import * as mediaTestBase from './MediaTestBase.js';
export function playAudioSource(src, duration, playTime, checkSeekTime, done) {
console.info(`case media source url: ${src}`)
let volumeChanged = false;
let playCount = 0;
let pauseCount = 0;
let stopCount = 0;
let seekCount = 0;
let audioPlayer = media.createAudioPlayer();
if (audioPlayer == null) {
console.error('case createAudioPlayer failed');
expect().assertFail();
done();
}
audioPlayer.src = src;
audioPlayer.on('dataLoad', () => {
console.info('case set source success');
expect(audioPlayer.state).assertEqual('paused');
expect(audioPlayer.currentTime).assertEqual(0);
expect(audioPlayer.duration).assertClose(duration, 500);
// step 0: dataLoad -> play
audioPlayer.play();
});
audioPlayer.on('play', () => {
console.info('case start to play');
expect(audioPlayer.state).assertEqual('playing');
playCount++;
if (playCount == 1) {
// step 1: play -> seek duration/3
mediaTestBase.msleep(playTime);
audioPlayer.seek(audioPlayer.duration / 3);
} else if (playCount == 2) {
// step 5: play -> seek duration when loop is true
audioPlayer.loop = true;
audioPlayer.seek(audioPlayer.duration);
} else if (playCount == 3) {
// step 9: play -> stop
audioPlayer.stop();
} else {
// step 12: play -> pause
audioPlayer.pause();
}
});
audioPlayer.on('pause', () => {
console.info('case now is paused');
expect(audioPlayer.state).assertEqual('paused');
pauseCount++;
if (pauseCount == 1) {
// step 3: pause -> seek 0
audioPlayer.seek(0);
} else {
// step 13: pause -> stop
audioPlayer.stop();
}
});
audioPlayer.on('stop', () => {
console.info('case stop success');
expect(audioPlayer.state).assertEqual('stopped');
stopCount++;
if (stopCount == 1) {
// step 10: stop -> reset
audioPlayer.reset();
} else {
// step 14: stop -> release
expect(volumeChanged).assertEqual(true);
audioPlayer.release();
done();
}
});
audioPlayer.on('reset', () => {
console.info('case reset success');
expect(audioPlayer.state).assertEqual('idle');
// step 11: reset -> dataLoad
audioPlayer.src = src;
});
audioPlayer.on('timeUpdate', (seekDoneTime) => {
seekCount++;
if (seekDoneTime == null) {
console.info(`case seek filed`);
audioPlayer.release();
expect().assertFail();
done();
return;
}
console.info('case seek success, and seek time is ' + seekDoneTime);
if (seekCount == 1) {
// step 2: seek duration/3 -> pause
expect(audioPlayer.state).assertEqual('playing');
if (checkSeekTime) {
expect(audioPlayer.duration / 3).assertEqual(seekDoneTime);
}
mediaTestBase.msleep(playTime);
audioPlayer.pause();
} else if (seekCount == 2){
// step 4: seek 0 -> play
if (checkSeekTime) {
expect(0).assertEqual(seekDoneTime);
}
expect(audioPlayer.state).assertEqual('paused');
audioPlayer.play();
} else if (seekCount == 3){
// step 6: seek duration -> setVolume + seek duration when loop is false
if (checkSeekTime) {
expect(audioPlayer.duration).assertEqual(seekDoneTime);
}
mediaTestBase.msleep(playTime);
expect(audioPlayer.state).assertEqual('playing');
audioPlayer.loop = false;
audioPlayer.setVolume(0.5);
audioPlayer.seek(audioPlayer.duration);
} else if (seekCount == 4){
// step 7: seek duration -> setVolume + seek duration when loop is false
if (checkSeekTime) {
expect(audioPlayer.duration).assertEqual(seekDoneTime);
}
mediaTestBase.msleep(playTime);
expect(audioPlayer.state).assertEqual('stopped');
}
});
audioPlayer.on('volumeChange', () => {
console.info('case set volume success ');
volumeChanged = true;
});
audioPlayer.on('finish', () => {
console.info('case play end');
expect(audioPlayer.state).assertEqual('stopped');
// step 8: play when stream is end
audioPlayer.play();
});
audioPlayer.on('error', (err) => {
console.error(`case error called,errMessage is ${err.message}`);
audioPlayer.release();
expect().assertFail();
done();
});
}
\ No newline at end of file
...@@ -38,7 +38,7 @@ export async function clearRouter() { ...@@ -38,7 +38,7 @@ export async function clearRouter() {
await router.clear(); await router.clear();
} }
export async function playVideoSource(url, width, height, duration, playTime) { export async function playVideoSource(url, width, height, duration, playTime, done) {
console.info(`case media source url: ${url}`) console.info(`case media source url: ${url}`)
let videoPlayer = null; let videoPlayer = null;
let surfaceID = globalThis.value; let surfaceID = globalThis.value;
...@@ -49,6 +49,7 @@ export async function playVideoSource(url, width, height, duration, playTime) { ...@@ -49,6 +49,7 @@ export async function playVideoSource(url, width, height, duration, playTime) {
} else { } else {
console.error('case createVideoPlayer failed'); console.error('case createVideoPlayer failed');
expect().assertFail(); expect().assertFail();
done();
} }
}, mediaTestBase.failureCallback).catch(mediaTestBase.catchCallback); }, mediaTestBase.failureCallback).catch(mediaTestBase.catchCallback);
...@@ -59,13 +60,14 @@ export async function playVideoSource(url, width, height, duration, playTime) { ...@@ -59,13 +60,14 @@ export async function playVideoSource(url, width, height, duration, playTime) {
videoPlayer.on('error', (err) => { videoPlayer.on('error', (err) => {
console.error(`case error called, errMessage is ${err.message}`); console.error(`case error called, errMessage is ${err.message}`);
expect().assertFail(); expect().assertFail();
videoPlayer.release();
done();
}); });
videoPlayer.url = url; videoPlayer.url = url;
if (width != null & height != null) {
await videoPlayer.setDisplaySurface(surfaceID).then(() => { await videoPlayer.setDisplaySurface(surfaceID).then(() => {
console.info('case setDisplaySurface success, surfaceID: ' + surfaceID); console.info('case setDisplaySurface success, surfaceID: ' + surfaceID);
}, mediaTestBase.failureCallback).catch(mediaTestBase.catchCallback); }, mediaTestBase.failureCallback).catch(mediaTestBase.catchCallback);
}
await videoPlayer.prepare().then(() => { await videoPlayer.prepare().then(() => {
console.info('case prepare called'); console.info('case prepare called');
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
} }
], ],
"deviceType": [ "deviceType": [
"phone", "default",
"tablet", "tablet",
"tv", "tv",
"wearable" "wearable"
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
} }
], ],
"deviceType": [ "deviceType": [
"phone", "default",
"tablet", "tablet",
"tv", "tv",
"wearable" "wearable"
......
# 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("//test/xts/tools/build/suite.gni")
ohos_js_hap_suite("recorder_format_js_hap") {
hap_profile = "./src/main/config.json"
deps = [
":recorder_format_js_assets",
":recorder_format_resources",
]
certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsRecorderFormatJsTest"
}
ohos_js_assets("recorder_format_js_assets") {
source_dir = "./src/main/js/default"
}
ohos_resources("recorder_format_resources") {
sources = [ "./src/main/resources" ]
hap_profile = "./src/main/config.json"
}
{
"description": "Configuration for audioRecorder Tests",
"driver": {
"type": "JSUnitTest",
"test-timeout": "1000000",
"package": "ohos.acts.multimedia.audio.recorderformat",
"shell-timeout": "60000"
},
"kits": [
{
"type": "ShellKit",
"run-command": [
],
"teardown-command":[
]
},
{
"test-file-name": [
"ActsRecorderFormatJsTest.hap"
],
"type": "AppInstallKit",
"cleanup-apps": true
}
]
}
\ No newline at end of file
{
"app": {
"apiVersion": {
"compatible": 6,
"releaseType": "Beta1",
"target": 7
},
"vendor": "acts",
"bundleName": "ohos.acts.multimedia.audio.recorderformat",
"version": {
"code": 1000000,
"name": "1.0.0"
}
},
"deviceConfig": {
"default": {
"debug": true
}
},
"module": {
"abilities": [
{
"iconId": 16777218,
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
]
}
],
"descriptionId": 16777217,
"visible": true,
"labelId": 16777216,
"icon": "$media:icon",
"name": "ohos.acts.multimedia.audio.recorderformat.MainAbility",
"description": "$string:mainability_description",
"label": "$string:entry_MainAbility",
"type": "page",
"homeAbility": true,
"launchType": "standard"
}
],
"deviceType": [
"default",
"tablet",
"tv",
"wearable"
],
"reqPermissions": [
{
"name" : "ohos.permission.GRANT_SENSITIVE_PERMISSIONS",
"reason" : "use ohos.permission.GRANT_SENSITIVE_PERMISSIONS"
},
{
"name" : "ohos.permission.REVOKE_SENSITIVE_PERMISSIONS",
"reason" : "use ohos.permission.REVOKE_SENSITIVE_PERMISSIONS"
},
{
"name" : "ohos.permission.MICROPHONE",
"reason" : "use ohos.permission.MICROPHONE"
},
{
"name" : "ohos.permission.MEDIA_LOCATION",
"reason" : "use ohos.permission.MEDIA_LOCATION"
},
{
"name" : "ohos.permission.READ_MEDIA",
"reason" : "use ohos.permission.READ_MEDIA"
},
{
"name" : "ohos.permission.WRITE_MEDIA",
"reason" : "use ohos.permission.WRITE_MEDIA"
}
],
"mainAbility": "ohos.acts.multimedia.audio.recorderformat.MainAbility",
"distro": {
"moduleType": "entry",
"installationFree": false,
"deliveryWithInstall": true,
"moduleName": "entry"
},
"package": "ohos.acts.multimedia.audio.recorderformat",
"name": ".MyApplication",
"js": [
{
"pages": [
"pages/index/index"
],
"name": "default",
"window": {
"designWidth": 720,
"autoDesignWidth": true
}
}
]
}
}
\ No newline at end of file
/*
* Copyright (C) 2022 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.
*/
package ohos.acts.multimedia.audio.audioplayer;
import ohos.ace.ability.AceAbility;
import ohos.aafwk.content.Intent;
/*
* java MainAbility
*/
public class MainAbility extends AceAbility {
@Override
public void onStart(Intent intent) {
super.onStart(intent);
}
@Override
public void onStop() {
super.onStop();
}
}
/*
* Copyright (C) 2022 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.
*/
package ohos.acts.multimedia.audio.audioplayer;
import ohos.aafwk.ability.AbilityPackage;
/*
* java MyApplication
*/
public class MyApplication extends AbilityPackage {
@Override
public void onInitialize() {
super.onInitialize();
}
}
/*
* Copyright (C) 2022 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.
*/
export default {
onCreate() {
console.info('AceApplication onCreate');
},
onDestroy() {
console.info('AceApplication onDestroy');
}
};
{
"strings": {
"hello": "Hello",
"world": "World"
}
}
\ No newline at end of file
{
"strings": {
"hello": "您好",
"world": "世界"
}
}
\ No newline at end of file
/*
* Copyright (C) 2022 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.
*/
.container {
flex-direction: column;
justify-content: center;
align-items: center;
width: 100%;
height: 100%;
}
.title {
font-size: 40px;
color: #000000;
opacity: 0.9;
}
@media screen and (device-type: tablet) and (orientation: landscape) {
.title {
font-size: 100px;
}
}
@media screen and (device-type: wearable) {
.title {
font-size: 28px;
color: #FFFFFF;
}
}
@media screen and (device-type: tv) {
.container {
background-image: url("/common/images/Wallpaper.png");
background-size: cover;
background-repeat: no-repeat;
background-position: center;
}
.title {
font-size: 100px;
color: #FFFFFF;
}
}
@media screen and (device-type: phone) and (orientation: landscape) {
.title {
font-size: 60px;
}
}
<!--
Copyright (c) 2022 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.
-->
<div class="container">
<text class="title">
{{ $t('strings.hello') }} {{ title }}
</text>
</div>
/*
* Copyright (C) 2022 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 {Core, ExpectExtend} from 'deccjsunit/index'
export default {
data: {
title: ""
},
onInit() {
this.title = this.$t('strings.world');
},
onShow() {
console.info('onShow finish')
const core = Core.getInstance()
const expectExtend = new ExpectExtend({
'id': 'extend'
})
core.addService('expect', expectExtend)
core.init()
const configService = core.getDefaultService('config')
this.timeout = 60000
configService.setConfig(this)
require('../../../test/List.test')
core.execute()
},
onReady() {
},
}
\ No newline at end of file
/*
* 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 media from '@ohos.multimedia.media'
import abilityAccessCtrl from '@ohos.abilityAccessCtrl'
import bundle from '@ohos.bundle'
import mediaLibrary from '@ohos.multimedia.mediaLibrary'
import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index'
describe('AudioRecorderFormatCompatibilityTest', function () {
const END_STATE = 0;
const PRE_STATE = 1;
const START_STATE = 2;
const PAUSE_STATE = 3;
const RESUME_STATE = 4;
const STOP_STATE = 5;
const RESET_STATE = 6;
const RELEASE_STATE = 7;
const ERROR_STATE = 8;
const RECORDER_TIME = 1000;
let fdPath;
let fileAsset;
let fdNumber;
let audioRecorder;
let audioConfig = {
audioSourceType : media.AudioSourceType.AUDIO_SOURCE_TYPE_MIC,
audioEncoder : media.AudioSourceType.AAC_LC,
audioEncodeBitRate : 22050,
audioSampleRate : 22050,
numberOfChannels : 2,
format : media.AudioOutputFormat.AAC_ADTS,
uri : 'file:///data/accounts/account_0/appdata/appdata/recorder/test.m4a',
location : { latitude : 1, longitude : 1 },
}
function sleep(time) {
for(let t = Date.now();Date.now() - t <= time;);
}
function initAudioRecorder() {
if (typeof (audioRecorder) != 'undefined') {
audioRecorder.release();
audioRecorder = undefined;
}
audioRecorder = media.createAudioRecorder();
}
beforeAll(async function () {
await applyPermission();
console.info('beforeAll case');
})
beforeEach(function () {
console.info('beforeEach case');
})
afterEach(async function () {
await closeFd();
console.info('afterEach case');
})
afterAll(function () {
console.info('afterAll case');
})
async function applyPermission() {
let appInfo = await bundle.getApplicationInfo('ohos.acts.multimedia.audio.recorderformat', 0, 100);
let atManager = abilityAccessCtrl.createAtManager();
if (atManager != null) {
let tokenID = appInfo.accessTokenId;
console.info('[permission] case accessTokenID is ' + tokenID);
let permissionName1 = 'ohos.permission.MICROPHONE';
let permissionName2 = 'ohos.permission.MEDIA_LOCATION';
let permissionName3 = 'ohos.permission.READ_MEDIA';
let permissionName4 = 'ohos.permission.WRITE_MEDIA';
await atManager.grantUserGrantedPermissi
on(tokenID, permissionName1, 1).then((result) => {
console.info('[permission] case grantUserGrantedPermission success :' + result);
}).catch((err) => {
console.error('[permission] case grantUserGrantedPermission failed :' + err);
});
await atManager.grantUserGrantedPermission(tokenID, permissionName2, 1).then((result) => {
console.info('[permission] case grantUserGrantedPermission success :' + result);
}).catch((err) => {
console.error('[permission] case grantUserGrantedPermission failed :' + err);
});
await atManager.grantUserGrantedPermission(tokenID, permissionName3, 1).then((result) => {
console.info('[permission] case grantUserGrantedPermission success :' + result);
}).catch((err) => {
console.error('[permission] case grantUserGrantedPermission failed :' + err);
});
await atManager.grantUserGrantedPermission(tokenID, permissionName4, 1).then((result) => {
console.info('[permission] case grantUserGrantedPermission success :' + result);
}).catch((err) => {
console.error('[permission] case grantUserGrantedPermission failed :' + err);
});
} else {
console.error('[permission] case apply permission failed, createAtManager failed');
}
}
async function getFd(pathName) {
let displayName = pathName;
const mediaTest = mediaLibrary.getMediaLibrary();
let fileKeyObj = mediaLibrary.FileKey;
let mediaType = mediaLibrary.MediaType.VIDEO;
let publicPath = await mediaTest.getPublicDirectory(mediaLibrary.DirectoryType.DIR_VIDEO);
let dataUri = await mediaTest.createAsset(mediaType, displayName, publicPath);
if (dataUri != undefined) {
let args = dataUri.id.toString();
let fetchOp = {
selections : fileKeyObj.ID + "=?",
selectionArgs : [args],
}
let fetchFileResult = await mediaTest.getFileAssets(fetchOp);
fileAsset = await fetchFileResult.getAllObject();
fdNumber = await fileAsset[0].open('Rw');
fdPath = "fd://" + fdNumber.toString();
console.info(`[mediaLibrary] case fdPath: ${fdPath}`);
} else {
console.error('[mediaLibrary] case dataUri is null')
}
}
async function closeFd() {
if (fileAsset != null) {
await fileAsset[0].close(fdNumber).then(() => {
console.info('[mediaLibrary] case close fd success');
}).catch((err) => {
console.error('[mediaLibrary] case close fd failed');
});
} else {
console.error('[mediaLibrary] case fileAsset is null');
}
}
function nextStep(mySteps, done) {
if (mySteps[0] == END_STATE) {
done();
console.info('case to done');
return;
}
switch (mySteps[0]) {
case PRE_STATE:
console.info('case to prepare');
audioRecorder.prepare(audioConfig);
break;
case START_STATE:
console.info('case to start');
audioRecorder.start();
break;
case PAUSE_STATE:
console.info('case to pause');
audioRecorder.pause();
break;
case RESUME_STATE:
console.info('case to resume');
audioRecorder.resume();
break;
case STOP_STATE:
console.info('case to stop');
audioRecorder.stop();
break;
case RESET_STATE:
console.info('case to reset');
audioRecorder.reset();
break;
case RELEASE_STATE:
console.info('case to release');
audioRecorder.release();
audioRecorder = undefined;
break;
case ERROR_STATE:
console.info('case to wait error callback');
break;
default:
break;
}
}
function setCallback(mySteps, done) {
audioRecorder.on('prepare', () => {
console.info('setCallback prepare() case callback is called');
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('start', () => {
console.info('setCallback start() case callback is called');
sleep(RECORDER_TIME);
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('pause', () => {
console.info('setCallback pause() case callback is called');
sleep(RECORDER_TIME);
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('resume', () => {
console.info('setCallback resume() case callback is called');
sleep(RECORDER_TIME);
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('stop', () => {
console.info('setCallback stop() case callback is called');
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('reset', () => {
console.info('setCallback reset() case callback is called');
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('release', () => {
console.info('setCallback release() case callback is called');
mySteps.shift();
nextStep(mySteps, done);
});
audioRecorder.on('error', (err) => {
console.info(`case error called,errName is ${err.name}`);
console.info(`case error called,errCode is ${err.code}`);
console.info(`case error called,errMessage is ${err.message}`);
mySteps.shift();
expect(mySteps[0]).assertEqual(ERROR_STATE);
mySteps.shift();
nextStep(mySteps, done);
});
}
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0100
* @tc.name : location: {latitude: -90, longitude: -180}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0100', 0, async function (done) {
await getFd('COMPATIBILITY_0100.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = -90;
audioConfig.location.longitude = -180;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0200
* @tc.name : location: {latitude: 90, longitude: 180}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0200', 0, async function (done) {
await getFd('COMPATIBILITY_0200.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = 90;
audioConfig.location.longitude = 180;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0300
* @tc.name : location: {latitude: 0, longitude: 0}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0300', 0, async function (done) {
await getFd('COMPATIBILITY_0300.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = 0;
audioConfig.location.longitude = 0;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0400
* @tc.name : location: {latitude: 0, longitude: 180}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0400', 0, async function (done) {
await getFd('COMPATIBILITY_0400.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = 0;
audioConfig.location.longitude = 180;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0500
* @tc.name : location: {latitude: -30, longitude: 60}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0500', 0, async function (done) {
await getFd('COMPATIBILITY_0500.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = -30;
audioConfig.location.longitude = 60;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
/* *
* @tc.number : SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0600
* @tc.name : location: {latitude: 60, longitude: -90}
* @tc.desc : location test
* @tc.size : MediumTest
* @tc.type : Function
* @tc.level : Level1
*/
it('SUB_MEDIA_AUDIO_RECORDER_FORMAT_COMPATIBILITY_0600', 0, async function (done) {
await getFd('COMPATIBILITY_0600.m4a');
audioConfig.uri = fdPath;
audioConfig.location.latitude = 60;
audioConfig.location.longitude = -90;
initAudioRecorder();
let mySteps = new Array(PRE_STATE, START_STATE, STOP_STATE, RELEASE_STATE, END_STATE);
setCallback(mySteps, done);
audioRecorder.prepare(audioConfig);
})
})
/*
* Copyright (C) 2022 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.
*/
require('./AudioRecorderFormatCompatibilityTest.test.js')
{
"string": [
{
"name": "entry_MainAbility",
"value": "entry_MainAbility"
},
{
"name": "mainability_description",
"value": "JS_Empty Ability"
}
]
}
\ No newline at end of file
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
} }
], ],
"deviceType": [ "deviceType": [
"phone", "default",
"tablet", "tablet",
"tv", "tv",
"wearable" "wearable"
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
} }
], ],
"deviceType": [ "deviceType": [
"phone", "default",
"tablet", "tablet",
"tv", "tv",
"wearable" "wearable"
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册