From fc03417e745e6d9d5cca4dc9a9194ac28a576b9d Mon Sep 17 00:00:00 2001 From: ling990 Date: Wed, 8 Jun 2022 11:20:17 +0800 Subject: [PATCH] modify testcases Signed-off-by: ling990 Signed-off-by: ling990 --- multimedia/BUILD.gn | 5 +- .../media_js_standard/audioDecoder/BUILD.gn | 32 - .../media_js_standard/audioDecoder/Test.json | 41 - .../audioDecoder/signature/openharmony_sx.p7b | Bin 3437 -> 0 bytes .../audioDecoder/src/main/config.json | 74 - .../audioDecoder/src/main/js/default/app.js | 23 - .../src/main/js/default/i18n/en-US.json | 6 - .../src/main/js/default/i18n/zh-CN.json | 6 - .../src/main/js/default/pages/index/index.css | 61 - .../src/main/js/default/pages/index/index.hml | 20 - .../src/main/js/default/pages/index/index.js | 41 - .../main/js/test/AudioDecoderEnumTest.test.js | 163 -- .../AudioDecoderFormatCallbackTest.test.js | 912 ---------- .../AudioDecoderFormatPromiseTest.test.js | 767 -------- .../test/AudioDecoderFuncCallbackTest.test.js | 1084 ------------ .../test/AudioDecoderFuncPromiseTest.test.js | 883 ---------- .../AudioDecoderMultiInstancesTest.test.js | 272 --- ...udioDecoderReliabilityCallbackTest.test.js | 1348 -------------- ...AudioDecoderReliabilityPromiseTest.test.js | 1349 -------------- .../src/main/js/test/List.test.js | 25 - .../main/resources/base/element/string.json | 12 - .../src/main/resources/base/media/icon.png | Bin 6790 -> 0 bytes .../media_js_standard/audioEncoder/BUILD.gn | 32 - .../media_js_standard/audioEncoder/Test.json | 37 - .../audioEncoder/signature/openharmony_sx.p7b | Bin 3437 -> 0 bytes .../audioEncoder/src/main/config.json | 74 - .../audioEncoder/src/main/js/default/app.js | 23 - .../src/main/js/default/i18n/en-US.json | 6 - .../src/main/js/default/i18n/zh-CN.json | 6 - .../src/main/js/default/pages/index/index.css | 61 - .../src/main/js/default/pages/index/index.hml | 20 - .../src/main/js/default/pages/index/index.js | 41 - .../test/AudioEncoderFuncCallbackTest.test.js | 798 --------- .../test/AudioEncoderFuncPromiseTest.test.js | 649 ------- .../AudioEncoderMultiInstancesTest.test.js | 322 ---- ...udioEncoderReliabilityCallbackTest.test.js | 1196 ------------- ...AudioEncoderReliabilityPromiseTest.test.js | 1200 ------------- .../src/main/js/test/List.test.js | 20 - .../main/resources/base/element/string.json | 12 - .../src/main/resources/base/media/icon.png | Bin 6790 -> 0 bytes .../media_js_standard/videoDecoder/BUILD.gn | 31 - .../media_js_standard/videoDecoder/Test.json | 39 - .../videoDecoder/signature/openharmony_sx.p7b | Bin 3437 -> 0 bytes .../videoDecoder/src/main/config.json | 75 - .../videoDecoder/src/main/js/default/app.js | 23 - .../src/main/js/default/i18n/en-US.json | 6 - .../src/main/js/default/i18n/zh-CN.json | 6 - .../main/js/default/pages/display/display.css | 61 - .../main/js/default/pages/display/display.hml | 26 - .../main/js/default/pages/display/display.js | 33 - .../src/main/js/default/pages/index/index.css | 61 - .../src/main/js/default/pages/index/index.hml | 20 - .../src/main/js/default/pages/index/index.js | 42 - .../src/main/js/test/List.test.js | 24 - .../main/js/test/VideoDecoderEnumTest.test.js | 355 ---- .../test/VideoDecoderFuncCallbackTest.test.js | 437 ----- .../test/VideoDecoderFuncPromiseTest.test.js | 487 ------ .../test/VideoDecoderReliCallbackTest.test.js | 1277 -------------- .../test/VideoDecoderReliPromiseTest.test.js | 1268 -------------- ...deoDecoderSoftwareFuncCallbackTest.test.js | 542 ------ ...ideoDecoderSoftwareFuncPromiseTest.test.js | 537 ------ ...deoDecoderSoftwareReliCallbackTest.test.js | 1278 -------------- ...ideoDecoderSoftwareReliPromiseTest.test.js | 1271 -------------- .../main/resources/base/element/string.json | 12 - .../src/main/resources/base/media/icon.png | Bin 6790 -> 0 bytes .../src/main/resources/base/media/info.txt | 1 - .../src/main/resources/base/media/mp3_MP3.mp3 | Bin 222715 -> 0 bytes .../media_js_standard/videoEncoder/BUILD.gn | 32 - .../media_js_standard/videoEncoder/Test.json | 36 - .../videoEncoder/signature/openharmony_sx.p7b | Bin 3437 -> 0 bytes .../videoEncoder/src/main/config.json | 74 - .../videoEncoder/src/main/js/default/app.js | 23 - .../src/main/js/default/i18n/en-US.json | 6 - .../src/main/js/default/i18n/zh-CN.json | 6 - .../src/main/js/default/pages/index/index.css | 61 - .../src/main/js/default/pages/index/index.hml | 20 - .../src/main/js/default/pages/index/index.js | 41 - .../src/main/js/test/List.test.js | 22 - .../main/js/test/VideoEncoderEnumTest.test.js | 52 - .../VideoEncoderMultiInstancesTest.test.js | 320 ---- ...deoEncoderSoftwareFuncCallbackTest.test.js | 562 ------ ...ideoEncoderSoftwareFuncPromiseTest.test.js | 698 -------- ...derSoftwareReliabilityCallbackTest.test.js | 1551 ----------------- ...oderSoftwareReliabilityPromiseTest.test.js | 1524 ---------------- .../test/VideoHardwareEncoderEnumTest.test.js | 64 - .../main/resources/base/element/string.json | 12 - .../src/main/resources/base/media/icon.png | Bin 6790 -> 0 bytes 87 files changed, 1 insertion(+), 24636 deletions(-) delete mode 100644 multimedia/media/media_js_standard/audioDecoder/BUILD.gn delete mode 100644 multimedia/media/media_js_standard/audioDecoder/Test.json delete mode 100644 multimedia/media/media_js_standard/audioDecoder/signature/openharmony_sx.p7b delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/config.json delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/app.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/en-US.json delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/zh-CN.json delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.css delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.hml delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderEnumTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderMultiInstancesTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/js/test/List.test.js delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/element/string.json delete mode 100644 multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/media/icon.png delete mode 100644 multimedia/media/media_js_standard/audioEncoder/BUILD.gn delete mode 100644 multimedia/media/media_js_standard/audioEncoder/Test.json delete mode 100644 multimedia/media/media_js_standard/audioEncoder/signature/openharmony_sx.p7b delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/config.json delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/app.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/en-US.json delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/zh-CN.json delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.css delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.hml delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderMultiInstancesTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/js/test/List.test.js delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/element/string.json delete mode 100644 multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/media/icon.png delete mode 100644 multimedia/media/media_js_standard/videoDecoder/BUILD.gn delete mode 100644 multimedia/media/media_js_standard/videoDecoder/Test.json delete mode 100644 multimedia/media/media_js_standard/videoDecoder/signature/openharmony_sx.p7b delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/config.json delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/app.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/en-US.json delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/zh-CN.json delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.css delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.hml delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.css delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.hml delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/List.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderEnumTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/element/string.json delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/media/icon.png delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/media/info.txt delete mode 100644 multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/media/mp3_MP3.mp3 delete mode 100644 multimedia/media/media_js_standard/videoEncoder/BUILD.gn delete mode 100644 multimedia/media/media_js_standard/videoEncoder/Test.json delete mode 100644 multimedia/media/media_js_standard/videoEncoder/signature/openharmony_sx.p7b delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/config.json delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/app.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/en-US.json delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/zh-CN.json delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.css delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.hml delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/List.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderEnumTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderMultiInstancesTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityCallbackTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityPromiseTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoHardwareEncoderEnumTest.test.js delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/element/string.json delete mode 100644 multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/media/icon.png diff --git a/multimedia/BUILD.gn b/multimedia/BUILD.gn index 11b6aac6a..2708748cc 100644 --- a/multimedia/BUILD.gn +++ b/multimedia/BUILD.gn @@ -20,13 +20,10 @@ group("multimedia") { "audio/audio_js_standard/audioManager:audio_manager_js_hap", "camera/camera_js_standard:camera_standard_ets_hap", "image/image_js_standard:image_js_hap", - "media/media_js_standard/audioDecoder:audio_decoder_js_hap", - "media/media_js_standard/audioEncoder:audio_encoder_js_hap", "media/media_js_standard/audioPlayer:audio_player_js_hap", "media/media_js_standard/audioRecorder:audio_recorder_js_hap", - "media/media_js_standard/videoDecoder:video_decoder_js_hap", - "media/media_js_standard/videoEncoder:video_encoder_js_hap", "media/media_js_standard/videoPlayer:video_player_js_hap", + #"media/media_js_standard/videoRecorder:video_recorder_js_hap", "medialibrary/mediaLibrary_js_standard:mediaLibrary_js_hap", ] diff --git a/multimedia/media/media_js_standard/audioDecoder/BUILD.gn b/multimedia/media/media_js_standard/audioDecoder/BUILD.gn deleted file mode 100644 index 05613d295..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/BUILD.gn +++ /dev/null @@ -1,32 +0,0 @@ -# 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("//test/xts/tools/build/suite.gni") - -ohos_js_hap_suite("audio_decoder_js_hap") { - hap_profile = "./src/main/config.json" - js2abc = true - deps = [ - ":audio_decoder_js_assets", - ":audio_decoder_resources", - ] - certificate_profile = "./signature/openharmony_sx.p7b" - hap_name = "ActsAudioDecoderJsTest" -} -ohos_js_assets("audio_decoder_js_assets") { - source_dir = "./src/main/js/default" -} -ohos_resources("audio_decoder_resources") { - sources = [ "./src/main/resources" ] - hap_profile = "./src/main/config.json" -} diff --git a/multimedia/media/media_js_standard/audioDecoder/Test.json b/multimedia/media/media_js_standard/audioDecoder/Test.json deleted file mode 100644 index cedb3b5ec..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/Test.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "description": "Configuration for audioDecoder Tests", - "driver": { - "type": "JSUnitTest", - "test-timeout": "2000000", - "package": "ohos.acts.multimedia.audio.audiodecoder", - "shell-timeout": "60000" - }, - "kits": [ - { - "test-file-name": [ - "ActsAudioDecoderJsTest.hap" - ], - "type": "AppInstallKit", - "cleanup-apps": true - }, - { - "type": "PushKit", - "pre-push": [ - ], - "push": [ - "./resource/audio/audioDecode/AAC_48000_32_1.aac ->/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/", - "./resource/audio/audioDecode/AAC_16000_1.aac ->/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/", - "./resource/audio/audioDecode/FLAC_48000_32_1.flac ->/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/", - "./resource/audio/audioDecode/mp3.es ->/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/", - "./resource/audio/audioDecode/vorbis.es ->/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/" - ] - }, - { - "type": "ShellKit", - "run-command": [ - "rm -R /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/results", - "mkdir -p /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/results/", - "chmod 777 -R /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder", - "chmod 777 /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/*" - ], - "teardown-command":[ - ] - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/signature/openharmony_sx.p7b b/multimedia/media/media_js_standard/audioDecoder/signature/openharmony_sx.p7b deleted file mode 100644 index 9be1e98fa4c0c28ca997ed660112fa16b194f0f5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3437 zcmcgvX>b$g8MY4FF(5FQyMT=#m||qU)nQ9cId-MBB-<-lvSdq&snM}IENNF>t+bK| zgowuF2vC|SxSZxNN5eHhV%(WPpbeB9Fc3;JDMtzMBv1-XAc2N~c2_tCXW&OCGw6qQ z-s9VS-tT?h=bI0tMS+~WDXqHJyCPmLzdbE-fV8Nd&*MRZfG8(#POFZG3xs@Lb{0ry z=R8j3wWo!5g=yjKx#BoZMFS)uA)H}cTp@-^K`9VV?RC3J59@}eik*>n|pRKOLZ zxdn7G!Yv@9O#y<&eUy{)vMXb;fQR)ffVAADQsEMXm;IBMDLfLD0w^U;6%HVo-0Q_5 zCHEa?DBuauNpZzoF+tK27w#n~?u%toS-DhR4k@Q*{7x^8Q=D6&kd^_~J#VVG2LXkL zaAy=}U*?Jto)9hx5MGjdp9hcQAu@tfk_;l!PeyxPY<8b&+&D!CyaBh9=8BSVKLpk4 z4Ml3yY|&Th)vyK4cpC{!uU8v2YBlVV`d~(nz&<@{G1oe*DHub1z7~J5*;s2bX<)_* zV_GbsPQg`(&rpxRb_*Od7}++3+liSw-$!1 zs5*g}EHWhI3i|!-FcfzYL0`SL-rq>LENC;PMl)G(0(1U2%Va|smp0UFx0xd@soZA* zD5LYc4OlbE7@ARt#h}rr3>K@bf%B#^-c+xz8Hr)0D5ExIFltezN@Hn8>o5d~bSfYtkc+_Z&kI#-N5_GhCg*V-^TSO=!G~ z(fXy{n2XV+k}6w_W`dTOP2a4u0ly;ANZ>4OxSKAzFB!yBzdo`gX zO?o|H@WiAw$y6l?=^3jA_Hy0S)nTYs12;4hKE&ekQ|>?|ZLJ}#F`2BczC7kdE4@xV zZBD_)Otwjhz+NSaz?d45!;FsGSu-#qh#hStD%B}f!mCT!KqzSo>I`NGH_9Dea$1Qi zg29Ydt!~lQVR99_T7#Hije~(12drl-P)SV?QR*9sus`8th-8^OQ7@xI$(Yp|^;bL1 zR50O$mDXw6P>i7B(TJ)ciPzTE>XY%X6HAa)b#OBRXv&~%Bw|J#Y><i4=e%95bjtw|cJp=#P#Pf#*luqI_wR;fISDCJhAqSG6R%xItn%~QtZ@m%&u zjGGLX;t6Ls62eQvNmf@v+}J%54^CygxRZ`?8X#r|wkev7(s;Ou4T#y1XNNf)h;o7z z8a^Lfq<1uH`E{G9E z*(=)Css_LSk=>E9jr)s5^2-!+MN=Ds}>1hRma4`uCIz9%p3O77839E{xf z4c_I?**|1`K2tg4!Hvyrou4BsJQuv*UfF)<%CelYIS>D^o?X)3+MK%la6kooW8&G@BU)Y0hT`+mOm$Z_%rB=a%o>I z!2c6lHyKQN)VjiFwa!eE^p8jc$sy$vB+8i25lI~6KPFFh$!o$avA~rj#L6xvR|Z83 z*WD6T9e+5Pyy=F+)pNTf{ny3cy>7Rkd3o*TS?TZJ`NS^NF2%HMkyS{?uJ$`!P4_L^ z1`NFDUbNyg_qREifgktnp1_v{Jbb`7m}2PTyUdOmtJj~m z9bB=ecw4_^rw1IW=of+>nrW5=d3k`3qHCxsIN_F{T1A545};;+fsyC&qChi+YV zr~M63H8ZLCPYmsjY>ls9cL%I)F|JIW-#+48$+lD4k*(P*kDM%zx_fvu4u5ZYUnI}5 zdrycFq>xFU)&X3p@pP2u%$o}}YcRn(MhJ&B2o?KS@cIVz>Ye%o^xV?CB{_Qhu z;}_q1bvO^g{8<3!gYbo4Di{8qzV+(9 zdlmksohQmRTs@qB;(Wo?dER_ux6XQb@q$tQPW?CMu6GVQd;R=iR;-S{Kr%Zks7>b1 zNs{|-+jhObYE}NR&`TGGr^h^4bjh%c>R#@=8nM&Md>_a+zVulsl;){flFekV1t9ob z+SqfV_Pv3$2f)bQ8%Ul2>fdYR^1zs0BQF~olsOj5AodC&Q_7SMFzsz2 z9newxE&jodk~tNHwl%LBMMDbrk=(^b diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/config.json b/multimedia/media/media_js_standard/audioDecoder/src/main/config.json deleted file mode 100644 index ac9aca6e8..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/config.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "app": { - "apiVersion": { - "compatible": 6, - "releaseType": "Beta1", - "target": 7 - }, - "vendor": "acts", - "bundleName": "ohos.acts.multimedia.audio.audiodecoder", - "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.audiodecoder.MainAbility", - "description": "$string:mainability_description", - "label": "$string:entry_MainAbility", - "type": "page", - "homeAbility": true, - "launchType": "standard" - } - ], - "deviceType": [ - "phone", - "tablet", - "tv", - "wearable" - ], - "mainAbility": "ohos.acts.multimedia.audio.audiodecoder.MainAbility", - "distro": { - "moduleType": "entry", - "installationFree": false, - "deliveryWithInstall": true, - "moduleName": "entry" - }, - "package": "ohos.acts.multimedia.audio.audiodecoder", - "name": ".MyApplication", - "js": [ - { - "pages": [ - "pages/index/index" - ], - "name": "default", - "window": { - "designWidth": 720, - "autoDesignWidth": true - } - } - ] - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/app.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/app.js deleted file mode 100644 index 830070d19..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/app.js +++ /dev/null @@ -1,23 +0,0 @@ -/* - * 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'); - } -}; diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/en-US.json b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/en-US.json deleted file mode 100644 index e63c70d97..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/en-US.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "Hello", - "world": "World" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/zh-CN.json b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/zh-CN.json deleted file mode 100644 index de6ee5748..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/i18n/zh-CN.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "您好", - "world": "世界" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.css b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.css deleted file mode 100644 index c9195944a..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.css +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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; - } -} diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.hml b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.hml deleted file mode 100644 index 8d0e2061b..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.hml +++ /dev/null @@ -1,20 +0,0 @@ - - -
- - {{ $t('strings.hello') }} {{ title }} - -
diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.js deleted file mode 100644 index 67f8b8567..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/default/pages/index/index.js +++ /dev/null @@ -1,41 +0,0 @@ -/* - * 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 diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderEnumTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderEnumTest.test.js deleted file mode 100644 index 4b04c73a0..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderEnumTest.test.js +++ /dev/null @@ -1,163 +0,0 @@ -/* - * 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 {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderEnum', function () { - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - }) - - afterEach(function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_ENUM_AACProfile_0100 - * @tc.name : 001.AACProfile - * @tc.desc : Test Enumerate AACProfile - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_ENUM_AACProfile_0100', 0, async function (done) { - expect(media.AACProfile.AAC_PROFILE_LC).assertEqual(0); - expect(media.AACProfile.AAC_PROFILE_ELD).assertEqual(1); - expect(media.AACProfile.AAC_PROFILE_ERLC).assertEqual(2); - expect(media.AACProfile.AAC_PROFILE_HE).assertEqual(3); - expect(media.AACProfile.AAC_PROFILE_HE_V2).assertEqual(4); - expect(media.AACProfile.AAC_PROFILE_LD).assertEqual(5); - expect(media.AACProfile.AAC_PROFILE_MAIN).assertEqual(6); - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_ENUM_AudioCaps_0100 - * @tc.name : 002.AudioCaps - * @tc.desc : Test Interface AudioCaps - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_ENUM_AudioCaps_0100', 0, async function (done) { - console.info("case test Test Interface AudioCaps"); - let audioDecodeProcessor; - let audioCaps; - await media.createAudioDecoderByName('avdec_aac').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - audioCaps = AudioCaps; - }, failCallback).catch(failCatch); - // check AudioCaps - expect(audioCaps.codecInfo !== undefined).assertTrue(); - - // check AudioCaps.AVCodecInfo - let avCodecInfo = audioCaps.codecInfo; - expect(avCodecInfo.name !== undefined).assertTrue(); - console.info('avCodecInfo.name: '+ avCodecInfo.name); - expect(avCodecInfo.type !== undefined).assertTrue(); - console.info('avCodecInfo.type: '+ avCodecInfo.type); - expect(avCodecInfo.mimeType !== undefined).assertTrue(); - console.info('avCodecInfo.mimeType: '+ avCodecInfo.mimeType); - expect(avCodecInfo.isHardwareAccelerated !== undefined).assertTrue(); - console.info('avCodecInfo.isHardwareAccelerated: '+ avCodecInfo.isHardwareAccelerated); - expect(avCodecInfo.isSoftwareOnly !== undefined).assertTrue(); - console.info('avCodecInfo.isSoftwareOnly: '+ avCodecInfo.isSoftwareOnly); - expect(avCodecInfo.isVendor !== undefined).assertTrue(); - console.info('avCodecInfo.isVendor: '+ avCodecInfo.isVendor); - - // check AudioCaps.supportedBitrate - expect(audioCaps.supportedBitrate !== undefined).assertTrue(); - console.info('supportedBitrate.min: '+ audioCaps.supportedBitrate.min); - console.info('supportedBitrate.max: '+ audioCaps.supportedBitrate.max); - - // check AudioCaps.supportedChannel - expect(audioCaps.supportedChannel !== undefined).assertTrue(); - console.info('supportedChannel.min: '+ audioCaps.supportedChannel.min); - console.info('supportedChannel.max: '+ audioCaps.supportedChannel.max); - - // check AudioCaps.supportedFormats - expect(audioCaps.supportedFormats !== undefined).assertTrue(); - console.info('audioCaps.supportedFormats: '+ audioCaps.supportedFormats); - - // check AudioCaps.supportedSampleRates - expect(audioCaps.supportedSampleRates !== undefined).assertTrue(); - console.info('audioCaps.supportedSampleRates: '+ audioCaps.supportedSampleRates); - - // check AudioCaps.supportedProfiles - expect(audioCaps.supportedProfiles !== undefined).assertTrue(); - console.info('audioCaps.supportedProfiles: '+ audioCaps.supportedProfiles); - - // check AudioCaps.supportedComplexity - expect(audioCaps.supportedComplexity !== undefined).assertTrue(); - console.info('supportedComplexity.min: '+ audioCaps.supportedComplexity.min); - console.info('supportedComplexity.max: '+ audioCaps.supportedComplexity.max); - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_ENUM_AVCodecType_0100 - * @tc.name : 003.AVCodecType - * @tc.desc : Test Enumerate AVCodecType - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_ENUM_AVCodecType_0100', 0, async function (done) { - expect(media.AVCodecType.AVCODEC_TYPE_VIDEO_ENCODER).assertEqual(0); - expect(media.AVCodecType.AVCODEC_TYPE_VIDEO_DECODER).assertEqual(1); - expect(media.AVCodecType.AVCODEC_TYPE_AUDIO_ENCODER).assertEqual(2); - expect(media.AVCodecType.AVCODEC_TYPE_AUDIO_DECODER).assertEqual(3); - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_ENUM_CodecMimeType_0100 - * @tc.name : 004.CodecMimeType - * @tc.desc : Test Enumerate CodecMimeType - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_ENUM_CodecMimeType_0100', 0, async function (done) { - expect(media.CodecMimeType.AUDIO_AAC).assertEqual('audio/mp4a-latm'); - expect(media.CodecMimeType.AUDIO_VORBIS).assertEqual('audio/vorbis'); - expect(media.CodecMimeType.AUDIO_FLAC).assertEqual('audio/flac'); - done(); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatCallbackTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatCallbackTest.test.js deleted file mode 100644 index 8f6460db4..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatCallbackTest.test.js +++ /dev/null @@ -1,912 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderFormatCallback', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH1 = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const AUDIOPATH2 = RESOURCEPATH + 'FLAC_48000_32_1.flac' - const AUDIOPATH3 = RESOURCEPATH + 'mp3.es'; - const AUDIOPATH4 = RESOURCEPATH + 'vorbis.es'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_format_callback_'; - let audioDecodeProcessor; - let readStreamSync; - let needGetMediaDes = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = []; - let ES_LENGTH = 0; - let samplerate = 44.1; - let isMp3 = false; - let isVorbis = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = null; - readStreamSync = undefined; - needGetMediaDes = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = []; - ES_LENGTH = 0; - samplerate = 44.1; - isMp3 = false; - isVorbis = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.log(e); - } - } - - function readFile(path) { - console.log('read file start execution'); - try{ - console.log('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.log(e); - } - } - - function getContent(buf, len) { - console.log("start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.log('lengthreal: ' + lengthreal); - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - inputobject.timeMs = timestamp; - inputobject.offset = 0; - if (frameCnt==1 && isVorbis) { - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 8; - } else if (isMp3) { - inputobject.length = ES[1]; - getContent(inputobject.data, ES[1]); - inputobject.flags = 0; - } else { - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - } - if (isMp3) { - timestamp += ES[1]/samplerate; - } else { - timestamp += ES[frameCnt]/samplerate; - } - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject, () => { - console.info('queueInput success'); - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.log("stop success"); - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.log("reset success"); - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioDecodeProcessor = null; - done(); - }) - }) - }) - } else { - writeFile(savepath, outputobject.data, outputobject.length); - console.log("write to file success"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject, () => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info("inputBufferAvailable"); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info("outputBufferAvailable"); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - console.log("get OutputMediaDescription success"); - console.log('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }) - } - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0100 - * @tc.name : 001.test aac format(createbymime) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0100', 0, async function (done) { - console.log("case test aac format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'aac_01.pcm'; - needGetMediaDes = true; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338]; - ES_LENGTH = 1000; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH1); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0101 - * @tc.name : 001.test aac format(createbyname) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0101', 0, async function (done) { - console.log("case test aac format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'aac_02.pcm'; - needGetMediaDes = true; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338]; - ES_LENGTH = 1000; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH1); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByName('avdec_aac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0200 - * @tc.name : 002.test flac format(createbymime) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0200', 0, async function (done) { - console.log("case test flac format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'flac_01.pcm'; - needGetMediaDes = true; - samplerate = 48; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, 2806, - 2796,2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, 2839, 2794, - 2770, 2763,2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, 2969, 3240, 3199, - 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, 2779, 2963, 2893, 2870, - 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, 2876, 3223, 3040, 3006, 3042, - 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, 3300, 3140, 3014, 2975, 2952, 2896, - 2897, 2842, 2929, 3567, 3929, 3485, 3082, 3625, 4953, 5239, 5094, 4993, 4821, 4431, - 5195, 5542, 5557, 4894, 4414, 5085, 5496, 5089, 4459, 4532, 4778, 5460, 5372, 5224, - 4395, 4701, 5512, 5304, 4798, 7128, 6534, 5704, 5562, 5539, 5675, 5780, 6058, 6194, - 6076, 5971, 5758, 5202, 4438, 3821, 4267, 5550, 4896, 3841, 5166, 4904, 4504, 5530, - 5354, 5047, 5695, 5422, 5168, 5338, 5154, 5385, 5322, 4934, 4512, 4001, 3793, 3624, - 3589, 3562, 4346, 5407, 5582, 5645, 5581, 5605, 5520, 5399, 5164, 4991, 4556, 4058, - 3662, 3757, 4627, 5183, 5061, 4114, 5840, 5051, 5126, 4573, 5269, 4437, 5021, 5508, - 5289, 5171, 5153, 5118, 5721, 5375, 4863, 6353, 5477, 5608, 5614, 5737, 5178, 4614, - 4671, 5204, 5027, 4977, 3922, 5904]; - ES_LENGTH = 200; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH2); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByMime('audio/flac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0201 - * @tc.name : 002.test flac format(createbyname) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0201', 0, async function (done) { - console.log("case test flac format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'flac_02.pcm'; - needGetMediaDes = true; - samplerate = 48; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, 2806, - 2796,2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, 2839, 2794, - 2770, 2763,2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, 2969, 3240, 3199, - 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, 2779, 2963, 2893, 2870, - 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, 2876, 3223, 3040, 3006, 3042, - 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, 3300, 3140, 3014, 2975, 2952, 2896, - 2897, 2842, 2929, 3567, 3929, 3485, 3082, 3625, 4953, 5239, 5094, 4993, 4821, 4431, - 5195, 5542, 5557, 4894, 4414, 5085, 5496, 5089, 4459, 4532, 4778, 5460, 5372, 5224, - 4395, 4701, 5512, 5304, 4798, 7128, 6534, 5704, 5562, 5539, 5675, 5780, 6058, 6194, - 6076, 5971, 5758, 5202, 4438, 3821, 4267, 5550, 4896, 3841, 5166, 4904, 4504, 5530, - 5354, 5047, 5695, 5422, 5168, 5338, 5154, 5385, 5322, 4934, 4512, 4001, 3793, 3624, - 3589, 3562, 4346, 5407, 5582, 5645, 5581, 5605, 5520, 5399, 5164, 4991, 4556, 4058, - 3662, 3757, 4627, 5183, 5061, 4114, 5840, 5051, 5126, 4573, 5269, 4437, 5021, 5508, - 5289, 5171, 5153, 5118, 5721, 5375, 4863, 6353, 5477, 5608, 5614, 5737, 5178, 4614, - 4671, 5204, 5027, 4977, 3922, 5904]; - ES_LENGTH = 200; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH2); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByName('avdec_flac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0300 - * @tc.name : 003.test mp3 format(createbymime) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0300', 0, async function (done) { - console.log("test mp3 format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'mp3_01.pcm'; - needGetMediaDes = true; - isMp3 = true; - isVorbis = false; - ES = [0, 1044]; - ES_LENGTH = 1000; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH3); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByMime('audio/mpeg', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0301 - * @tc.name : 003.test mp3 format(createbyname) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0301', 0, async function (done) { - console.log("test mp3 format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'mp3_02.pcm'; - needGetMediaDes = true; - isMp3 = true; - isVorbis = false; - ES = [0, 1044]; - ES_LENGTH = 1000; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH3); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByName('avdec_mp3', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0400 - * @tc.name : 004.test vorbis format(createbymime) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0400', 0, async function (done) { - console.log("test vorbis format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'vorbis_01.pcm'; - needGetMediaDes = true; - samplerate = 48; - isVorbis = true; - ES = [0, 3251, 33, 160, 162, 159, 148, 160, 160, 159, 167, 156, 162, 173, 135, 137, 133, - 126, 126, 130, 127, 133, 138, 132, 124, 129, 134, 136, 146, 135, 137, 144, 137, 128, - 124, 127, 129, 127, 130, 127, 134, 130, 135, 146, 142, 140, 134, 134, 128, 119, 122, - 122, 123, 121, 128, 125, 128, 122, 137, 141, 136, 135, 127, 128, 125, 128, 122, 126, - 132, 127, 127, 135, 143, 134, 148, 133, 131, 140, 143, 135, 140, 141, 135, 149, 27, - 30, 36, 32, 157, 155, 158, 154, 136, 150, 149, 142, 150, 142, 149, 139, 142, 146, 138, - 138, 144, 138, 139, 132, 120, 130, 134, 124, 127, 130, 130, 123, 133, 141, 137, 135, - 140, 147, 139, 141, 134, 131, 146, 139, 136, 136, 130, 143, 147, 144, 138, 145, 137, - 137, 138, 142, 148, 149, 138, 141, 148, 139, 139, 139, 134, 135, 131, 124, 131, 131, - 120, 121, 132, 128, 127, 130, 136, 129, 130, 123, 133, 132, 141, 147, 147, 139, 127, - 149, 157, 165, 154, 143, 153, 141, 157, 144, 146, 135, 142, 133, 134, 140, 142, 133, - 136, 133, 141, 143, 128, 127, 136, 144, 138, 141, 133, 127, 123, 138, 131, 126, 130, - 131, 135, 131, 137, 136, 125, 127, 126, 143, 142, 127, 134, 140, 144, 128, 125, 139, - 144, 135, 141, 123, 130, 127, 126, 140, 136, 140, 139, 140, 133, 132, 146, 142, 138, - 134, 130, 125, 130, 130, 129, 137, 133, 128, 130, 130, 132, 135, 126, 129, 142, 129, - 151, 150, 146, 130, 130, 144, 137, 145, 140, 126, 123, 128, 138, 136, 140, 137, 137, - 147, 146, 141, 137, 139, 117, 133, 140, 126, 137, 138, 143, 141, 141, 132, 128, 132, - 145, 148, 151, 160, 162, 154, 140, 147, 30, 28, 28, 26, 27, 27, 31, 33, 32, 145, 132, - 130, 124, 142, 140, 128, 124, 131, 127, 130, 128, 135, 125, 137, 137, 127, 128, 127, - 125, 127, 130, 124, 134, 137, 129, 127, 146, 136, 131, 124, 125, 130, 131, 135, 147, - 148, 151, 147, 143, 148, 145, 158, 142, 137, 129, 127, 156, 147, 143, 137, 135, 142, - 141, 140, 137, 136, 132, 134, 130, 124, 127, 130, 127, 126, 127, 129, 132, 134, 141, - 147, 136, 141, 141, 134, 126, 127, 136, 135, 134, 122, 130, 128, 140, 133, 124, 128, - 137, 128, 141, 135, 141, 147, 153, 151, 151, 154, 150, 147, 157, 153, 153, 153, 151, - 155, 154, 153, 150, 143, 157, 146, 150, 154, 152, 153, 28, 35, 33, 34, 37, 36, 30, 31, - 27, 37, 38, 36, 38, 37, 36, 39, 38, 36, 172, 172, 179, 178, 172, 171, 180, 173, 163, - 164, 159, 159, 155, 163, 184, 187, 176, 176, 184, 179, 174, 167, 165, 166, 160, 166, - 169, 169, 159, 165, 166, 168, 162, 180, 174, 186, 179, 180, 186, 187, 178, 156, 158, - 156, 161, 165, 163, 160, 169, 160, 160, 168, 161, 159, 167, 173, 177, 170, 172, 172, - 169, 157, 161, 155, 165, 164, 154, 161, 160, 31, 30, 28, 31, 31, 29, 38, 36, 40, 31, - 33, 37, 39, 179, 30, 28, 27, 30, 28, 30, 30, 37, 42, 39, 184, 163, 158, 172, 166, 161, - 160, 167, 174, 175, 183, 176, 192, 176, 170, 179, 173, 164, 156, 160, 162, 152, 155, - 157, 174, 176, 184, 173, 180, 177, 182, 190, 170, 167, 154, 156, 171, 169, 172, 177, - 190, 192, 186, 188, 192, 192, 176, 179, 175, 191, 174, 197, 194, 203, 198, 190, 185, - 202, 179, 169, 179, 184, 193, 185, 185, 181, 197, 188, 189, 188, 189, 193, 197, 198, - 203, 188, 189, 198, 190, 196, 191, 191, 197, 202, 182, 178, 186, 194, 192, 186, 187, - 188, 186, 179, 179, 168, 165, 173, 165, 160, 161, 145, 162, 149, 155, 154, 145, 154, - 152, 152, 163, 174, 175, 170, 181, 177, 162, 167, 164, 162, 147, 147, 157, 159, 27, - 28, 28, 36, 36, 37, 35, 35, 35, 35, 37, 37, 35, 35, 36, 171, 40, 40, 176, 178, 171, - 174, 165, 161, 157, 160, 154, 167, 163, 174, 172, 155, 158, 165, 166, 181, 190, 160, - 158, 160, 30, 39, 36, 174, 157, 180, 174, 167, 178, 177, 171, 175, 173, 166, 28, 28, - 28, 29, 30, 34, 35, 36, 29, 36, 37, 38, 32, 29, 41, 38, 38, 35, 34, 34, 36, 34, 35, - 30, 30, 31, 31, 28, 30, 31, 36, 36, 36, 40, 38, 44, 41, 34, 38, 38, 38, 39, 184, 157, - 155, 167, 178]; - ES_LENGTH = 757; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH4); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByMime('audio/vorbis', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0401 - * @tc.name : 004.test vorbis format(createbyname) - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_CALLBACK_01_0401', 0, async function (done) { - console.log("test vorbis format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'vorbis_02.pcm'; - needGetMediaDes = true; - samplerate = 48; - isVorbis = true; - ES = [0, 3251, 33, 160, 162, 159, 148, 160, 160, 159, 167, 156, 162, 173, 135, 137, 133, - 126, 126, 130, 127, 133, 138, 132, 124, 129, 134, 136, 146, 135, 137, 144, 137, 128, - 124, 127, 129, 127, 130, 127, 134, 130, 135, 146, 142, 140, 134, 134, 128, 119, 122, - 122, 123, 121, 128, 125, 128, 122, 137, 141, 136, 135, 127, 128, 125, 128, 122, 126, - 132, 127, 127, 135, 143, 134, 148, 133, 131, 140, 143, 135, 140, 141, 135, 149, 27, - 30, 36, 32, 157, 155, 158, 154, 136, 150, 149, 142, 150, 142, 149, 139, 142, 146, 138, - 138, 144, 138, 139, 132, 120, 130, 134, 124, 127, 130, 130, 123, 133, 141, 137, 135, - 140, 147, 139, 141, 134, 131, 146, 139, 136, 136, 130, 143, 147, 144, 138, 145, 137, - 137, 138, 142, 148, 149, 138, 141, 148, 139, 139, 139, 134, 135, 131, 124, 131, 131, - 120, 121, 132, 128, 127, 130, 136, 129, 130, 123, 133, 132, 141, 147, 147, 139, 127, - 149, 157, 165, 154, 143, 153, 141, 157, 144, 146, 135, 142, 133, 134, 140, 142, 133, - 136, 133, 141, 143, 128, 127, 136, 144, 138, 141, 133, 127, 123, 138, 131, 126, 130, - 131, 135, 131, 137, 136, 125, 127, 126, 143, 142, 127, 134, 140, 144, 128, 125, 139, - 144, 135, 141, 123, 130, 127, 126, 140, 136, 140, 139, 140, 133, 132, 146, 142, 138, - 134, 130, 125, 130, 130, 129, 137, 133, 128, 130, 130, 132, 135, 126, 129, 142, 129, - 151, 150, 146, 130, 130, 144, 137, 145, 140, 126, 123, 128, 138, 136, 140, 137, 137, - 147, 146, 141, 137, 139, 117, 133, 140, 126, 137, 138, 143, 141, 141, 132, 128, 132, - 145, 148, 151, 160, 162, 154, 140, 147, 30, 28, 28, 26, 27, 27, 31, 33, 32, 145, 132, - 130, 124, 142, 140, 128, 124, 131, 127, 130, 128, 135, 125, 137, 137, 127, 128, 127, - 125, 127, 130, 124, 134, 137, 129, 127, 146, 136, 131, 124, 125, 130, 131, 135, 147, - 148, 151, 147, 143, 148, 145, 158, 142, 137, 129, 127, 156, 147, 143, 137, 135, 142, - 141, 140, 137, 136, 132, 134, 130, 124, 127, 130, 127, 126, 127, 129, 132, 134, 141, - 147, 136, 141, 141, 134, 126, 127, 136, 135, 134, 122, 130, 128, 140, 133, 124, 128, - 137, 128, 141, 135, 141, 147, 153, 151, 151, 154, 150, 147, 157, 153, 153, 153, 151, - 155, 154, 153, 150, 143, 157, 146, 150, 154, 152, 153, 28, 35, 33, 34, 37, 36, 30, 31, - 27, 37, 38, 36, 38, 37, 36, 39, 38, 36, 172, 172, 179, 178, 172, 171, 180, 173, 163, - 164, 159, 159, 155, 163, 184, 187, 176, 176, 184, 179, 174, 167, 165, 166, 160, 166, - 169, 169, 159, 165, 166, 168, 162, 180, 174, 186, 179, 180, 186, 187, 178, 156, 158, - 156, 161, 165, 163, 160, 169, 160, 160, 168, 161, 159, 167, 173, 177, 170, 172, 172, - 169, 157, 161, 155, 165, 164, 154, 161, 160, 31, 30, 28, 31, 31, 29, 38, 36, 40, 31, - 33, 37, 39, 179, 30, 28, 27, 30, 28, 30, 30, 37, 42, 39, 184, 163, 158, 172, 166, 161, - 160, 167, 174, 175, 183, 176, 192, 176, 170, 179, 173, 164, 156, 160, 162, 152, 155, - 157, 174, 176, 184, 173, 180, 177, 182, 190, 170, 167, 154, 156, 171, 169, 172, 177, - 190, 192, 186, 188, 192, 192, 176, 179, 175, 191, 174, 197, 194, 203, 198, 190, 185, - 202, 179, 169, 179, 184, 193, 185, 185, 181, 197, 188, 189, 188, 189, 193, 197, 198, - 203, 188, 189, 198, 190, 196, 191, 191, 197, 202, 182, 178, 186, 194, 192, 186, 187, - 188, 186, 179, 179, 168, 165, 173, 165, 160, 161, 145, 162, 149, 155, 154, 145, 154, - 152, 152, 163, 174, 175, 170, 181, 177, 162, 167, 164, 162, 147, 147, 157, 159, 27, - 28, 28, 36, 36, 37, 35, 35, 35, 35, 37, 37, 35, 35, 36, 171, 40, 40, 176, 178, 171, - 174, 165, 161, 157, 160, 154, 167, 163, 174, 172, 155, 158, 165, 166, 181, 190, 160, - 158, 160, 30, 39, 36, 174, 157, 180, 174, 167, 178, 177, 171, 175, 173, 166, 28, 28, - 28, 29, 30, 34, 35, 36, 29, 36, 37, 38, 32, 29, 41, 38, 38, 35, 34, 34, 36, 34, 35, - 30, 30, 31, 31, 28, 30, 31, 36, 36, 36, 40, 38, 44, 41, 34, 38, 38, 38, 39, 184, 157, - 155, 167, 178]; - ES_LENGTH = 757; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.log("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH4); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByName('avdec_vorbis', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatPromiseTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatPromiseTest.test.js deleted file mode 100644 index 1435aa48d..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFormatPromiseTest.test.js +++ /dev/null @@ -1,767 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderFormatPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH1 = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const AUDIOPATH2 = RESOURCEPATH + 'FLAC_48000_32_1.flac' - const AUDIOPATH3 = RESOURCEPATH + 'mp3.es'; - const AUDIOPATH4 = RESOURCEPATH + 'vorbis.es'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_format_promise_'; - let audioDecodeProcessor; - let readStreamSync; - let needGetMediaDes = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = []; - let ES_LENGTH = 0; - let samplerate = 44.1; - let isMp3 = false; - let isVorbis = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = null; - readStreamSync = undefined; - needGetMediaDes = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = []; - ES_LENGTH = 0; - samplerate = 44.1; - isMp3 = false; - isVorbis = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.log(e) - } - } - - function readFile(path) { - console.log('read file start execution'); - try{ - console.log('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.log(e); - } - } - - function getContent(buf, len) { - console.log("start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.log('lengthreal: ' + lengthreal); - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - inputobject.timeMs = timestamp; - inputobject.offset = 0; - if (frameCnt==1 && isVorbis) { - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 8; - } else if (isMp3) { - inputobject.length = ES[1]; - getContent(inputobject.data, ES[1]); - inputobject.flags = 0; - } else { - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - } - if (isMp3) { - timestamp += ES[1]/samplerate; - } else { - timestamp += ES[frameCnt]/samplerate; - } - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject).then(() => { - console.info("queueInput success") - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - await audioDecodeProcessor.stop().then(() => { - console.log("stop success"); - }, failCallback).catch(failCatch); - inputQueue = []; - outputQueue = []; - await audioDecodeProcessor.reset().then(() => { - console.log("reset success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.release().then(() => { - console.info('release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - done(); - } - else{ - writeFile(savepath, outputobject.data, outputobject.length); - console.log("write to file success"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info("inputBufferAvailable"); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info("outputBufferAvailable"); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.log("get OutputMediaDescription success"); - console.log('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }, failCallback).catch(failCatch);} - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0100 - * @tc.name : 001.test aac format(createbymime) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0100', 0, async function (done) { - console.log("case test aac format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'aac_01.pcm'; - needGetMediaDes = true; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338]; - ES_LENGTH = 1000; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH1); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0101 - * @tc.name : 001.test aac format(createbyname) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0101', 0, async function (done) { - console.log("case test aac format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'aac_02.pcm'; - needGetMediaDes = true; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338]; - ES_LENGTH = 1000; - await media.createAudioDecoderByName('avdec_aac').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH1); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0200 - * @tc.name : 002.test flac format(createbymime) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0200', 0, async function (done) { - console.log("case test flac format"); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'flac_01.pcm'; - needGetMediaDes = true; - samplerate = 48; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, 2806, - 2796,2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, 2839, 2794, - 2770, 2763,2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, 2969, 3240, 3199, - 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, 2779, 2963, 2893, 2870, - 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, 2876, 3223, 3040, 3006, 3042, - 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, 3300, 3140, 3014, 2975, 2952, 2896, - 2897, 2842, 2929, 3567, 3929, 3485, 3082, 3625, 4953, 5239, 5094, 4993, 4821, 4431, - 5195, 5542, 5557, 4894, 4414, 5085, 5496, 5089, 4459, 4532, 4778, 5460, 5372, 5224, - 4395, 4701, 5512, 5304, 4798, 7128, 6534, 5704, 5562, 5539, 5675, 5780, 6058, 6194, - 6076, 5971, 5758, 5202, 4438, 3821, 4267, 5550, 4896, 3841, 5166, 4904, 4504, 5530, - 5354, 5047, 5695, 5422, 5168, 5338, 5154, 5385, 5322, 4934, 4512, 4001, 3793, 3624, - 3589, 3562, 4346, 5407, 5582, 5645, 5581, 5605, 5520, 5399, 5164, 4991, 4556, 4058, - 3662, 3757, 4627, 5183, 5061, 4114, 5840, 5051, 5126, 4573, 5269, 4437, 5021, 5508, - 5289, 5171, 5153, 5118, 5721, 5375, 4863, 6353, 5477, 5608, 5614, 5737, 5178, 4614, - 4671, 5204, 5027, 4977, 3922, 5904]; - ES_LENGTH = 200; - await media.createAudioDecoderByMime('audio/flac').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - console.log("start configure"); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH2); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0201 - * @tc.name : 002.test flac format(createbyname) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0201', 0, async function (done) { - console.log("case test flac format"); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'flac_02.pcm'; - needGetMediaDes = true; - samplerate = 48; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, 2806, - 2796,2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, 2839, 2794, - 2770, 2763,2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, 2969, 3240, 3199, - 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, 2779, 2963, 2893, 2870, - 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, 2876, 3223, 3040, 3006, 3042, - 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, 3300, 3140, 3014, 2975, 2952, 2896, - 2897, 2842, 2929, 3567, 3929, 3485, 3082, 3625, 4953, 5239, 5094, 4993, 4821, 4431, - 5195, 5542, 5557, 4894, 4414, 5085, 5496, 5089, 4459, 4532, 4778, 5460, 5372, 5224, - 4395, 4701, 5512, 5304, 4798, 7128, 6534, 5704, 5562, 5539, 5675, 5780, 6058, 6194, - 6076, 5971, 5758, 5202, 4438, 3821, 4267, 5550, 4896, 3841, 5166, 4904, 4504, 5530, - 5354, 5047, 5695, 5422, 5168, 5338, 5154, 5385, 5322, 4934, 4512, 4001, 3793, 3624, - 3589, 3562, 4346, 5407, 5582, 5645, 5581, 5605, 5520, 5399, 5164, 4991, 4556, 4058, - 3662, 3757, 4627, 5183, 5061, 4114, 5840, 5051, 5126, 4573, 5269, 4437, 5021, 5508, - 5289, 5171, 5153, 5118, 5721, 5375, 4863, 6353, 5477, 5608, 5614, 5737, 5178, 4614, - 4671, 5204, 5027, 4977, 3922, 5904]; - ES_LENGTH = 200; - await media.createAudioDecoderByName('avdec_flac').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - console.log("start configure"); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH2); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0300 - * @tc.name : 003.test mp3 format(createbymime) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0300', 0, async function (done) { - console.log("case test mp3 format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'mp3_01.pcm'; - needGetMediaDes = true; - isMp3 = true; - ES = [0, 1044]; - ES_LENGTH = 1000; - await media.createAudioDecoderByMime('audio/mpeg').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH3); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0301 - * @tc.name : 003.test mp3 format(createbyname) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0301', 0, async function (done) { - console.log("case test mp3 format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'mp3_02.pcm'; - needGetMediaDes = true; - isMp3 = true; - ES = [0, 1044]; - ES_LENGTH = 1000; - await media.createAudioDecoderByName('avdec_mp3').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH3); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0400 - * @tc.name : 004.test vorbis format(createbymime) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0400', 0, async function (done) { - console.log("case test vorbis format"); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'vorbis_01.pcm'; - needGetMediaDes = true; - samplerate = 48; - isVorbis = true; - ES = [0, 3251, 33, 160, 162, 159, 148, 160, 160, 159, 167, 156, 162, 173, 135, 137, 133, - 126, 126, 130, 127, 133, 138, 132, 124, 129, 134, 136, 146, 135, 137, 144, 137, 128, - 124, 127, 129, 127, 130, 127, 134, 130, 135, 146, 142, 140, 134, 134, 128, 119, 122, - 122, 123, 121, 128, 125, 128, 122, 137, 141, 136, 135, 127, 128, 125, 128, 122, 126, - 132, 127, 127, 135, 143, 134, 148, 133, 131, 140, 143, 135, 140, 141, 135, 149, 27, - 30, 36, 32, 157, 155, 158, 154, 136, 150, 149, 142, 150, 142, 149, 139, 142, 146, 138, - 138, 144, 138, 139, 132, 120, 130, 134, 124, 127, 130, 130, 123, 133, 141, 137, 135, - 140, 147, 139, 141, 134, 131, 146, 139, 136, 136, 130, 143, 147, 144, 138, 145, 137, - 137, 138, 142, 148, 149, 138, 141, 148, 139, 139, 139, 134, 135, 131, 124, 131, 131, - 120, 121, 132, 128, 127, 130, 136, 129, 130, 123, 133, 132, 141, 147, 147, 139, 127, - 149, 157, 165, 154, 143, 153, 141, 157, 144, 146, 135, 142, 133, 134, 140, 142, 133, - 136, 133, 141, 143, 128, 127, 136, 144, 138, 141, 133, 127, 123, 138, 131, 126, 130, - 131, 135, 131, 137, 136, 125, 127, 126, 143, 142, 127, 134, 140, 144, 128, 125, 139, - 144, 135, 141, 123, 130, 127, 126, 140, 136, 140, 139, 140, 133, 132, 146, 142, 138, - 134, 130, 125, 130, 130, 129, 137, 133, 128, 130, 130, 132, 135, 126, 129, 142, 129, - 151, 150, 146, 130, 130, 144, 137, 145, 140, 126, 123, 128, 138, 136, 140, 137, 137, - 147, 146, 141, 137, 139, 117, 133, 140, 126, 137, 138, 143, 141, 141, 132, 128, 132, - 145, 148, 151, 160, 162, 154, 140, 147, 30, 28, 28, 26, 27, 27, 31, 33, 32, 145, 132, - 130, 124, 142, 140, 128, 124, 131, 127, 130, 128, 135, 125, 137, 137, 127, 128, 127, - 125, 127, 130, 124, 134, 137, 129, 127, 146, 136, 131, 124, 125, 130, 131, 135, 147, - 148, 151, 147, 143, 148, 145, 158, 142, 137, 129, 127, 156, 147, 143, 137, 135, 142, - 141, 140, 137, 136, 132, 134, 130, 124, 127, 130, 127, 126, 127, 129, 132, 134, 141, - 147, 136, 141, 141, 134, 126, 127, 136, 135, 134, 122, 130, 128, 140, 133, 124, 128, - 137, 128, 141, 135, 141, 147, 153, 151, 151, 154, 150, 147, 157, 153, 153, 153, 151, - 155, 154, 153, 150, 143, 157, 146, 150, 154, 152, 153, 28, 35, 33, 34, 37, 36, 30, 31, - 27, 37, 38, 36, 38, 37, 36, 39, 38, 36, 172, 172, 179, 178, 172, 171, 180, 173, 163, - 164, 159, 159, 155, 163, 184, 187, 176, 176, 184, 179, 174, 167, 165, 166, 160, 166, - 169, 169, 159, 165, 166, 168, 162, 180, 174, 186, 179, 180, 186, 187, 178, 156, 158, - 156, 161, 165, 163, 160, 169, 160, 160, 168, 161, 159, 167, 173, 177, 170, 172, 172, - 169, 157, 161, 155, 165, 164, 154, 161, 160, 31, 30, 28, 31, 31, 29, 38, 36, 40, 31, - 33, 37, 39, 179, 30, 28, 27, 30, 28, 30, 30, 37, 42, 39, 184, 163, 158, 172, 166, 161, - 160, 167, 174, 175, 183, 176, 192, 176, 170, 179, 173, 164, 156, 160, 162, 152, 155, - 157, 174, 176, 184, 173, 180, 177, 182, 190, 170, 167, 154, 156, 171, 169, 172, 177, - 190, 192, 186, 188, 192, 192, 176, 179, 175, 191, 174, 197, 194, 203, 198, 190, 185, - 202, 179, 169, 179, 184, 193, 185, 185, 181, 197, 188, 189, 188, 189, 193, 197, 198, - 203, 188, 189, 198, 190, 196, 191, 191, 197, 202, 182, 178, 186, 194, 192, 186, 187, - 188, 186, 179, 179, 168, 165, 173, 165, 160, 161, 145, 162, 149, 155, 154, 145, 154, - 152, 152, 163, 174, 175, 170, 181, 177, 162, 167, 164, 162, 147, 147, 157, 159, 27, - 28, 28, 36, 36, 37, 35, 35, 35, 35, 37, 37, 35, 35, 36, 171, 40, 40, 176, 178, 171, - 174, 165, 161, 157, 160, 154, 167, 163, 174, 172, 155, 158, 165, 166, 181, 190, 160, - 158, 160, 30, 39, 36, 174, 157, 180, 174, 167, 178, 177, 171, 175, 173, 166, 28, 28, - 28, 29, 30, 34, 35, 36, 29, 36, 37, 38, 32, 29, 41, 38, 38, 35, 34, 34, 36, 34, 35, - 30, 30, 31, 31, 28, 30, 31, 36, 36, 36, 40, 38, 44, 41, 34, 38, 38, 38, 39, 184, 157, - 155, 167, 178]; - ES_LENGTH = 757; - await media.createAudioDecoderByMime('audio/vorbis').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH4); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0401 - * @tc.name : 004.test vorbis format(createbyname) - * @tc.desc : decode format test - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FORMAT_PROMISE_01_0401', 0, async function (done) { - console.log("case test vorbis format"); - let mediaDescription = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + 'vorbis_02.pcm'; - needGetMediaDes = true; - samplerate = 48; - isVorbis = true; - ES = [0, 3251, 33, 160, 162, 159, 148, 160, 160, 159, 167, 156, 162, 173, 135, 137, 133, - 126, 126, 130, 127, 133, 138, 132, 124, 129, 134, 136, 146, 135, 137, 144, 137, 128, - 124, 127, 129, 127, 130, 127, 134, 130, 135, 146, 142, 140, 134, 134, 128, 119, 122, - 122, 123, 121, 128, 125, 128, 122, 137, 141, 136, 135, 127, 128, 125, 128, 122, 126, - 132, 127, 127, 135, 143, 134, 148, 133, 131, 140, 143, 135, 140, 141, 135, 149, 27, - 30, 36, 32, 157, 155, 158, 154, 136, 150, 149, 142, 150, 142, 149, 139, 142, 146, 138, - 138, 144, 138, 139, 132, 120, 130, 134, 124, 127, 130, 130, 123, 133, 141, 137, 135, - 140, 147, 139, 141, 134, 131, 146, 139, 136, 136, 130, 143, 147, 144, 138, 145, 137, - 137, 138, 142, 148, 149, 138, 141, 148, 139, 139, 139, 134, 135, 131, 124, 131, 131, - 120, 121, 132, 128, 127, 130, 136, 129, 130, 123, 133, 132, 141, 147, 147, 139, 127, - 149, 157, 165, 154, 143, 153, 141, 157, 144, 146, 135, 142, 133, 134, 140, 142, 133, - 136, 133, 141, 143, 128, 127, 136, 144, 138, 141, 133, 127, 123, 138, 131, 126, 130, - 131, 135, 131, 137, 136, 125, 127, 126, 143, 142, 127, 134, 140, 144, 128, 125, 139, - 144, 135, 141, 123, 130, 127, 126, 140, 136, 140, 139, 140, 133, 132, 146, 142, 138, - 134, 130, 125, 130, 130, 129, 137, 133, 128, 130, 130, 132, 135, 126, 129, 142, 129, - 151, 150, 146, 130, 130, 144, 137, 145, 140, 126, 123, 128, 138, 136, 140, 137, 137, - 147, 146, 141, 137, 139, 117, 133, 140, 126, 137, 138, 143, 141, 141, 132, 128, 132, - 145, 148, 151, 160, 162, 154, 140, 147, 30, 28, 28, 26, 27, 27, 31, 33, 32, 145, 132, - 130, 124, 142, 140, 128, 124, 131, 127, 130, 128, 135, 125, 137, 137, 127, 128, 127, - 125, 127, 130, 124, 134, 137, 129, 127, 146, 136, 131, 124, 125, 130, 131, 135, 147, - 148, 151, 147, 143, 148, 145, 158, 142, 137, 129, 127, 156, 147, 143, 137, 135, 142, - 141, 140, 137, 136, 132, 134, 130, 124, 127, 130, 127, 126, 127, 129, 132, 134, 141, - 147, 136, 141, 141, 134, 126, 127, 136, 135, 134, 122, 130, 128, 140, 133, 124, 128, - 137, 128, 141, 135, 141, 147, 153, 151, 151, 154, 150, 147, 157, 153, 153, 153, 151, - 155, 154, 153, 150, 143, 157, 146, 150, 154, 152, 153, 28, 35, 33, 34, 37, 36, 30, 31, - 27, 37, 38, 36, 38, 37, 36, 39, 38, 36, 172, 172, 179, 178, 172, 171, 180, 173, 163, - 164, 159, 159, 155, 163, 184, 187, 176, 176, 184, 179, 174, 167, 165, 166, 160, 166, - 169, 169, 159, 165, 166, 168, 162, 180, 174, 186, 179, 180, 186, 187, 178, 156, 158, - 156, 161, 165, 163, 160, 169, 160, 160, 168, 161, 159, 167, 173, 177, 170, 172, 172, - 169, 157, 161, 155, 165, 164, 154, 161, 160, 31, 30, 28, 31, 31, 29, 38, 36, 40, 31, - 33, 37, 39, 179, 30, 28, 27, 30, 28, 30, 30, 37, 42, 39, 184, 163, 158, 172, 166, 161, - 160, 167, 174, 175, 183, 176, 192, 176, 170, 179, 173, 164, 156, 160, 162, 152, 155, - 157, 174, 176, 184, 173, 180, 177, 182, 190, 170, 167, 154, 156, 171, 169, 172, 177, - 190, 192, 186, 188, 192, 192, 176, 179, 175, 191, 174, 197, 194, 203, 198, 190, 185, - 202, 179, 169, 179, 184, 193, 185, 185, 181, 197, 188, 189, 188, 189, 193, 197, 198, - 203, 188, 189, 198, 190, 196, 191, 191, 197, 202, 182, 178, 186, 194, 192, 186, 187, - 188, 186, 179, 179, 168, 165, 173, 165, 160, 161, 145, 162, 149, 155, 154, 145, 154, - 152, 152, 163, 174, 175, 170, 181, 177, 162, 167, 164, 162, 147, 147, 157, 159, 27, - 28, 28, 36, 36, 37, 35, 35, 35, 35, 37, 37, 35, 35, 36, 171, 40, 40, 176, 178, 171, - 174, 165, 161, 157, 160, 154, 167, 163, 174, 172, 155, 158, 165, 166, 181, 190, 160, - 158, 160, 30, 39, 36, 174, 157, 180, 174, 167, 178, 177, 171, 175, 173, 166, 28, 28, - 28, 29, 30, 34, 35, 36, 29, 36, 37, 38, 32, 29, 41, 38, 38, 35, 34, 34, 36, 34, 35, - 30, 30, 31, 31, 28, 30, 31, 36, 36, 36, 40, 38, 44, 41, 34, 38, 38, 38, 39, 184, 157, - 155, 167, 178]; - ES_LENGTH = 757; - await media.createAudioDecoderByName('avdec_vorbis').then((processor) => { - console.log("create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.log("get AudioDecoderCaps success"); - console.log("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.log("configure success"); - readFile(AUDIOPATH4); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.log("prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.log("start success"); - }, failCallback).catch(failCatch); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncCallbackTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncCallbackTest.test.js deleted file mode 100644 index 926ac674e..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncCallbackTest.test.js +++ /dev/null @@ -1,1084 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderFuncCallback', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const AUDIOPATH2 = RESOURCEPATH + 'AAC_16000_1.aac'; - const AUDIOPATH3 = RESOURCEPATH + 'FLAC_48000_32_1.flac'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_func_callback_'; - let audioDecodeProcessor; - let readStreamSync; - let eosframenum = 0; - let samplerate = 44.1; - let workdoneAtEOS = false; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let needGetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = null; - readStreamSync = undefined; - eosframenum = 0; - samplerate = 44.1; - workdoneAtEOS = false; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - ES_LENGTH = 1500; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - function resetParam(){ - readStreamSync = undefined; - eosframenum = 0; - samplerate = 44.1; - workdoneAtEOS = false; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeFile(path, buf, len){ - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - }catch(e){ - console.info(e) - } - } - - function readFile(path){ - console.info('read file start execution'); - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - }catch(e){ - console.info(e); - } - } - - function getContent(buf, len){ - console.info("start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - async function stopWork() { - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success") - }) - } - - async function resetWork() { - resetParam(); - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info("case reset success"); - if (needrelease) { - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioDecodeProcessor = null; - }) - } - }) - } - - async function flushWork() { - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }) - } - - async function doneWork(done) { - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success"); - resetParam(); - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.log("case reset success"); - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioDecodeProcessor = null; - done(); - }) - }) - }) - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function enqueueAllInputs(queue){ - while (queue.length > 0 && !sawInputEOS){ - let inputobject = queue.shift(); - console.info("frameCnt:" + frameCnt); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1){ - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } - else{ - console.info("read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - timestamp += ES[frameCnt]/samplerate; - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject, () => { - console.info('queueInput success'); - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (stopAtEOS) { - await stopWork(); - } else if (resetAtEOS) { - await resetWork(); - } else if (flushAtEOS) { - await flushWork(); - } else if (workdoneAtEOS) { - await doneWork(done); - } else { - console.info("saw output EOS"); - } - } - else{ - writeFile(savepath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject, () => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needGetMediaDes){ - audioDecodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - expect(err).assertUndefined(); - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }); - } - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_00_0100 - * @tc.name : 000.test set EOS after last frame and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_00_0100', 0, async function (done) { - console.info("case test set EOS after last frame and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - workdoneAtEOS = true; - needGetMediaDes = true; - let savepath = BASIC_PATH + '0000.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - eventEmitter.on('createAudioDecoder', () => { - media.createAudioDecoderByName('avdec_aac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }); - media.getMediaCapability((err, mediaCaps) => { - expect(err).assertUndefined(); - console.info('getMediaCapability success'); - if (typeof (mediaCaps) != 'undefined') { - mediaCaps.getAudioDecoderCaps((err, audioCapsArray) => { - expect(err).assertUndefined(); - console.info('getAudioDecoderCaps success'); - if (typeof (audioCapsArray) != 'undefined') { - console.info('get first audioCaps'+ audioCapsArray[0]); - console.info('codecInfo: '+ audioCapsArray[0].codecInfo); - console.info('supportedBitrate: '+ audioCapsArray[0].supportedBitrate); - console.info('supportedBitrate.min: '+ audioCapsArray[0].supportedBitrate.min); - } else { - console.info('audioCaps is not defined'); - } - }) - } else { - console.info('mediaCaps is not defined'); - } - eventEmitter.emit('createAudioDecoder'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0100 - * @tc.name : 001.test set EOS manually before last frame and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0100', 0, async function (done) { - console.info("case test set EOS manually before last frame and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - eosframenum = 500; - workdoneAtEOS = true; - let savepath = BASIC_PATH + '0100.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.getMediaCapability((err, mediaCaps) => { - expect(err).assertUndefined(); - console.info(`case getMediaCapability 1`); - mediaCaps.getAudioDecoderCaps((err, audioCaps) => { - expect(err).assertUndefined(); - console.info('getAudioDecoderCaps success'); - if (typeof (audioCaps) != 'undefined') { - console.info("case audioCaps " + audioCaps); - } else { - console.info("case audioCaps is not defined"); - } - }) - }) - media.createAudioDecoderByName('avdec_aac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0200 - * @tc.name : 002.test flush at running state - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0200', 0, async function (done) { - console.info("case test flush at running state"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - workdoneAtEOS = true; - let savepath = BASIC_PATH + '0200.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - setTimeout(() => {eventEmitter.emit('flush')},2000) - }) - }); - eventEmitter.on('flush', () => { - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info(`case flush after 2s`); - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0300 - * @tc.name : 003. test flush at EOS state - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0300', 0, async function (done) { - console.info("case test flush at EOS state"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - eosframenum = 200; - flushAtEOS = true; - let savepath = BASIC_PATH + '0300.pcm'; - - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0400 - * @tc.name : 004. test stop at running state and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0400', 0, async function (done) { - console.info("case test stop at running state and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0400.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - eventEmitter.emit('stop'); - }) - }); - eventEmitter.on('stop', () => { - sleep(5000).then(() => { - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`case stop 1`); - eventEmitter.emit('reset'); - }) - }) - }); - eventEmitter.on('reset', () => { - resetParam(); - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info(`case reset 1`); - eventEmitter.emit('release'); - }) - }); - eventEmitter.on('release', () => { - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info(`case release 1`); - audioDecodeProcessor = null; - done(); - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0500 - * @tc.name : 005. test stop and restart - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0500', 0, async function (done) { - console.info("case test start - stop - restart"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - eosframenum = 200; - let savepath = BASIC_PATH + '0500.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - eventEmitter.emit('stop'); - }) - }); - eventEmitter.on('stop', () => { - sleep(5000).then(() => { - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`stop after 5s`); - resetParam(); - readFile(AUDIOPATH); - eventEmitter.emit('restart'); - }) - }) - }); - eventEmitter.on('restart', () => { - sleep(2000).then(() => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`restart after 2s`); - workdoneAtEOS=true; - enqueueAllInputs(inputQueue); - }) - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0600 - * @tc.name : 006. test reconfigure for new file with the same format - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0600', 0, async function (done) { - console.info("case test reconfigure codec for new file with the same format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - eosframenum = 200; - resetAtEOS = true; - let savepath = BASIC_PATH + '0600.pcm'; - let mediaDescription2 = { - "channel_count": 1, - "sample_rate": 16000, - "audio_sample_format": 1, - } - let hasreconfigured = false; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - if (!hasreconfigured){ - eventEmitter.emit('reconfigure', mediaDescription2); - } - }) - }); - eventEmitter.on('reconfigure', (mediaDescription2) => { - sleep(10000).then(() => { - audioDecodeProcessor.configure(mediaDescription2, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 2`); - resetParam(); - console.info('resetParam success, resetAtEOS IS :' + resetAtEOS) - readFile(AUDIOPATH2) - savepath = BASIC_PATH + '0601.pcm'; - workdoneAtEOS = true; - ES = [0, 239, 302, 309, 330, 474, 684, 699, 683, 674, 647, 649, 638, 644, 640, - 639, 650, 702, 713, 718, 707, 707, 683, 670, 674, 699, 654, 650, 715, 770, - 764, 736, 697, 664, 643, 649, 704, 730, 720, 710, 689, 670, 673, 653, 635, - 643, 638, 653, 658, 683, 683, 705, 690, 681, 648, 659, 743, 681, 706, 707, - 718, 714, 746, 725, 741, 709, 675, 675, 751, 698, 736, 738, 711, 702, 691, - 668, 668, 650, 661, 678, 694, 719, 685, 700, 657, 671, 668, 701, 689, 685, - 682, 668, 696, 690, 683, 739, 704, 667, 694, 716, 757, 714, 701, 664, 619, - 609, 591, 644, 573, 572, 605, 595, 597, 529, 581, 578, 586, 537, 577, 535, - 572, 570, 534, 547, 581, 530, 591, 521, 556, 570, 557, 541, 506, 572, 579, - 502, 516, 582, 540, 584, 548, 555, 539, 578, 588, 541, 539, 526, 575, 535, - 571, 525, 569, 560, 584, 551, 574, 572, 537, 550, 582, 512, 559, 593, 601, - 594, 546, 560, 567, 547, 529, 576, 577, 556, 551, 530, 542, 575, 510, 559, - 613, 628, 511, 566, 515, 539, 594, 536, 565, 551, 533, 613, 557, 523, 574, - 582, 616, 610, 573, 509, 535]; - ES_LENGTH = 200; - samplerate = 16; - hasreconfigured = true; - eventEmitter.emit('prepare'); - }) - }) - }); - media.createAudioDecoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0700 - * @tc.name : 007. test reconfigure for new file with different formats - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_CALLBACK_01_0700', 0, async function (done) { - console.info("case test reconfigure codec for new file with different format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let mediaDescription2 = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let hasrecreate = false; - eosframenum = 200; - resetAtEOS = true; - needrelease = true; - let savepath = BASIC_PATH + '0700.pcm'; - eventEmitter.on('getAudioDecoderCaps', () => { - audioDecodeProcessor.getAudioDecoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioDecoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - if (!hasrecreate){ - eventEmitter.emit('recreate'); - } - }) - }); - eventEmitter.on('recreate', () => { - sleep(10000).then(() => { - media.createAudioDecoderByMime('audio/flac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder flac`); - audioDecodeProcessor = processor; - hasrecreate = true; - eventEmitter.emit('reconfigure', mediaDescription2); - }) - }) - }); - eventEmitter.on('reconfigure', (mediaDescription2) => { - audioDecodeProcessor.configure(mediaDescription2, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 2`); - resetParam(); - readFile(AUDIOPATH3) - savepath = BASIC_PATH + '0701.pcm'; - workdoneAtEOS = true; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, - 2806, 2796, 2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, - 2839, 2794, 2770, 2763, 2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, - 2969, 3240, 3199, 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, - 2779, 2963, 2893, 2870, 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, - 2876, 3223, 3040, 3006, 3042, 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, - 3300, 3140, 3014, 2975, 2952, 2896, 2897, 2842, 2929, 3567, 3929, 3485, 3082, - 3625, 4953, 5239, 5094, 4993, 4821, 4431, 5195, 5542, 5557, 4894, 4414]; - ES_LENGTH = 100; - samplerate = 48; - eventEmitter.emit('prepare'); - }) - }); - media.createAudioDecoderByName('avdec_aac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - eventEmitter.emit('getAudioDecoderCaps'); - }) - }) -}) - diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncPromiseTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncPromiseTest.test.js deleted file mode 100644 index e2b4045b6..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderFuncPromiseTest.test.js +++ /dev/null @@ -1,883 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderFuncPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const AUDIOPATH2 = RESOURCEPATH + 'AAC_16000_1.aac'; - const AUDIOPATH3 = RESOURCEPATH + 'FLAC_48000_32_1.flac'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_func_promise_'; - let audioDecodeProcessor; - let readStreamSync; - let eosframenum = 0; - let samplerate = 44.1; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = undefined; - readStreamSync = undefined; - eosframenum = 0; - samplerate = 44.1; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - ES_LENGTH = 1500; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - eosframenum = 0; - samplerate = 44.1; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - }catch(e) { - console.info(e) - } - } - - function readFile(path) { - console.info('read file start execution'); - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - }catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - } - - async function stopWork() { - await audioDecodeProcessor.stop().then(() => { - console.info("case stop success") - }, failCallback).catch(failCatch); - } - - async function resetWork() { - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - if (needrelease) { - audioDecodeProcessor = null; - } - }, failCallback).catch(failCatch); - } - - async function flushWork() { - inputQueue = []; - outputQueue = []; - await audioDecodeProcessor.flush().then(() => { - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }, failCallback).catch(failCatch); - } - - async function doneWork() { - await audioDecodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioDecodeProcessor = null; - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - timestamp += ES[frameCnt]/samplerate; - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueAllOutputs(queue, savapath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - console.info("sawOutputEOS == true"); - if (stopAtEOS) { - await stopWork(); - } else if (resetAtEOS) { - await resetWork(); - } else if (flushAtEOS) { - await flushWork(); - } else if (workdoneAtEOS) { - await doneWork(); - done(); - } else { - console.info("saw output EOS"); - } - } - else{ - writeFile(savapath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - console.info("outputbuffer.flags: " + outBuffer.flags); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }, failCallback).catch(failCatch);} - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_00_0100 - * @tc.name : 000.test set EOS after last frame and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_00_0100', 0, async function (done) { - console.info("case test set EOS after last frame and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0000.pcm'; - workdoneAtEOS = true; - needGetMediaDes = true; - await media.getMediaCapability().then((mediaCaps) => { - console.info('getMediaCapability success'); - if (typeof (mediaCaps) != 'undefined') { - mediaCaps.getAudioDecoderCaps().then((audioCapsArray) => { - console.info('getAudioDecoderCaps success'); - if (typeof (audioCapsArray) != 'undefined') { - console.info('audioCapsArray is not null'); - console.info('get first audioCaps'+ audioCapsArray[0]); - console.info('codecInfo: '+ audioCapsArray[0].codecInfo); - console.info('supportedBitrate: '+ audioCapsArray[0].supportedBitrate); - console.info('supportedBitrate.min: '+ audioCapsArray[0].supportedBitrate.min); - } else { - console.info('audioCaps is not defined'); - } - }, failCallback).catch(failCatch); - } else { - console.info('mediaCaps is not defined'); - } - }, failCallback).catch(failCatch); - await media.createAudioDecoderByName('avdec_aac').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0100 - * @tc.name : 001.test set EOS manually before last frame and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0100', 0, async function (done) { - console.info("case test set EOS manually before last frame and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0100.pcm'; - eosframenum = 500; - workdoneAtEOS = true; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - console.info("get AudioDecoderCaps:"); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0200 - * @tc.name : 002.test flush at running state - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0200', 0, async function (done) { - console.info("case test flush at running state"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0200.pcm'; - workdoneAtEOS = true; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(3000).then(() => { - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.flush().then(() => { - console.info("case flush after 5s"); - }, failCallback).catch(failCatch); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0300 - * @tc.name : 003. test flush at EOS state - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0300', 0, async function (done) { - console.info("case test flush at EOS state"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0300.pcm'; - eosframenum = 200; - flushAtEOS = true; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0400 - * @tc.name : 004. test stop at running state and reset - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0400', 0, async function (done) { - console.info("case test stop at running state and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0400.pcm'; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(5000).then(() => { - audioDecodeProcessor.stop().then(() => { - console.info("case stop after 5s success"); - }, failCallback).catch(failCatch);}); - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioDecodeProcessor = null; - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0500 - * @tc.name : 005. test stop and restart - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0500', 0, async function (done) { - console.info("case test stop and restart"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0500.pcm'; - eosframenum = 200; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(5000).then(() => { - console.info("case stop decoding after 5s"); - }); - await audioDecodeProcessor.stop().then(() => { - console.info("case stop after 5s success"); - }, failCallback).catch(failCatch); - await sleep(2000).then(() => { - console.info("case restart decoding after 2s"); - resetParam(); - readFile(AUDIOPATH); - }); - await audioDecodeProcessor.start().then(() => { - console.info("case restart after 3s success"); - workdoneAtEOS = true; - enqueueAllInputs(inputQueue); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0600 - * @tc.name : 006. test reconfigure for new file with the same format - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0600', 0, async function (done) { - console.info("case test reconfigure codec for new file with the same format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let mediaDescription2 = { - "channel_count": 1, - "sample_rate": 16000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0600.pcm'; - eosframenum = 200; - resetAtEOS = true; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(10000).then(() => { - console.info("case start configure 2"); - }); - await audioDecodeProcessor.configure(mediaDescription2).then(() => { - console.info("case configure 2 success"); - resetParam(); - readFile(AUDIOPATH2); - }, failCallback).catch(failCatch); - savepath = BASIC_PATH + '0601.pcm'; - workdoneAtEOS = true; - ES = [0, 239, 302, 309, 330, 474, 684, 699, 683, 674, 647, 649, 638, 644, 640, - 639, 650, 702, 713, 718, 707, 707, 683, 670, 674, 699, 654, 650, 715, 770, - 764, 736, 697, 664, 643, 649, 704, 730, 720, 710, 689, 670, 673, 653, 635, - 643, 638, 653, 658, 683, 683, 705, 690, 681, 648, 659, 743, 681, 706, 707, - 718, 714, 746, 725, 741, 709, 675, 675, 751, 698, 736, 738, 711, 702, 691, - 668, 668, 650, 661, 678, 694, 719, 685, 700, 657, 671, 668, 701, 689, 685, - 682, 668, 696, 690, 683, 739, 704, 667, 694, 716, 757, 714, 701, 664, 619, - 609, 591, 644, 573, 572, 605, 595, 597, 529, 581, 578, 586, 537, 577, 535, - 572, 570, 534, 547, 581, 530, 591, 521, 556, 570, 557, 541, 506, 572, 579, - 502, 516, 582, 540, 584, 548, 555, 539, 578, 588, 541, 539, 526, 575, 535, - 571, 525, 569, 560, 584, 551, 574, 572, 537, 550, 582, 512, 559, 593, 601, - 594, 546, 560, 567, 547, 529, 576, 577, 556, 551, 530, 542, 575, 510, 559, - 613, 628, 511, 566, 515, 539, 594, 536, 565, 551, 533, 613, 557, 523, 574, - 582, 616, 610, 573, 509, 535]; - ES_LENGTH = 200; - samplerate = 16; - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare2 success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start2 success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0700 - * @tc.name : 007. test reconfigure for new file with different formats - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_DECODER_FUNCTION_PROMISE_01_0700', 0, async function (done) { - console.info("case test reconfigure codec for new file with different formats"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let mediaDescription2 = { - "channel_count": 1, - "sample_rate": 48000, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0700.pcm'; - eosframenum = 200; - resetAtEOS = true; - needrelease = true; - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioDecoder success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.getAudioDecoderCaps().then((AudioCaps) => { - console.info("case get AudioDecoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(10000).then(() => { - console.info("start createaudiodecoder 2"); - }); - await media.createAudioDecoderByMime('audio/flac').then((processor) => { - console.info("case create createAudioDecoder flac success"); - audioDecodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioDecodeProcessor.configure(mediaDescription2).then(() => { - console.info("case configure 2 success"); - resetParam(); - readFile(AUDIOPATH3); - }, failCallback).catch(failCatch); - savepath = BASIC_PATH + '0701.pcm'; - workdoneAtEOS = true; - ES = [0, 2116, 2093, 2886, 2859, 2798, 2778, 2752, 2752, 2754, 2720, 2898, 2829, - 2806, 2796, 2786, 2774, 2758, 2741, 3489, 3342, 3272, 3167, 3048, 3060, 2919, - 2839, 2794, 2770, 2763, 2756, 2722, 2950, 2876, 2842, 2827, 2792, 3121, 3075, - 2969, 3240, 3199, 3082, 2975, 2895, 3135, 3024, 2970, 2902, 2860, 2802, 2778, - 2779, 2963, 2893, 2870, 2831, 2800, 2762, 2752, 2760, 2759, 2726, 2889, 2960, - 2876, 3223, 3040, 3006, 3042, 2980, 3097, 3069, 3215, 3365, 3296, 3653, 3480, - 3300, 3140, 3014, 2975, 2952, 2896, 2897, 2842, 2929, 3567, 3929, 3485, 3082, - 3625, 4953, 5239, 5094, 4993, 4821, 4431, 5195, 5542, 5557, 4894, 4414]; - ES_LENGTH = 100; - samplerate = 48; - setCallback(savepath, done); - await audioDecodeProcessor.prepare().then(() => { - console.info("case prepare2 success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.start().then(() => { - console.info("case start2 success"); - }, failCallback).catch(failCatch); - }) -}) diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderMultiInstancesTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderMultiInstancesTest.test.js deleted file mode 100644 index da33ba37d..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderMultiInstancesTest.test.js +++ /dev/null @@ -1,272 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderMultiInstances', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH = RESOURCEPATH + 'AAC_48000_32_1.aac'; - let readStreamSync; - let eosframenum = 0; - let samplerate = 44.1; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = []; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - }) - - afterEach(function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - eosframenum = 0; - samplerate = 44.1; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - }catch(e) { - console.info(e) - } - } - - function readFile(path) { - console.info('read file start execution'); - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - }catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - } - - async function stopWork(audioDecodeProcessor) { - await audioDecodeProcessor.stop().then(() => { - console.info("case stop success") - }, failCallback).catch(failCatch); - } - - async function resetWork(audioDecodeProcessor) { - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - if (needrelease) { - audioDecodeProcessor = null; - } - }, failCallback).catch(failCatch); - } - - async function flushWork(audioDecodeProcessor) { - inputQueue = []; - outputQueue = []; - await audioDecodeProcessor.flush().then(() => { - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }, failCallback).catch(failCatch); - } - - async function doneWork(audioDecodeProcessor) { - await audioDecodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - audioDecodeProcessor = null; - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function enqueueAllInputs(audioDecodeProcessor, queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - timestamp += ES[frameCnt]/samplerate; - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueAllOutputs(audioDecodeProcessor, queue, savapath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - console.info("sawOutputEOS == true"); - if (stopAtEOS) { - await stopWork(audioDecodeProcessor); - } else if (resetAtEOS) { - await resetWork(audioDecodeProcessor); - } else if (flushAtEOS) { - await flushWork(audioDecodeProcessor); - } else if (workdoneAtEOS) { - await doneWork(audioDecodeProcessor); - done(); - } else { - console.info("saw output EOS"); - } - } - else{ - writeFile(savapath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(audioDecodeProcessor, savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(audioDecodeProcessor, inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - console.info("outputbuffer.flags: " + outBuffer.flags); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }, failCallback).catch(failCatch);} - outputQueue.push(outBuffer); - await dequeueAllOutputs(audioDecodeProcessor, outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_MULTIINSTANCE_0100 - * @tc.name : 001.create multiple decoders - * @tc.desc : basic decode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_MULTIINSTANCE_0100', 0, async function (done) { - console.info("case test multiple instances"); - let array = new Array(); - for (let i = 0; i < 2; i += 1) { - await media.createAudioDecoderByMime('audio/mp4a-latm').then((processor) => { - if (typeof(processor) != 'undefined') { - console.info("case create createAudioDecoder success: " + i); - array[i] = processor; - } else { - console.info("case create createAudioDecoder failed: " + i); - } - }, failCallback).catch(failCatch); - } - console.info('case has created multiple decoders'); - for (let j = 0; j < 2; j++) { - resetParam(); - await array[j].reset().then(() => { - console.info("reset decoder " + j); - }, failCallback).catch(failCatch); - await array[j].release().then(() => { - console.info('release success'); - array[j] = null; - }, failCallback).catch(failCatch); - } - done(); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityCallbackTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityCallbackTest.test.js deleted file mode 100644 index 8364daa5f..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityCallbackTest.test.js +++ /dev/null @@ -1,1348 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderReliabilityCallback', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_reliability_callback'; - const END = 0; - const CONFIGURE = 1; - const PREPARE = 2; - const START = 3; - const FLUSH = 4; - const STOP = 5; - const RESET = 6; - const HOLDON = 7; - const WAITFORALLOUTS = 8; - const CONFIGURE_ERROR = 9; - const PREPARE_ERROR = 10; - const START_ERROR = 11; - const FLUSH_ERROR = 12; - const STOP_ERROR = 13; - const JUDGE_EOS = 14; - const WAITTIME = 3000; - let audioDecodeProcessor; - let readStreamSync; - let EOSFrameNum = 0; - let samplerate = 44.1; - let workdoneAtEOS = false; - let flushAtEOS = false; - let needGetMediaDes = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - let ES_LENGTH = 500; - let mime = 'audio/mp4a-latm'; - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - }; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = null; - readStreamSync = undefined; - EOSFrameNum = 0; - samplerate = 44.1; - workdoneAtEOS = false; - flushAtEOS = false; - needGetMediaDes = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - ES_LENGTH = 500; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - function resetParam() { - readStreamSync = undefined; - EOSFrameNum = 0; - samplerate = 44.1; - workdoneAtEOS = false; - flushAtEOS = false; - needGetMediaDes = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function createAudioDecoder(savepath, mySteps, done) { - media.createAudioDecoderByMime(mime, (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - setCallback(savepath, done); - console.info("case start api test"); - nextStep(mySteps, mediaDescription, done); - }) - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - }catch(e) { - console.info(e) - } - } - - function readFile(path) { - console.info('read file start execution'); - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - }catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - async function doneWork(done) { - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success"); - resetParam(); - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.log("case reset success"); - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioDecodeProcessor = null; - done(); - }) - }) - }) - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - function nextStep(mySteps, mediaDescription, done) { - console.info("case myStep[0]: " + mySteps[0]); - if (mySteps[0] == END) { - console.info('case to done'); - audioDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info(`case release 1`); - audioDecodeProcessor = null; - done(); - }); - } - switch (mySteps[0]) { - case CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - nextStep(mySteps, mediaDescription, done); - }); - break; - case PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - audioDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case START: - mySteps.shift(); - console.info(`case to start`); - if (sawOutputEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - enqueueAllInputs(inputQueue); - } - audioDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case FLUSH: - mySteps.shift(); - console.info(`case to flush`); - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info(`case flush 1`); - if (flushAtEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - flushAtEOS = false; - } - nextStep(mySteps, mediaDescription, done); - }); - break; - case STOP: - mySteps.shift(); - console.info(`case to stop`); - audioDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`case stop 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case RESET: - mySteps.shift(); - console.info(`case to reset`); - resetParam(); - audioDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info(`case reset 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case HOLDON: - mySteps.shift(); - setTimeout(() =>{ - nextStep(mySteps, mediaDescription, done); - }, WAITTIME); - break; - case WAITFORALLOUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - case CONFIGURE_ERROR: - mySteps.shift(); - console.info(`case to configure 2`); - audioDecodeProcessor.configure(mediaDescription, (err) => { - expect(err != undefined).assertTrue(); - console.info(`case configure error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case PREPARE_ERROR: - mySteps.shift(); - console.info(`case to prepare`); - audioDecodeProcessor.prepare((err) => { - expect(err != undefined).assertTrue(); - console.info(`case prepare error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case START_ERROR: - mySteps.shift(); - console.info(`case to start`); - audioDecodeProcessor.start((err) => { - expect(err != undefined).assertTrue(); - console.info(`case start error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case FLUSH_ERROR: - mySteps.shift(); - console.info(`case to flush`); - audioDecodeProcessor.flush((err) => { - expect(err != undefined).assertTrue(); - console.info(`case flush error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case STOP_ERROR: - mySteps.shift(); - console.info(`case to stop`); - audioDecodeProcessor.stop((err) => { - expect(err != undefined).assertTrue(); - console.info(`case stop error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case JUDGE_EOS: - mySteps.shift(); - console.info(`case judge EOS state`); - expect(sawOutputEOS).assertTrue(); - nextStep(mySteps, mediaDescription, done); - break; - default: - break; - } - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - console.info("frameCnt:" + frameCnt); - if (frameCnt == EOSFrameNum || frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } - else{ - console.info("read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - timestamp += ES[frameCnt]/samplerate; - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject, () => { - console.info('queueInput success'); - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (workdoneAtEOS) { - await doneWork(done); - } else { - console.info("sawOutputEOS = true"); - } - } - else{ - console.info("not last frame, continue"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject, () => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - expect(err).assertUndefined(); - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }); - } - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0100 - * @tc.name : 001.create -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0100.pcm'; - let mySteps = new Array(CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0300 - * @tc.name : 003.start -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, CONFIGURE_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0700.pcm'; - let mySteps = new Array(RESET, CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0800.pcm'; - let mySteps = new Array(CONFIGURE, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_CALLBACK_0900', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0900.pcm'; - let mySteps = new Array(CONFIGURE, RESET, CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0100.pcm'; - let mySteps = new Array(PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, PREPARE_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0100 - * @tc.name : 001.create -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0100.pcm'; - let mySteps = new Array(START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0200 - * @tc.name : 002.configure -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0200.pcm'; - let mySteps = new Array(CONFIGURE, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0400 - * @tc.name : 004.start -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0500 - * @tc.name : 005.flush -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0600 - * @tc.name : 006.stop -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, START_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0800 - * @tc.name : 008.reset -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0100 - * @tc.name : 001.create -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0100.pcm'; - let mySteps = new Array(FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0200.pcm'; - let mySteps = new Array(CONFIGURE, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0400 - * @tc.name : 004.start -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, FLUSH, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0100 - * @tc.name : 001.create -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0100.pcm'; - let mySteps = new Array(STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0200.pcm'; - let mySteps = new Array(CONFIGURE, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0400 - * @tc.name : 004.start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, STOP, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0100 - * @tc.name : 001.create -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0100.pcm'; - let mySteps = new Array(RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0200.pcm'; - let mySteps = new Array(CONFIGURE, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0400 - * @tc.name : 004.start -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0100.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, WAITFORALLOUTS); - EOSFrameNum = 2; - flushAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, CONFIGURE, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, WAITFORALLOUTS); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityPromiseTest.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityPromiseTest.test.js deleted file mode 100644 index 83f325989..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/AudioDecoderReliabilityPromiseTest.test.js +++ /dev/null @@ -1,1349 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioDecoderReliabilityPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audiodecoder/' - const AUDIOPATH = RESOURCEPATH + 'AAC_48000_32_1.aac'; - const BASIC_PATH = RESOURCEPATH + 'results/decode_reliability_promise'; - const END = 0; - const CONFIGURE = 1; - const PREPARE = 2; - const START = 3; - const FLUSH = 4; - const STOP = 5; - const RESET = 6; - const HOLDON = 7; - const WAITFORALLOUTS = 8; - const CONFIGURE_ERROR = 9; - const PREPARE_ERROR = 10; - const START_ERROR = 11; - const FLUSH_ERROR = 12; - const STOP_ERROR = 13; - const JUDGE_EOS = 14; - const WAITTIME = 3000; - let audioDecodeProcessor; - let readStreamSync; - let EOSFrameNum = 0; - let samplerate = 44.1; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - let ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - let ES_LENGTH = 500; - let mime = 'audio/mp4a-latm'; - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - }; - let expectError = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioDecodeProcessor = null; - readStreamSync = undefined; - EOSFrameNum = 0; - samplerate = 44.1; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES = [0, 283, 336, 291, 405, 438, 411, 215, 215, 313, 270, 342, 641, 554, 545, 545, 546, - 541, 540, 542, 552, 537, 533, 498, 472, 445, 430, 445, 427, 414, 386, 413, 370, 380, - 401, 393, 369, 391, 367, 395, 396, 396, 385, 391, 384, 395, 392, 386, 388, 384, 379, - 376, 381, 375, 373, 349, 391, 357, 384, 395, 384, 380, 386, 372, 386, 383, 378, 385, - 385, 384, 342, 390, 379, 387, 386, 393, 397, 362, 393, 394, 391, 383, 385, 377, 379, - 381, 369, 375, 379, 346, 382, 356, 361, 366, 394, 393, 385, 362, 406, 399, 384, 377, - 385, 389, 375, 346, 396, 388, 381, 383, 352, 357, 397, 382, 395, 376, 388, 373, 374, - 353, 383, 384, 393, 379, 348, 364, 389, 380, 381, 388, 423, 392, 381, 368, 351, 391, - 355, 358, 395, 390, 385, 382, 383, 388, 388, 389, 376, 379, 376, 384, 369, 354, 390, - 389, 396, 393, 382, 385, 353, 383, 381, 377, 411, 387, 390, 377, 349, 381, 390, 378, - 373, 375, 381, 351, 392, 381, 380, 381, 378, 387, 379, 383, 348, 386, 364, 386, 371, - 399, 399, 385, 380, 355, 397, 395, 382, 380, 386, 352, 387, 390, 373, 372, 388, 378, - 385, 368, 385, 370, 378, 373, 383, 368, 373, 388, 351, 384, 391, 387, 389, 383, 355, - 361, 392, 386, 354, 394, 392, 397, 392, 352, 381, 395, 349, 383, 390, 392, 350, 393, - 393, 385, 389, 393, 382, 378, 384, 378, 375, 373, 375, 389, 377, 383, 387, 373, 344, - 388, 379, 391, 373, 384, 358, 361, 391, 394, 363, 350, 361, 395, 399, 389, 398, 375, - 398, 400, 381, 354, 363, 366, 400, 400, 356, 370, 400, 394, 398, 385, 378, 372, 354, - 359, 393, 381, 363, 396, 396, 355, 390, 356, 355, 371, 399, 367, 406, 375, 377, 405, - 401, 390, 393, 392, 384, 386, 374, 358, 397, 389, 393, 385, 345, 379, 357, 388, 356, - 381, 389, 367, 358, 391, 360, 394, 396, 357, 395, 388, 394, 383, 357, 383, 392, 394, - 376, 379, 356, 386, 395, 387, 377, 377, 389, 377, 385, 351, 387, 350, 388, 384, 345, - 358, 368, 399, 394, 385, 384, 395, 378, 387, 386, 386, 376, 375, 382, 351, 359, 356, - 401, 388, 363, 406, 363, 374, 435, 366, 400, 393, 392, 371, 391, 359, 359, 397, 388, - 390, 420, 411, 369, 384, 382, 383, 383, 375, 381, 361, 380, 348, 379, 386, 379, 379, - 386, 371, 352, 378, 378, 388, 384, 385, 352, 355, 387, 383, 379, 362, 386, 399, 376, - 390, 350, 387, 357, 403, 398, 397, 360, 351, 394, 400, 399, 393, 388, 395, 370, 377, - 395, 360, 346, 381, 370, 390, 380, 391, 387, 382, 384, 383, 354, 349, 394, 358, 387, - 400, 386, 402, 354, 396, 387, 391, 365, 377, 359, 361, 365, 395, 388, 388, 384, 388, - 378, 374, 382, 376, 377, 389, 378, 341, 390, 376, 381, 375, 414, 368, 369, 387, 411, - 396, 391, 378, 389, 349, 383, 344, 381, 387, 380, 353, 361, 391, 365, 390, 396, 382, - 386, 385, 385, 409, 387, 386, 378, 372, 372, 374, 349, 388, 389, 348, 395, 380, 382, - 388, 375, 347, 383, 359, 389, 368, 361, 405, 398, 393, 395, 359, 360, 395, 395, 362, - 354, 388, 348, 388, 386, 390, 350, 388, 356, 369, 364, 404, 404, 391, 394, 385, 439, - 432, 375, 366, 441, 362, 367, 382, 374, 346, 391, 371, 354, 376, 390, 373, 382, 385, - 389, 378, 377, 347, 414, 338, 348, 385, 352, 385, 386, 381, 388, 387, 364, 465, 405, - 443, 387, 339, 376, 337, 379, 387, 370, 374, 358, 354, 357, 393, 356, 381, 357, 407, - 361, 397, 362, 394, 394, 392, 394, 391, 381, 386, 379, 354, 351, 392, 408, 393, 389, - 388, 385, 375, 388, 375, 388, 375, 354, 384, 379, 386, 394, 383, 359, 405, 395, 352, - 345, 403, 427, 373, 380, 350, 415, 378, 434, 385, 388, 387, 400, 405, 329, 391, 356, - 419, 358, 359, 375, 367, 391, 359, 369, 361, 376, 378, 379, 348, 390, 345, 388, 390, - 406, 349, 368, 364, 391, 384, 401, 384, 391, 361, 399, 359, 386, 392, 382, 386, 380, - 383, 345, 376, 393, 400, 395, 343, 352, 354, 381, 388, 357, 393, 389, 384, 389, 388, - 384, 404, 372, 358, 381, 352, 355, 485, 393, 371, 376, 389, 377, 391, 387, 376, 342, - 390, 375, 379, 396, 376, 402, 353, 392, 382, 383, 387, 386, 372, 377, 382, 388, 381, - 387, 357, 393, 385, 346, 389, 388, 357, 362, 404, 398, 397, 402, 371, 351, 370, 362, - 350, 388, 399, 402, 406, 377, 396, 359, 372, 390, 392, 368, 383, 346, 384, 381, 379, - 367, 384, 389, 381, 371, 358, 422, 372, 382, 374, 444, 412, 369, 362, 373, 389, 401, - 383, 380, 366, 365, 361, 379, 372, 345, 382, 375, 376, 375, 382, 356, 395, 383, 384, - 391, 361, 396, 407, 365, 351, 385, 378, 403, 344, 352, 387, 397, 399, 377, 371, 381, - 415, 382, 388, 368, 383, 405, 390, 386, 384, 374, 375, 381, 371, 372, 374, 377, 346, - 358, 381, 377, 359, 385, 396, 385, 390, 389, 391, 375, 357, 389, 390, 377, 370, 379, - 351, 381, 381, 380, 371, 386, 389, 389, 383, 362, 393, 388, 355, 396, 383, 352, 384, - 352, 383, 362, 396, 385, 396, 357, 388, 382, 377, 373, 379, 383, 386, 350, 393, 355, - 380, 401, 392, 391, 402, 391, 427, 407, 394, 332, 398, 367, 373, 343, 381, 383, 386, - 382, 349, 353, 393, 378, 386, 375, 390, 356, 392, 384, 387, 380, 381, 385, 386, 383, - 378, 379, 359, 381, 382, 388, 357, 357, 397, 358, 424, 382, 352, 409, 374, 368, 365, - 399, 352, 393, 389, 385, 352, 380, 398, 389, 385, 387, 387, 353, 402, 396, 386, 357, - 395, 368, 369, 407, 394, 383, 362, 380, 385, 368, 375, 365, 379, 377, 388, 380, 346, - 383, 381, 399, 359, 386, 455, 368, 406, 377, 339, 381, 377, 373, 371, 338, 371, 387, - 376, 386, 388, 382, 381, 377, 389, 352, 391, 396, 398, 374, 352, 358, 387, 368, 401, - 395, 387, 387, 354, 393, 401, 382, 390, 371, 374, 387, 377, 379, 377, 383, 374, 367, - 372, 393, 365, 392, 350, 378, 385, 377, 382, 388, 353, 389, 359, 366, 404, 390, 381, - 396, 388, 394, 380, 379, 372, 355, 397, 382, 351, 397, 378, 375, 378, 369, 387, 380, - 383, 346, 357, 362, 371, 413, 393, 365, 395, 391, 384, 386, 385, 390, 355, 385, 394, - 384, 383, 431, 369, 373, 392, 397, 396, 353, 391, 352, 375, 382, 397, 393, 371, 403, - 375, 338, 418, 368, 372, 370, 344, 392, 360, 402, 402, 425, 374, 378, 376, 380, 378, - 347, 379, 414, 377, 390, 383, 357, 390, 385, 377, 378, 368, 399, 389, 383, 368, 372, - 358, 386, 355, 380, 386, 349, 381, 379, 380, 351, 389, 380, 353, 359, 365, 370, 407, - 388, 381, 358, 364, 396, 369, 407, 391, 358, 440, 419, 412, 395, 344, 382, 391, 353, - 403, 391, 371, 354, 362, 407, 411, 397, 385, 388, 357, 348, 368, 401, 404, 380, 370, - 369, 365, 349, 373, 346, 351, 394, 399, 387, 393, 363, 402, 394, 375, 389, 386, 395, - 386, 386, 353, 403, 363, 376, 398, 383, 372, 350, 381, 353, 445, 386, 369, 383, 351, - 392, 397, 384, 389, 354, 400, 392, 379, 386, 355, 391, 388, 361, 390, 408, 357, 390, - 387, 352, 393, 357, 358, 401, 383, 391, 384, 388, 377, 380, 354, 393, 387, 357, 396, - 360, 362, 388, 390, 359, 367, 366, 396, 388, 394, 363, 391, 394, 351, 391, 391, 350, - 360, 365, 397, 366, 375, 400, 412, 372, 380, 383, 384, 383, 390, 380, 361, 363, 387, - 358, 385, 359, 385, 399, 351, 392, 388, 385, 384, 350, 379, 385, 383, 375, 389, 381, - 382, 376, 389, 390, 375, 381, 382, 390, 385, 380, 359, 351, 383, 391, 388, 379, 354, - 387, 382, 358, 381, 381, 386, 397, 373, 381, 387, 387, 381, 378, 383, 370, 360, 386, - 362, 402, 357, 398, 398, 397, 378, 394, 381, 375, 380, 390, 373, 369, 388, 347, 356, - 384, 391, 386, 394, 388, 357, 403, 381, 376, 414, 383, 387, 349, 379, 383, 384, 377, - 394, 426, 373, 392, 367, 381, 378, 378, 374, 373, 369, 368, 332, 335, 381, 392, 388, - 381, 424, 367, 398, 399, 392, 379, 391, 379, 370, 343, 405, 378, 367, 345, 379, 347, - 388, 353, 392, 382, 384, 387, 350, 363, 398, 398, 359, 402, 454, 440, 341, 383, 381, - 385, 355, 349, 369, 360, 388, 383, 354, 435, 405, 404, 399, 385, 386, 364, 388, 373, - 376, 384, 395, 400, 408, 390, 375, 341, 372, 371, 407, 345, 378, 345, 407, 365, 398, - 396, 339, 379, 375, 410, 386, 407, 387, 365, 375, 384, 347, 393, 377, 350, 376, 375, - 381, 410, 394, 386, 345, 345, 354, 397, 386, 375, 390, 347, 411, 381, 383, 374, 379, - 380, 378, 391, 380, 339, 390, 383, 375]; - ES_LENGTH = 500; - expectError = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioDecodeProcessor != null) { - await audioDecodeProcessor.release().then(() => { - console.info('audioDecodeProcessor release success'); - audioDecodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCallbackTrue = function(err, mySteps, done) { - console.info('case callback err : ' + err); - expect(err != undefined).assertTrue(); - nextStep(mySteps, done); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - EOSFrameNum = 0; - samplerate = 44.1; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function createAudioDecoder(savepath, mySteps, done) { - media.createAudioDecoderByMime(mime, (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioDecoder 1`); - audioDecodeProcessor = processor; - setCallback(savepath, done); - console.info("case start api test"); - nextStep(mySteps, done); - }) - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - }catch(e) { - console.info(e) - } - } - - function readFile(path) { - console.info('read file start execution'); - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - }catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - async function doneWork() { - await audioDecodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioDecodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await audioDecodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioDecodeProcessor = null; - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - function nextStep(mySteps, done) { - console.info("case myStep[0]: " + mySteps[0]); - if (mySteps[0] == END) { - audioDecodeProcessor.release().then(() => { - console.info("case release success"); - audioDecodeProcessor = null; - done(); - }, failCallback).catch(failCatch); - } - switch (mySteps[0]) { - case CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure 1`); - readFile(AUDIOPATH); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - audioDecodeProcessor.prepare().then(() => { - console.info(`case prepare 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case START: - mySteps.shift(); - console.info(`case to start`); - if (sawOutputEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - enqueueAllInputs(inputQueue); - } - audioDecodeProcessor.start().then(() => { - console.info(`case start 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case FLUSH: - mySteps.shift(); - console.info(`case to flush`); - inputQueue = []; - outputQueue = []; - audioDecodeProcessor.flush().then(() => { - console.info(`case flush 1`); - if (flushAtEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - flushAtEOS = false; - } - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case STOP: - mySteps.shift(); - console.info(`case to stop`); - audioDecodeProcessor.stop().then(() => { - console.info(`case stop 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case RESET: - mySteps.shift(); - console.info(`case to reset`); - resetParam(); - audioDecodeProcessor.reset().then(() => { - console.info(`case reset 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case HOLDON: - mySteps.shift(); - setTimeout(() =>{ - nextStep(mySteps, done); - }, WAITTIME); - break; - case WAITFORALLOUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - case CONFIGURE_ERROR: - mySteps.shift(); - console.info(`case to configure 2`); - audioDecodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case PREPARE_ERROR: - mySteps.shift(); - console.info(`case to prepare 2`); - audioDecodeProcessor.prepare().then(() => { - console.info(`case prepare error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case START_ERROR: - mySteps.shift(); - console.info(`case to start 2`); - audioDecodeProcessor.start().then(() => { - console.info(`case start error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case FLUSH_ERROR: - mySteps.shift(); - console.info(`case to flush 2`); - audioDecodeProcessor.flush().then(() => { - console.info(`case flush error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case STOP_ERROR: - mySteps.shift(); - console.info(`case to stop 2`); - audioDecodeProcessor.stop().then(() => { - console.info(`case stop error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case JUDGE_EOS: - mySteps.shift(); - console.info(`case judge EOS state`); - expect(sawOutputEOS).assertTrue(); - nextStep(mySteps, done); - break; - default: - break; - } - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == EOSFrameNum || frameCnt == ES_LENGTH + 1) { - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[frameCnt]; - getContent(inputobject.data, ES[frameCnt]); - inputobject.flags = 0; - } - timestamp += ES[frameCnt]/samplerate; - frameCnt += 1; - audioDecodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueAllOutputs(queue, savapath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (workdoneAtEOS) { - await doneWork(); - done(); - } else { - console.info("sawOutputEOS = true") - } - } - else{ - console.info("not last frame, continue"); - } - audioDecodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioDecodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioDecodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needGetMediaDes) { - audioDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }, failCallback).catch(failCatch);} - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioDecodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioDecodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0100 - * @tc.name : 001.create -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0100.pcm'; - let mySteps = new Array(CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0300 - * @tc.name : 003.start -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, CONFIGURE_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0700.pcm'; - let mySteps = new Array(RESET, CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0800.pcm'; - let mySteps = new Array(CONFIGURE, CONFIGURE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_CONFIGURE_PROMISE_0900', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0900.pcm'; - let mySteps = new Array(CONFIGURE, RESET, CONFIGURE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0100.pcm'; - let mySteps = new Array(PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, PREPARE_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_PREPARE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, PREPARE_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0100 - * @tc.name : 001.create -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0100.pcm'; - let mySteps = new Array(START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0200 - * @tc.name : 002.configure -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0200.pcm'; - let mySteps = new Array(CONFIGURE, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0400 - * @tc.name : 004.start -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0500 - * @tc.name : 005.flush -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0600 - * @tc.name : 006.stop -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, START_ERROR, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0800 - * @tc.name : 008.reset -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_START_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, START_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0100 - * @tc.name : 001.create -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0100.pcm'; - let mySteps = new Array(FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0200.pcm'; - let mySteps = new Array(CONFIGURE, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0400 - * @tc.name : 004.start -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, FLUSH, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_FLUSH_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, FLUSH_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0100 - * @tc.name : 001.create -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0100.pcm'; - let mySteps = new Array(STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0200.pcm'; - let mySteps = new Array(CONFIGURE, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0400 - * @tc.name : 004.start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, STOP, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_STOP_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, STOP_ERROR, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0100 - * @tc.name : 001.create -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0100.pcm'; - let mySteps = new Array(RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0200.pcm'; - let mySteps = new Array(CONFIGURE, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0400 - * @tc.name : 004.start -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0600.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0700.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_RESET_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0800.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, RESET, END); - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0100.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0200.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, WAITFORALLOUTS); - EOSFrameNum = 2; - flushAtEOS = true; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0300.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, CONFIGURE, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0400.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, WAITFORALLOUTS); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_DECODER_API_EOS_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0500.pcm'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, STOP, END); - EOSFrameNum = 2; - createAudioDecoder(savepath, mySteps, done); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/List.test.js b/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/List.test.js deleted file mode 100644 index 239657117..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/js/test/List.test.js +++ /dev/null @@ -1,25 +0,0 @@ -/* - * 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('./AudioDecoderFuncPromiseTest.test.js') -require('./AudioDecoderFuncCallbackTest.test.js') -require('./AudioDecoderFormatPromiseTest.test.js') -require('./AudioDecoderFormatCallbackTest.test.js') -require('./AudioDecoderReliabilityPromiseTest.test.js') -require('./AudioDecoderReliabilityCallbackTest.test.js') -require('./AudioDecoderMultiInstancesTest.test.js') -require('./AudioDecoderEnumTest.test.js') - diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/element/string.json b/multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/element/string.json deleted file mode 100644 index 0bae6bd40..000000000 --- a/multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/element/string.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "string": [ - { - "name": "entry_MainAbility", - "value": "entry_MainAbility" - }, - { - "name": "mainability_description", - "value": "JS_Empty Ability" - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/media/icon.png b/multimedia/media/media_js_standard/audioDecoder/src/main/resources/base/media/icon.png deleted file mode 100644 index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6790 zcmX|G1ymHk)?T_}Vd;>R?p|tHQo6fg38|$UVM!6BLrPFWk?s;$LOP{GmJpBl$qoSA!PUg~PA65-S00{{S`XKG6NkG0RgjEntPrmV+?0|00mu7;+5 zrdpa{2QLqPJ4Y{j7=Mrl{BaxrkdY69+c~(w{Fv-v&aR%aEI&JYSeRTLWm!zbv;?)_ ziZB;fwGbbeL5Q}YLx`J$lp~A09KK8t_z}PZ=4ZzgdeKtgoc+o5EvN9A1K1_<>M?MBqb#!ASf&# zEX?<)!RH(7>1P+j=jqG(58}TVN-$psA6K}atCuI!KTJD&FMmH-78ZejBm)0qc{ESp z|LuG1{QnBUJRg_E=h1#XMWt2%fcoN@l7eAS!Es?Q+;XsRNPhiiE=@AqlLkJzF`O18 zbsbSmKN=aaq8k3NFYZfDWpKmM!coBU0(XnL8R{4=i|wi{!uWYM2je{U{B*K2PVdu&=E zTq*-XsEsJ$u5H4g6DIm2Y!DN`>^v|AqlwuCD;w45K0@eqauiqWf7l&o)+YLHm~|L~ z7$0v5mkobriU!H<@mVJHLlmQqzQ3d6Rh_-|%Yy2li*tHO>_vcnuZ7OR_xkAIuIU&x z-|8Y0wj|6|a6_I(v91y%k_kNw6pnkNdxjqG8!%Vz_d%c_!X+6-;1`GC9_FpjoHev5fEV7RhJ>r=mh-jp$fqbqRJ=obwdgLDVP5+s zy1=_DWG0Y-Jb3t^WXmkr(d9~08k-|#Ly zaNOmT(^9tIb&eb4%CzIT zAm3CUtWSr1t4?h1kk#NBi{U|pJslvME{q|_eS^3En>SOqSxyuN1x;Is@8~m?*>}** znrRFArP!K_52RpX*&JHMR<^lVdm8ypJ}0R(SD(51j;6@ni$6bQ+2XL+R^|NnSp5}(kzvMZ^(@4fD_{QVu$(&K6H|C37TG1Am9Re{<<3gd zh@`>;BqkXMW&p0T6rt|iB$)~CvFe(XC)F9WgAZn*0@t$oZo;!*}r@_`h?KKH&6A@3= zISXoQB+~`op>NP-buiA*^0n{@i{_?MRG)&k)c)k_F+-2Lud!S9pc+i`s74NpBCaGF zXN+pHkubw*msGBTY27BKHv)RRh3;nMg4&$fD_6X9Vt~;_4D+5XPH~#Kn-yjcy!$}1 zigv#FNY>TqMhtIBb@UoF!cE~Q8~;!Pek>SQQwHnHuWKoVBosAiOr}q>!>aE*Krc)V zBUMEcJ5NU0g8}-h6i1zpMY9>m4ne?=U2~`w7K7Q0gB_=p@$5K7p6}thw z-~3dMj?YNX2X$lZ+7ngQ$=s}3mizNN@kE%OtB)?c&i~2L55z8^=yz;xMHLmlY>&Q# zJj?!)M#q_SyfkQh)k?j8IfLtB)ZCp|*vf4_B zos?73yd^h-Ac+;?E4*bpf=o*^3x3-`TVjbY4n6!EN10K6o@fxdyps05Vo3PU)otB} z`3kR+2w7_C#8Z!q`J)p{Vh!+m9-UP!$STp+Hb}}#@#_u^SsUQg<}59< zTvH3%XS4G+6FF^(m6bVF&nSUIXcl;nw{=H$%fgeJ>CgDYiLdpDXr{;-AnG z8dvcrHYVMI&`R6;GWekI@Ir3!uo)oz4^{6q0m^}@f2tM9&=YHNi6-?rh0-{+k@cQm zdp`g#YdQn%MDVg2GR>wZ`n2<0l4)9nx1Wfr&!Dvz=bPwU!h2S?ez6MVc5APE4-xLB zi&W9Q8k2@0w!C53g?iAIQ}~p*3O(@zja6KQ=M3zfW*_6o5SwR-)6VBh~m7{^-=MC-owYH5-u40a}a0liho3QZZ5L{bS_xM1)4}19)zTU$$MY zq3eZML1WC{K%YFd`Be0M-rkO^l?h{kM{$2oK1*A@HVJ57*yhDkUF!2WZ&oA4Y-sK( zCY69%#`mBCi6>6uw(x4gbFaP0+FD*JKJ-q!F1E?vLJ+d35!I5d7@^eU?(CS|C^tmI5?lv@s{{*|1F zFg|OzNpZ0hxljdjaW%45O0MOttRrd(Z?h{HYbB-KFUx&9GfFL3b8NwZ$zNu)WbBD` zYkj$^UB5%3Pj1MDr>S2Ejr9pUcgA!;ZG!@{uAy12)vG=*^9-|dNQBc8&`oxBlU~#y zs!anJX&T?57Jdr^sb>e+V`MVfY>Y0ESg7MG<7W0g&bR-ZYzzZ%2H&Etcp zcd6QeXO1D!5A#zM0lx*GH}`M)2~ZFLE;sP^RSB5wVMNfiZXPd(cmO>j=OSA3`o5r& zna(|^jGXbdN7PK)U8b7^zYtYkkeb%<%F~=OqB~kXMQkq}ii|skh@WSRt>5za;cjP0 zZ~nD%6)wzedqE}BMLt~qKwlvTr33))#uP~xyw#*Eaa|DbMQ_%mG0U8numf8)0DX`r zRoG2bM;#g|p-8gWnwRV5SCW0tLjLO&9Z?K>FImeIxlGUgo0Zk`9Qzhj1eco~7XZy+hXc@YF&ZQ=? zn*^1O56yK^x{y}q`j7}blGCx%dydV!c7)g~tJzmHhV=W~jbWRRR{1<^oDK+1clprm zz$eCy7y9+?{E|YgkW~}}iB#I4XoJ*xr8R?i_Hv$=Cof5bo-Nj~f`-DLebH}&0% zfQj9@WGd4;N~Y?mzQsHJTJq6!Qzl^-vwol(+fMt#Pl=Wh#lI5Vmu@QM0=_r+1wHt` z+8WZ~c2}KQQ+q)~2Ki77QvV&`xb|xVcTms99&cD$Zz4+-^R4kvUBxG8gDk7Y`K*)JZ^2rL(+ZWV~%W(@6 z)0bPArG#BROa_PHs~&WplQ_UIrpd)1N1QGPfv!J(Z9jNT#i%H?CE6|pPZb9hJ1JW4 z^q;ft#!HRNV0YgPojzIYT`8LuET2rUe-J|c!9l4`^*;4WtY@Ew@pL>wkjmMgGfN7 ze}}GtmU0@<_#08~I-Suk=^*9GLW=H4xhsml;vAV{%hy5Eegl@!6qKqbG024%n2HHw zCc@ivW_$@5ZoHP70(7D+(`PvgjW1Pd`wsiuv-aCukMrafwDm)B!xXVy*j2opohhoU zcJz%ADmj>i3`-3-$7nQKBQQuGY;2Qt&+(L~C>vSGFj5{Mlv?T_^dql;{zkpe4R1}R z%XfZyQ}wr*sr>jrKgm*PWLjuVc%6&&`Kbf1SuFpHPN&>W)$GmqC;pIoBC`=4-hPY8 zT*>%I2fP}vGW;R=^!1be?ta2UQd2>alOFFbVl;(SQJ4Jk#)4Z0^wpWEVvY4=vyDk@ zqlModi@iVPMC+{?rm=4(n+<;|lmUO@UKYA>EPTS~AndtK^Wy^%#3<;(dQdk3WaUkRtzSMC9}7x2||CNpF#(3T4C)@ z$~RWs`BNABKX|{cmBt>Q=&gkXl&x!!NK_%5hW0LS)Z4PB>%sV?F-{Wyj#s7W%$F{D zXdK^Fp3wvy+48+GP6F_|^PCRx=ddcTO3sG;B23A49~Qaw31SZ0Rc~`r4qqt%#OGW{ zCA_(LG5^N>yzUn&kAgVmxb=EA8s&tBXC}S1CZ(KoW)(%^JjLTPo^fs`Va;`=YlVPgmB$!yB}<(4ym6OeZ3xAJJ#;)2+B%p3P1Wt+d$eo`vz`T zXfUP2))kBDPoscH;Jc7I3NU<({|@wM$&GaDt`n7WLgIY3IA7A6-_R?z8N3mz|}*i z(zl5ot--Oq@f2-nv{X(ujT2T(k1vY_qh93pK@>H-qc%2Xta)IP0Q%zt%bqYgI`o!wv!0QerB`nCN^1n|@$sVOQ!V0teVG!I z_fD%JvfDeT1cK#-{o6Gv7}& zY0#NWin~kVaf$aufV&;63Hbs|`QVZWpDX6IMk1Hj2G}fiH9e-^6u2zf^FIr^BwD<6zjw63+{yUe8PUFvk8v{sJ=R{d#`O!sz`Q13~< zPT$JS(w=yQfU2`zPCNfSw=&zup@DXc(98afjhv@1w_f!m2Z>rMJ19AB&dB%P#Ls3b z=lK7OILM+SQ&VEd=1GN6o&>YVVtIzoZ%=Z_SdqJN2}E43{bE`>w+A;=y->@^k{oCC z$F*WTY&?34;kfyFV?b*Xb1Pq`Z=%OgwEg)Rz)tx=`f%5#w_INP=x&z5!jI;#;N$ma zhO)+MDm;SxOEVL15; zGq(v2pL3&P1Sl)8P*;G-fd{l1QJsv@e@d8)1PK4w2m*M%V3j-V~L^$i|&C@b?D?9tfwE{B^}Z$k8e5FmQ>v7Xz)sG32g9t}YBt zyR$+*_00RmPx+0mW+vVG4mxd(n$(eQf3-w>JPl2UJpafrPaL5@2j}%{VE-) zBI%6Qpj*dsdH<;g!S!avA~bv^0E+ zfyJbSjPb+j;J52U)<|cIcntQBI2T#>2;tOxu{%D?kML476AErF(qN9hPva5Nkc@BF zC-tLF@3ZFb%Kpj)M<{)x*l|*Ia@ECeXo2E4h2f!aV=cHAhi_E_mfUth(sM4^hJq7B zQsGWqdZUm9S%F`$nQ*_#NcuD`&)Ek%_s{&^78{9Hm ztri&rYLOxgFdG>O@+XHy z9#;|&vBCPXH5Mon^I`jSuR$&~ZWtyB67ujzFSj!51>#C}C17~TffQ{c-!QFQkTQ%! zIR^b1`zHx|*1GU?tbBx23weFLz5H?y_Q%N&t$}k?w+``2A=aotj0;2v$~AL z{scF-cL{wsdrmPvf#a9OHyYLcwQD4Kcm)`LLwMh4WT~p29f7M!iafJSU`IV}QY5Wa z(n44-9oA}?J{a+ah*@31WTs#&J#o1`H98#6IQf;Wv0N_!);f&9g7o-k(lW5rWnDUR zQBFIRG+X=6NnsI@mxnwm;tf5;_Uxg?jZ8m-m0}&6+DA!qam(p$mN5R})yA_7m$q@| zFEd|dpS595rxQr-n#GjI5i-AhnUE>Cr;jpCqSrD~EwK_DqI^7%3#p5)%T_od!t3SOmH9MyXeeGO2(UQL;ax|x?Ncixmeo1=$ z{-);Au{*tfzOG?KQ~K|ak8-HQ?`Pekhe2WM(8s{xv-p>Zmu_6{G!-oE$7$mY`MOJorI=+mMx?H;`pr!;fVYz?5~yXBACruWB`Ph zZM}90_<^OBxIhyZ9BW$`>6JvO;%VFpqVr8|7t3~AmxYak6?`Pp#c;**_SYmi`&z23 z`p6_~ePvH)C6x-G9$hgL=eVALq`-AiamN>!3~Lxw&{H(b{B(7xSRm6<3<{%{yXiH# zos5Rv1L+8fUKJLo%P>4I&$}y/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/" - ] - }, - { - "type": "ShellKit", - "run-command": [ - "rm -R /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/results", - "mkdir -p /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/results/", - "chmod 777 -R /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder", - "chmod 777 /data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/*" - ], - "teardown-command":[ - ] - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/signature/openharmony_sx.p7b b/multimedia/media/media_js_standard/audioEncoder/signature/openharmony_sx.p7b deleted file mode 100644 index 9be1e98fa4c0c28ca997ed660112fa16b194f0f5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3437 zcmcgvX>b$g8MY4FF(5FQyMT=#m||qU)nQ9cId-MBB-<-lvSdq&snM}IENNF>t+bK| zgowuF2vC|SxSZxNN5eHhV%(WPpbeB9Fc3;JDMtzMBv1-XAc2N~c2_tCXW&OCGw6qQ z-s9VS-tT?h=bI0tMS+~WDXqHJyCPmLzdbE-fV8Nd&*MRZfG8(#POFZG3xs@Lb{0ry z=R8j3wWo!5g=yjKx#BoZMFS)uA)H}cTp@-^K`9VV?RC3J59@}eik*>n|pRKOLZ zxdn7G!Yv@9O#y<&eUy{)vMXb;fQR)ffVAADQsEMXm;IBMDLfLD0w^U;6%HVo-0Q_5 zCHEa?DBuauNpZzoF+tK27w#n~?u%toS-DhR4k@Q*{7x^8Q=D6&kd^_~J#VVG2LXkL zaAy=}U*?Jto)9hx5MGjdp9hcQAu@tfk_;l!PeyxPY<8b&+&D!CyaBh9=8BSVKLpk4 z4Ml3yY|&Th)vyK4cpC{!uU8v2YBlVV`d~(nz&<@{G1oe*DHub1z7~J5*;s2bX<)_* zV_GbsPQg`(&rpxRb_*Od7}++3+liSw-$!1 zs5*g}EHWhI3i|!-FcfzYL0`SL-rq>LENC;PMl)G(0(1U2%Va|smp0UFx0xd@soZA* zD5LYc4OlbE7@ARt#h}rr3>K@bf%B#^-c+xz8Hr)0D5ExIFltezN@Hn8>o5d~bSfYtkc+_Z&kI#-N5_GhCg*V-^TSO=!G~ z(fXy{n2XV+k}6w_W`dTOP2a4u0ly;ANZ>4OxSKAzFB!yBzdo`gX zO?o|H@WiAw$y6l?=^3jA_Hy0S)nTYs12;4hKE&ekQ|>?|ZLJ}#F`2BczC7kdE4@xV zZBD_)Otwjhz+NSaz?d45!;FsGSu-#qh#hStD%B}f!mCT!KqzSo>I`NGH_9Dea$1Qi zg29Ydt!~lQVR99_T7#Hije~(12drl-P)SV?QR*9sus`8th-8^OQ7@xI$(Yp|^;bL1 zR50O$mDXw6P>i7B(TJ)ciPzTE>XY%X6HAa)b#OBRXv&~%Bw|J#Y><i4=e%95bjtw|cJp=#P#Pf#*luqI_wR;fISDCJhAqSG6R%xItn%~QtZ@m%&u zjGGLX;t6Ls62eQvNmf@v+}J%54^CygxRZ`?8X#r|wkev7(s;Ou4T#y1XNNf)h;o7z z8a^Lfq<1uH`E{G9E z*(=)Css_LSk=>E9jr)s5^2-!+MN=Ds}>1hRma4`uCIz9%p3O77839E{xf z4c_I?**|1`K2tg4!Hvyrou4BsJQuv*UfF)<%CelYIS>D^o?X)3+MK%la6kooW8&G@BU)Y0hT`+mOm$Z_%rB=a%o>I z!2c6lHyKQN)VjiFwa!eE^p8jc$sy$vB+8i25lI~6KPFFh$!o$avA~rj#L6xvR|Z83 z*WD6T9e+5Pyy=F+)pNTf{ny3cy>7Rkd3o*TS?TZJ`NS^NF2%HMkyS{?uJ$`!P4_L^ z1`NFDUbNyg_qREifgktnp1_v{Jbb`7m}2PTyUdOmtJj~m z9bB=ecw4_^rw1IW=of+>nrW5=d3k`3qHCxsIN_F{T1A545};;+fsyC&qChi+YV zr~M63H8ZLCPYmsjY>ls9cL%I)F|JIW-#+48$+lD4k*(P*kDM%zx_fvu4u5ZYUnI}5 zdrycFq>xFU)&X3p@pP2u%$o}}YcRn(MhJ&B2o?KS@cIVz>Ye%o^xV?CB{_Qhu z;}_q1bvO^g{8<3!gYbo4Di{8qzV+(9 zdlmksohQmRTs@qB;(Wo?dER_ux6XQb@q$tQPW?CMu6GVQd;R=iR;-S{Kr%Zks7>b1 zNs{|-+jhObYE}NR&`TGGr^h^4bjh%c>R#@=8nM&Md>_a+zVulsl;){flFekV1t9ob z+SqfV_Pv3$2f)bQ8%Ul2>fdYR^1zs0BQF~olsOj5AodC&Q_7SMFzsz2 z9newxE&jodk~tNHwl%LBMMDbrk=(^b diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/config.json b/multimedia/media/media_js_standard/audioEncoder/src/main/config.json deleted file mode 100644 index 04226482d..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/config.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "app": { - "apiVersion": { - "compatible": 6, - "releaseType": "Beta1", - "target": 7 - }, - "vendor": "acts", - "bundleName": "ohos.acts.multimedia.audio.audioencoder", - "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.audioencoder.MainAbility", - "description": "$string:mainability_description", - "label": "$string:entry_MainAbility", - "type": "page", - "homeAbility": true, - "launchType": "standard" - } - ], - "deviceType": [ - "phone", - "tablet", - "tv", - "wearable" - ], - "mainAbility": "ohos.acts.multimedia.audio.audioencoder.MainAbility", - "distro": { - "moduleType": "entry", - "installationFree": false, - "deliveryWithInstall": true, - "moduleName": "entry" - }, - "package": "ohos.acts.multimedia.audio.audioencoder", - "name": ".MyApplication", - "js": [ - { - "pages": [ - "pages/index/index" - ], - "name": "default", - "window": { - "designWidth": 720, - "autoDesignWidth": true - } - } - ] - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/app.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/app.js deleted file mode 100644 index 830070d19..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/app.js +++ /dev/null @@ -1,23 +0,0 @@ -/* - * 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'); - } -}; diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/en-US.json b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/en-US.json deleted file mode 100644 index e63c70d97..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/en-US.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "Hello", - "world": "World" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/zh-CN.json b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/zh-CN.json deleted file mode 100644 index de6ee5748..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/i18n/zh-CN.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "您好", - "world": "世界" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.css b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.css deleted file mode 100644 index 9f1321a1d..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.css +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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; - } -} diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.hml b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.hml deleted file mode 100644 index 689212399..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.hml +++ /dev/null @@ -1,20 +0,0 @@ - - -
- - {{ $t('strings.hello') }} {{ title }} - -
diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.js deleted file mode 100644 index 67f8b8567..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/default/pages/index/index.js +++ /dev/null @@ -1,41 +0,0 @@ -/* - * 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 diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncCallbackTest.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncCallbackTest.test.js deleted file mode 100644 index 63fbf83af..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncCallbackTest.test.js +++ /dev/null @@ -1,798 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioEncoderFuncCallback', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/' - const AUDIOPATH = RESOURCEPATH + 'S16LE.pcm'; - const BASIC_PATH = RESOURCEPATH + 'results/encode_func_callback_'; - let audioEncodeProcessor; - let readStreamSync; - let eosframenum = 0; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - const ES = [0, 4096]; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioEncodeProcessor = null; - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES_LENGTH = 1500; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioEncodeProcessor != null) { - await audioEncodeProcessor.release().then(() => { - console.info('audioEncodeProcessor release success'); - audioEncodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - function resetParam() { - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needrelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeHead(path, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let head = new ArrayBuffer(7); - addADTStoPacket(head, len); - let num = writestream.writeSync(head, {length:7}); - console.info(' writeSync head num = ' + num); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - - function readFile(path) { - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - function addADTStoPacket(head, len) { - let view = new Uint8Array(head) - console.info("start add ADTS to Packet"); - let packetLen = len + 7; // 7: head length - let profile = 2; // 2: AAC LC - let freqIdx = 4; // 4: 44100HZ - let chanCfg = 2; // 2: 2 channel - view[0] = 0xFF; - view[1] = 0xF9; - view[2] = ((profile - 1) << 6) + (freqIdx << 2) + (chanCfg >> 2); - view[3] = ((chanCfg & 3) << 6) + (packetLen >> 11); - view[4] = (packetLen & 0x7FF) >> 3; - view[5] = ((packetLen & 7) << 5) + 0x1F; - view[6] = 0xFC; - } - - async function stopWork() { - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success") - }) - } - - async function resetWork() { - resetParam(); - audioEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info("case reset success"); - if (needrelease) { - audioEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info("case release success"); - audioEncodeProcessor = null; - }) - } - }) - } - - async function flushWork() { - inputQueue = []; - outputQueue = []; - audioEncodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }) - } - - async function doneWork(done) { - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success"); - resetParam(); - audioEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - audioEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioEncodeProcessor = null; - done(); - }) - }) - }) - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1) { - console.info("EOS frame seperately") - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[1]; - getContent(inputobject.data, ES[1]); - inputobject.flags = 0; - } - timestamp += 23; - frameCnt += 1; - audioEncodeProcessor.pushInputData(inputobject, () => { - console.info('queueInput success'); - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (stopAtEOS) { - await stopWork(); - } else if (resetAtEOS) { - await resetWork(); - } else if (flushAtEOS) { - await flushWork(); - } else if (workdoneAtEOS) { - await doneWork(done); - } else { - console.info("sawOutputEOS = true"); - } - } - else{ - writeHead(savepath, outputobject.length); - writeFile(savepath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioEncodeProcessor.freeOutputBuffer(outputobject, () => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioEncodeProcessor.on('needInputData', async(inBuffer) => { - console.info('case inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('case outputBufferAvailable'); - if (needGetMediaDes) { - audioEncodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - expect(err).assertUndefined(); - console.info("case get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }); - } - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioEncodeProcessor.on('streamChanged',(format) => { - console.info('case Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_00_0100 - * @tc.name : 000.test set EOS after last frame and reset - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_00_0100', 0, async function (done) { - console.info("test set EOS after last frame and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let mediaDescription2 = { - "codec_mime": 'audio/mp4a-latm', - } - let savepath = BASIC_PATH + '0000.aac'; - needGetMediaDes = true; - workdoneAtEOS = true; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, AudioCaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info(`AudioCaps: ` + AudioCaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.getMediaCapability((err, mediaCaps) => { - expect(err).assertUndefined(); - console.info(`case getMediaCapability 1`); - mediaCaps.getAudioEncoderCaps((err, audioCaps) => { - expect(err).assertUndefined(); - console.info('getAudioDecoderCaps success'); - if (typeof (audioCaps) != 'undefined') { - console.info("case audioCaps " + audioCaps); - } else { - console.info("case audioCaps is not defined"); - } - }) - mediaCaps.findAudioEncoder(mediaDescription2, (err, codecname) => { - expect(err).assertUndefined(); - console.info('findAudioEncoder success'); - if (typeof (codecname) != 'undefined') { - console.info("case codecname " + codecname); - } else { - console.info("case codecname is not defined"); - } - }) - }) - media.createAudioEncoderByName('avenc_aac', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder by mime 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0100 - * @tc.name : 001.test set EOS manually before last frame and reset - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0100', 0, async function (done) { - console.info("case test set EOS manually before last frame and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0100.aac'; - eosframenum = 500; - workdoneAtEOS = true; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0200 - * @tc.name : 002.test flush at running state - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0200', 0, async function (done) { - console.info("case test flush at running state"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0200.aac'; - workdoneAtEOS = true; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - setTimeout(() => {eventEmitter.emit('flush')},5000) - }) - }); - eventEmitter.on('flush', () => { - inputQueue = []; - outputQueue = []; - audioEncodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info(`case flush after 5s`); - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0300 - * @tc.name : 003. test flush at EOS state - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0300', 0, async function (done) { - console.info("case test flush at EOS state"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0300.aac'; - eosframenum = 500; - flushAtEOS = true; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0400 - * @tc.name : 004.test stop at running state and reset - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0400', 0, async function (done) { - console.info("case test stop at running state and reset"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0400.aac'; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - eventEmitter.emit('stop'); - }) - }); - eventEmitter.on('stop', () => { - sleep(5000).then(() => { - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`case stop 1`); - eventEmitter.emit('reset'); - }) - }) - }); - eventEmitter.on('reset', () => { - resetParam(); - audioEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info(`case reset 1`); - eventEmitter.emit('release'); - }) - }); - eventEmitter.on('release', () => { - audioEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info(`case release 1`); - audioEncodeProcessor = null; - done(); - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0500 - * @tc.name : 005.test stop and restart - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0500', 0, async function (done) { - console.info("case test stop and restart"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0500.aac'; - eosframenum = 100; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - eventEmitter.emit('stop'); - }) - }); - eventEmitter.on('stop', () => { - sleep(5000).then(() => { - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`stop after 5s`); - resetParam(); - readFile(AUDIOPATH); - eventEmitter.emit('restart'); - }) - }) - }); - eventEmitter.on('restart', () => { - sleep(2000).then(() => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`restart after 2s`); - workdoneAtEOS = true; - enqueueAllInputs(inputQueue); - }) - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0600 - * @tc.name : 006.test reconfigure for new file with the same format - * @tc.desc : basic Encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_CALLBACK_01_0600', 0, async function (done) { - console.info("case test reconfigure for new file with the same format"); - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0600.aac'; - eosframenum = 100; - resetAtEOS = true; - let mediaDescription2 = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let hasreconfigured = false; - eventEmitter.on('getAudioEncoderCaps', () => { - audioEncodeProcessor.getAudioEncoderCaps((err, Audiocaps) => { - expect(err).assertUndefined(); - console.info(`case getAudioEncoderCaps 1`); - console.info("AudioCaps: " + Audiocaps); - eventEmitter.emit('configure', mediaDescription); - }) - }); - eventEmitter.on('configure', (mediaDescription) => { - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - setCallback(savepath, done); - eventEmitter.emit('start'); - }) - }); - eventEmitter.on('start', () => { - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - if (!hasreconfigured) { - eventEmitter.emit('reconfigure', mediaDescription2); - } - }) - }); - eventEmitter.on('reconfigure', (mediaDescription2) => { - sleep(10000).then(() => { - audioEncodeProcessor.configure(mediaDescription2, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 2`); - resetParam(); - readFile(AUDIOPATH) - savepath = BASIC_PATH + '0601.aac'; - workdoneAtEOS = true; - hasreconfigured = true; - eventEmitter.emit('prepare'); - }) - }) - }); - media.createAudioEncoderByMime('audio/mp4a-latm', (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - eventEmitter.emit('getAudioEncoderCaps'); - }) - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncPromiseTest.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncPromiseTest.test.js deleted file mode 100644 index 80fae451b..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderFuncPromiseTest.test.js +++ /dev/null @@ -1,649 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioEncoderFuncPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/' - const AUDIOPATH = RESOURCEPATH + 'S16LE.pcm'; - const BASIC_PATH = RESOURCEPATH + 'results/encode_func_promise_'; - let audioEncodeProcessor; - let readStreamSync; - let eosframenum = 0; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needgetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - const ES = [0, 4096]; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioEncodeProcessor = null; - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needgetMediaDes = false; - needrelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES_LENGTH = 1500; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioEncodeProcessor != null) { - await audioEncodeProcessor.release().then(() => { - console.info('audioEncodeProcessor release success'); - audioEncodeProcessor = null; - }, failCallback).catch(failCatch); - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needgetMediaDes = false; - needrelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeHead(path, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let head = new ArrayBuffer(7); - addADTStoPacket(head, len); - let num = writestream.writeSync(head, {length:7}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - - function readFile(path) { - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - function addADTStoPacket(head, len) { - let view = new Uint8Array(head); - console.info("start add ADTS to Packet"); - let packetLen = len + 7; // 7: head length - let profile = 2; // 2: AAC LC - let freqIdx = 4; // 4: 44100HZ - let chanCfg = 2; // 2: 2 channel - view[0] = 0xFF; - view[1] = 0xF9; - view[2] = ((profile - 1) << 6) + (freqIdx << 2) + (chanCfg >> 2); - view[3] = ((chanCfg & 3) << 6) + (packetLen >> 11); - view[4] = (packetLen & 0x7FF) >> 3; - view[5] = ((packetLen & 7) << 5) + 0x1F; - view[6] = 0xFC; - } - - async function stopWork() { - await audioEncodeProcessor.stop().then(() => { - console.info("case stop success") - }, failCallback).catch(failCatch); - } - - async function resetWork() { - resetParam(); - await audioEncodeProcessor.reset().then(async() => { - console.info("case reset success"); - if (needrelease) { - await audioEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - }, failCallback).catch(failCatch); - } - - async function flushWork() { - inputQueue = []; - outputQueue = []; - await audioEncodeProcessor.flush().then(() => { - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }, failCallback).catch(failCatch); - } - - async function doneWork() { - await audioEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now();Date.now() - t <= time;); - } - - async function enqueueInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - console.info("case frameCnt:" + frameCnt); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1) { - console.info("case EOS frame seperately") - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[1]; - getContent(inputobject.data, ES[1]); - inputobject.flags = 0; - } - timestamp += 23; - frameCnt += 1; - audioEncodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (stopAtEOS) { - await stopWork(); - } else if (resetAtEOS) { - await resetWork(); - } else if (flushAtEOS) { - await flushWork(); - } else if (workdoneAtEOS) { - await doneWork(); - done(); - } else { - console.info('sawOutputEOS = true'); - } - } - else{ - writeHead(savepath, outputobject.length); - writeFile(savepath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioEncodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioEncodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueInputs(inputQueue); - }); - audioEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needgetMediaDes) { - audioEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needgetMediaDes=false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - await dequeueOutputs(outputQueue, savepath, done); - }); - audioEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_00_0100 - * @tc.name : 000.test set EOS after last frame and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_00_0100', 0, async function (done) { - console.info("case test set EOS after last frame and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let mediaDescription2 = { - "codec_mime": 'audio/mp4a-latm', - } - let savepath = BASIC_PATH + '0000.aac'; - needgetMediaDes = true; - workdoneAtEOS = true; - await media.getMediaCapability().then((mediaCaps) => { - console.info('getMediaCapability success'); - if (typeof (mediaCaps) != 'undefined') { - mediaCaps.getAudioEncoderCaps().then((audioCaps) => { - console.info('getAudioEncoderCaps success'); - if (typeof (audioCaps) != 'undefined') { - console.info("case audioCaps " + audioCaps); - } else { - console.info("case audioCaps is not defined"); - } - }, failCallback).catch(failCatch); - mediaCaps.findAudioEncoder(mediaDescription2).then((codecname) => { - console.info('getAudioEncoderCaps success'); - if (typeof (codecname) != 'undefined') { - console.info("case codecname " + codecname); - } else { - console.info("case codecname is not defined"); - } - }, failCallback).catch(failCatch); - } else { - console.info('mediaCaps is not defined'); - } - }, failCallback).catch(failCatch); - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps) - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success") - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0100 - * @tc.name : 001.test set EOS manually before last frame and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0100', 0, async function (done) { - console.info("case test set EOS manually before last frame and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0100.aac'; - eosframenum = 500; - workdoneAtEOS = true; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0200 - * @tc.name : 002.test flush at running state - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0200', 0, async function (done) { - console.info("case test flush at running state"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0200.aac'; - workdoneAtEOS = true; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps) - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH) - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success") - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success") - }, failCallback).catch(failCatch); - await sleep(5000).then(() => { - inputQueue = []; - outputQueue = []; - audioEncodeProcessor.flush().then(() => { - console.info("case flush after 5s") - }, failCallback).catch(failCatch); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0300 - * @tc.name : 003.test flush at EOS state - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0300', 0, async function (done) { - console.info("case test flush at EOS state"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0300.aac'; - eosframenum = 500; - flushAtEOS = true; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0400 - * @tc.name : 004.test stop at running state and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0400', 0, async function (done) { - console.info("case test stop at running state and reset"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0400.aac'; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(5000).then(() => { - audioEncodeProcessor.stop().then(() => { - console.info("stop after 5s success"); - }, failCallback).catch(failCatch);}); - resetParam(); - await audioEncodeProcessor.reset().then(() => { - console.info("reset success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0500 - * @tc.name : 005.test stop and restart - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0500', 0, async function (done) { - console.info("case test stop and restart"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0500.aac'; - eosframenum = 100; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await sleep(5000).then(() => { - console.info("stop encoding after 5s"); - }); - await audioEncodeProcessor.stop().then(() => { - console.info("case stop after 5s success"); - }, failCallback).catch(failCatch); - await sleep(2000).then(() => { - console.info("restart encoding after 2s"); - resetParam(); - readFile(AUDIOPATH); - }); - await audioEncodeProcessor.start().then(() => { - console.info("case restart after 3s success"); - workdoneAtEOS = true; - enqueueInputs(inputQueue); - }, failCallback).catch(failCatch); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0600 - * @tc.name : 006.test reconfigure for new file with the same format - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_AUDIO_ENCODER_FUNCTION_PROMISE_01_0600', 0, async function (done) { - console.info("case test reconfigure for new file with the same format"); - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - let savepath = BASIC_PATH + '0600.aac'; - eosframenum = 100; - resetAtEOS = true; - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - console.info("case create createAudioEncoder success"); - audioEncodeProcessor = processor; - }, failCallback).catch(failCatch); - await audioEncodeProcessor.getAudioEncoderCaps().then((AudioCaps) => { - console.info("case get AudioEncoderCaps success"); - console.info("print AudioCaps: " + AudioCaps); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - setCallback(savepath, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - let mediaDescription2 = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - } - await sleep(10000).then(() => { - console.info("start configure 2"); - }); - await audioEncodeProcessor.configure(mediaDescription2).then(() => { - console.info("configure 2 success"); - resetParam(); - readFile(AUDIOPATH); - }, failCallback).catch(failCatch); - let savepath2 = BASIC_PATH + '0601.aac'; - workdoneAtEOS = true; - setCallback(savepath2, done); - await audioEncodeProcessor.prepare().then(() => { - console.info("prepare2 success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.start().then(() => { - console.info("start2 success"); - }, failCallback).catch(failCatch); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderMultiInstancesTest.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderMultiInstancesTest.test.js deleted file mode 100644 index 3a110986a..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderMultiInstancesTest.test.js +++ /dev/null @@ -1,322 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioEncoderFuncPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/' - const AUDIOPATH = RESOURCEPATH + 'S16LE.pcm'; - let readStreamSync; - let eosframenum = 0; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needgetMediaDes = false; - let needrelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - const ES = [0, 4096]; - let ES_LENGTH = 1500; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needgetMediaDes = false; - needrelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES_LENGTH = 1500; - }) - - afterEach(function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - eosframenum = 0; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - workdoneAtEOS = false; - needgetMediaDes = false; - needrelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function writeHead(path, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let head = new ArrayBuffer(7); - addADTStoPacket(head, len); - let num = writestream.writeSync(head, {length:7}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - - function readFile(path) { - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - function addADTStoPacket(head, len) { - let view = new Uint8Array(head); - console.info("start add ADTS to Packet"); - let packetLen = len + 7; // 7: head length - let profile = 2; // 2: AAC LC - let freqIdx = 4; // 4: 44100HZ - let chanCfg = 2; // 2: 2 channel - view[0] = 0xFF; - view[1] = 0xF9; - view[2] = ((profile - 1) << 6) + (freqIdx << 2) + (chanCfg >> 2); - view[3] = ((chanCfg & 3) << 6) + (packetLen >> 11); - view[4] = (packetLen & 0x7FF) >> 3; - view[5] = ((packetLen & 7) << 5) + 0x1F; - view[6] = 0xFC; - } - - async function stopWork(audioEncodeProcessor) { - await audioEncodeProcessor.stop().then(() => { - console.info("case stop success") - }, failCallback).catch(failCatch); - } - - async function resetWork(audioEncodeProcessor) { - resetParam(); - await audioEncodeProcessor.reset().then(async() => { - console.info("case reset success"); - if (needrelease) { - await audioEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - }, failCallback).catch(failCatch); - } - - async function flushWork(audioEncodeProcessor) { - inputQueue = []; - outputQueue = []; - await audioEncodeProcessor.flush().then(() => { - console.info("case flush at inputeos success"); - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS =true; - }, failCallback).catch(failCatch); - } - - async function doneWork(audioEncodeProcessor) { - await audioEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now();Date.now() - t <= time;); - } - - async function enqueueInputs(audioEncodeProcessor, queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - console.info("case frameCnt:" + frameCnt); - if (frameCnt == eosframenum || frameCnt == ES_LENGTH + 1) { - console.info("case EOS frame separately") - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES[1]; - getContent(inputobject.data, ES[1]); - inputobject.flags = 0; - } - timestamp += 23; - frameCnt += 1; - audioEncodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueOutputs(audioEncodeProcessor, queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (stopAtEOS) { - await stopWork(audioEncodeProcessor); - } else if (resetAtEOS) { - await resetWork(audioEncodeProcessor); - } else if (flushAtEOS) { - await flushWork(audioEncodeProcessor); - } else if (workdoneAtEOS) { - await doneWork(audioEncodeProcessor); - done(); - } else { - console.info('sawOutputEOS = true'); - } - } - else{ - writeHead(savepath, outputobject.length); - writeFile(savepath, outputobject.data, outputobject.length); - console.info("write to file success"); - } - audioEncodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(audioEncodeProcessor, savepath, done) { - console.info('case callback'); - audioEncodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueInputs(audioEncodeProcessor, inputQueue); - }); - audioEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needgetMediaDes) { - audioEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needgetMediaDes=false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - await dequeueOutputs(audioEncodeProcessor, outputQueue, savepath, done); - }); - audioEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_MULTIINSTANCE_0100 - * @tc.name : 001.create multiple encoder2 - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_MULTIINSTANCE_0100', 0, async function (done) { - console.info("case test multiple encoder instances"); - let array = new Array(); - for (let i = 0; i < 2; i += 1) { - await media.createAudioEncoderByMime('audio/mp4a-latm').then((processor) => { - if (typeof(processor) != 'undefined') { - console.info("case create createAudioEncoder success: " + i); - array[i] = processor; - } else { - console.info("case create createAudioEncoder failed: " + i); - } - }, failCallback).catch(failCatch); - } - console.info('case has created multiple encoders'); - for (let j = 0; j < 2; j++) { - resetParam(); - await array[j].reset().then(() => { - console.info("reset encoder " + j); - }, failCallback).catch(failCatch); - await array[j].release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - array[j] = null; - } - done(); - }) -}) - - \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityCallbackTest.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityCallbackTest.test.js deleted file mode 100644 index d57b46afb..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityCallbackTest.test.js +++ /dev/null @@ -1,1196 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioEncoderReliabilityCallback', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/' - const AUDIOPATH = RESOURCEPATH + 'S16LE.pcm'; - const BASIC_PATH = RESOURCEPATH + 'results/encode_reliability_callback_'; - const END = 0; - const CONFIGURE = 1; - const PREPARE = 2; - const START = 3; - const FLUSH = 4; - const STOP = 5; - const RESET = 6; - const HOLDON = 7; - const WAITFORALLOUTS = 8; - const CONFIGURE_ERROR = 9; - const PREPARE_ERROR = 10; - const START_ERROR = 11; - const FLUSH_ERROR = 12; - const STOP_ERROR = 13; - const JUDGE_EOS = 14; - const WAITTIME = 3000; - let audioEncodeProcessor; - let readStreamSync; - let EOSFrameNum = 0; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needRelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - const ES_SIZE = [0, 4096]; - let ES_LENGTH = 200; - let mime = 'audio/mp4a-latm'; - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - }; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioEncodeProcessor = null; - readStreamSync = undefined; - EOSFrameNum = 0; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needRelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES_LENGTH = 200; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioEncodeProcessor != null) { - await audioEncodeProcessor.release().then(() => { - console.info('audioEncodeProcessor release success'); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - function resetParam() { - readStreamSync = undefined; - EOSFrameNum = 0; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needRelease = false; - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function createAudioEncoder(savepath, mySteps, done) { - media.createAudioEncoderByMime(mime, (err, processor) => { - expect(err).assertUndefined(); - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - setCallback(savepath, done); - console.info("case start api test"); - nextStep(mySteps, mediaDescription, done); - }) - } - - function writeHead(path, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let head = new ArrayBuffer(7); - addADTStoPacket(head, len); - let num = writestream.writeSync(head, {length:7}); - console.info(' writeSync head num = ' + num); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - - function readFile(path) { - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - function addADTStoPacket(head, len) { - let view = new Uint8Array(head) - console.info("start add ADTS to Packet"); - let packetLen = len + 7; // 7: head length - let profile = 2; // 2: AAC LC - let freqIdx = 4; // 4: 44100HZ - let chanCfg = 2; // 2: 2 channel - view[0] = 0xFF; - view[1] = 0xF9; - view[2] = ((profile - 1) << 6) + (freqIdx << 2) + (chanCfg >> 2); - view[3] = ((chanCfg & 3) << 6) + (packetLen >> 11); - view[4] = (packetLen & 0x7FF) >> 3; - view[5] = ((packetLen & 7) << 5) + 0x1F; - view[6] = 0xFC; - } - - async function doneWork(done) { - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info("case stop success"); - resetParam(); - audioEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.log("case reset success"); - audioEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioEncodeProcessor = null; - done(); - }) - }) - }) - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - function nextStep(mySteps, mediaDescription, done) { - console.info("case myStep[0]: " + mySteps[0]); - if (mySteps[0] == END) { - audioEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.log("case release success"); - audioEncodeProcessor = null; - done(); - }) - } - switch (mySteps[0]) { - case CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - readFile(AUDIOPATH); - nextStep(mySteps, mediaDescription, done); - }); - break; - case PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - audioEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info(`case prepare 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case START: - mySteps.shift(); - console.info(`case to start`); - if (sawOutputEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - enqueueAllInputs(inputQueue); - } - audioEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info(`case start 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case FLUSH: - mySteps.shift(); - console.info(`case to flush`); - inputQueue = []; - outputQueue = []; - audioEncodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info(`case flush 1`); - if (flushAtEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - flushAtEOS = false; - } - nextStep(mySteps, mediaDescription, done); - }); - break; - case STOP: - mySteps.shift(); - console.info(`case to stop`); - audioEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`case stop 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case RESET: - mySteps.shift(); - console.info(`case to reset`); - resetParam(); - audioEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info(`case reset 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case HOLDON: - mySteps.shift(); - setTimeout(() =>{ - nextStep(mySteps, mediaDescription, done); - }, WAITTIME); - break; - case WAITFORALLOUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - case CONFIGURE_ERROR: - mySteps.shift(); - console.info(`case to configure`); - audioEncodeProcessor.configure(mediaDescription, (err) => { - expect(err != undefined).assertTrue(); - console.info(`case configure error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case PREPARE_ERROR: - mySteps.shift(); - console.info(`case to prepare`); - audioEncodeProcessor.prepare((err) => { - expect(err != undefined).assertTrue(); - console.info(`case prepare error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case START_ERROR: - mySteps.shift(); - console.info(`case to start`); - audioEncodeProcessor.start((err) => { - expect(err != undefined).assertTrue(); - console.info(`case start error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case FLUSH_ERROR: - mySteps.shift(); - console.info(`case to flush`); - audioEncodeProcessor.flush((err) => { - expect(err != undefined).assertTrue(); - console.info(`case flush error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case STOP_ERROR: - mySteps.shift(); - console.info(`case to stop`); - audioEncodeProcessor.stop((err) => { - expect(err != undefined).assertTrue(); - console.info(`case stop error 1`); - nextStep(mySteps, mediaDescription, done); - }); - break; - case JUDGE_EOS: - mySteps.shift(); - console.info(`case judge EOS state`); - expect(sawOutputEOS).assertTrue(); - nextStep(mySteps, mediaDescription, done); - break; - default: - break; - } - } - - async function enqueueAllInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - if (frameCnt == EOSFrameNum || frameCnt == ES_LENGTH + 1) { - console.info("EOS frame seperately") - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES_SIZE[1]; - getContent(inputobject.data, ES_SIZE[1]); - inputobject.flags = 0; - } - timestamp += 23; - frameCnt += 1; - audioEncodeProcessor.pushInputData(inputobject, () => { - console.info('queueInput success'); - }) - } - } - - async function dequeueAllOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (workdoneAtEOS) { - await doneWork(done); - } else { - console.info("sawOutputEOS = true"); - } - } - else{ - console.info("not last frame, continue"); - } - audioEncodeProcessor.freeOutputBuffer(outputobject, () => { - console.info('release output success'); - }) - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioEncodeProcessor.on('needInputData', async(inBuffer) => { - console.info('case inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueAllInputs(inputQueue); - }); - audioEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('case outputBufferAvailable'); - if (needGetMediaDes) { - audioEncodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - expect(err).assertUndefined(); - console.info("case get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }); - } - outputQueue.push(outBuffer); - await dequeueAllOutputs(outputQueue, savepath, done); - }); - audioEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioEncodeProcessor.on('streamChanged',(format) => { - console.info('case Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0100 - * @tc.name : 001.create -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0100.es'; - let mySteps = new Array(CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0300 - * @tc.name : 003.start -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, CONFIGURE_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0700.es'; - let mySteps = new Array(RESET, CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0800.es'; - let mySteps = new Array(CONFIGURE, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_CALLBACK_0900', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0900.es'; - let mySteps = new Array(CONFIGURE, RESET, CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0100.es'; - let mySteps = new Array(PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, PREPARE_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0100 - * @tc.name : 001.create -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0100.es'; - let mySteps = new Array(START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0200 - * @tc.name : 002.configure -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0200.es'; - let mySteps = new Array(CONFIGURE, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0400 - * @tc.name : 004.start -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0500 - * @tc.name : 005.flush -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0600 - * @tc.name : 006.stop -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, START_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0800 - * @tc.name : 008.reset -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0100 - * @tc.name : 001.create -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0100.es'; - let mySteps = new Array(FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0200.es'; - let mySteps = new Array(CONFIGURE, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0400 - * @tc.name : 004.start -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, FLUSH, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0100 - * @tc.name : 001.create -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0100.es'; - let mySteps = new Array(STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0200.es'; - let mySteps = new Array(CONFIGURE, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0400 - * @tc.name : 004.start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, STOP, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0100 - * @tc.name : 001.create -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0100.es'; - let mySteps = new Array(RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0200.es'; - let mySteps = new Array(CONFIGURE, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0400 - * @tc.name : 004.start -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_CALLBACK_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0100.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, WAITFORALLOUTS); - EOSFrameNum = 2; - flushAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, CONFIGURE, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, WAITFORALLOUTS); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_CALLBACK_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityPromiseTest.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityPromiseTest.test.js deleted file mode 100644 index fc584e3a8..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/AudioEncoderReliabilityPromiseTest.test.js +++ /dev/null @@ -1,1200 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('AudioEncoderReliabilityPromise', function () { - const RESOURCEPATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.audio.audioencoder/' - const AUDIOPATH = RESOURCEPATH + 'S16LE.pcm'; - const BASIC_PATH = RESOURCEPATH + 'results/encode_reliability_promise_'; - const END = 0; - const CONFIGURE = 1; - const PREPARE = 2; - const START = 3; - const FLUSH = 4; - const STOP = 5; - const RESET = 6; - const HOLDON = 7; - const WAITFORALLOUTS = 8; - const CONFIGURE_ERROR = 9; - const PREPARE_ERROR = 10; - const START_ERROR = 11; - const FLUSH_ERROR = 12; - const STOP_ERROR = 13; - const JUDGE_EOS = 14; - const WAITTIME = 3000; - let audioEncodeProcessor; - let readStreamSync; - let EOSFrameNum = 0; - let flushAtEOS = false; - let workdoneAtEOS = false; - let needGetMediaDes = false; - let needRelease = false; - let frameCnt = 1; - let timestamp = 0; - let sawInputEOS = false; - let sawOutputEOS = false; - let inputQueue = []; - let outputQueue = []; - const ES_SIZE = [0, 4096]; - let ES_LENGTH = 200; - let mime = 'audio/mp4a-latm'; - let mediaDescription = { - "channel_count": 2, - "sample_rate": 44100, - "audio_sample_format": 1, - }; - let expectError = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - audioEncodeProcessor = null; - readStreamSync = undefined; - EOSFrameNum = 0; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needRelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - ES_LENGTH = 200; - expectError = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (audioEncodeProcessor != null) { - await audioEncodeProcessor.release().then(() => { - console.info('audioEncodeProcessor release success'); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCallbackTrue = function(err, mySteps, done) { - console.info('case callback err : ' + err); - expect(err != undefined).assertTrue(); - nextStep(mySteps, done); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - readStreamSync = undefined; - EOSFrameNum = 0; - flushAtEOS = false; - workdoneAtEOS = false; - needGetMediaDes = false; - needRelease = false - frameCnt = 1; - timestamp = 0; - sawInputEOS = false; - sawOutputEOS = false; - inputQueue = []; - outputQueue = []; - } - - function createAudioEncoder(savepath, mySteps, done) { - media.createAudioEncoderByMime(mime).then((processor) => { - console.info(`case createAudioEncoder 1`); - audioEncodeProcessor = processor; - setCallback(savepath, done); - console.info("case start api test"); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - - function writeHead(path, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let head = new ArrayBuffer(7); - addADTStoPacket(head, len); - let num = writestream.writeSync(head, {length:7}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function writeFile(path, buf, len) { - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e); - } - } - - function readFile(path) { - try{ - console.info('filepath: ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info(e); - } - } - - function getContent(buf, len) { - console.info("case start get content"); - let lengthreal = -1; - lengthreal = readStreamSync.readSync(buf,{length:len}); - console.info('lengthreal: ' + lengthreal); - } - - function addADTStoPacket(head, len) { - let view = new Uint8Array(head); - console.info("start add ADTS to Packet"); - let packetLen = len + 7; // 7: head length - let profile = 2; // 2: AAC LC - let freqIdx = 4; // 4: 44100HZ - let chanCfg = 2; // 2: 2 channel - view[0] = 0xFF; - view[1] = 0xF9; - view[2] = ((profile - 1) << 6) + (freqIdx << 2) + (chanCfg >> 2); - view[3] = ((chanCfg & 3) << 6) + (packetLen >> 11); - view[4] = (packetLen & 0x7FF) >> 3; - view[5] = ((packetLen & 7) << 5) + 0x1F; - view[6] = 0xFC; - } - - async function doneWork() { - await audioEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - resetParam(); - await audioEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await audioEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - audioEncodeProcessor = null; - } - - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now();Date.now() - t <= time;); - } - - function nextStep(mySteps, done) { - console.info("case myStep[0]: " + mySteps[0]); - if (mySteps[0] == END) { - audioEncodeProcessor.release().then(() => { - console.info("case release success"); - audioEncodeProcessor = null; - done(); - }, failCallback).catch(failCatch); - } - switch (mySteps[0]) { - case CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure 1`); - readFile(AUDIOPATH); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - audioEncodeProcessor.prepare().then(() => { - console.info(`case prepare 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case START: - mySteps.shift(); - console.info(`case to start`); - if (sawOutputEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - enqueueInputs(inputQueue); - } - audioEncodeProcessor.start().then(() => { - console.info(`case start 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case FLUSH: - mySteps.shift(); - console.info(`case to flush`); - inputQueue = []; - outputQueue = []; - audioEncodeProcessor.flush().then(() => { - console.info(`case flush 1`); - if (flushAtEOS) { - resetParam(); - readFile(AUDIOPATH); - workdoneAtEOS = true; - flushAtEOS = false; - } - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case STOP: - mySteps.shift(); - console.info(`case to stop`); - audioEncodeProcessor.stop().then(() => { - console.info(`case stop 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case RESET: - mySteps.shift(); - console.info(`case to reset`); - resetParam(); - audioEncodeProcessor.reset().then(() => { - console.info(`case reset 1`); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - break; - case HOLDON: - mySteps.shift(); - setTimeout(() =>{ - nextStep(mySteps, done); - }, WAITTIME); - break; - case WAITFORALLOUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - case CONFIGURE_ERROR: - mySteps.shift(); - console.info(`case to configure 2`); - audioEncodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case PREPARE_ERROR: - mySteps.shift(); - console.info(`case to prepare 2`); - audioEncodeProcessor.prepare().then(() => { - console.info(`case prepare error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case START_ERROR: - mySteps.shift(); - console.info(`case to start 2`); - audioEncodeProcessor.start().then(() => { - console.info(`case start error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case FLUSH_ERROR: - mySteps.shift(); - console.info(`case to flush 2`); - audioEncodeProcessor.flush().then(() => { - console.info(`case flush error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case STOP_ERROR: - mySteps.shift(); - console.info(`case to stop 2`); - audioEncodeProcessor.stop().then(() => { - console.info(`case stop error 1`); - expect(expectError).assertTrue(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - break; - case JUDGE_EOS: - mySteps.shift(); - console.info(`case judge EOS state`); - expect(sawOutputEOS).assertTrue(); - nextStep(mySteps, done); - break; - default: - break; - } - } - - async function enqueueInputs(queue) { - while (queue.length > 0 && !sawInputEOS) { - let inputobject = queue.shift(); - console.info("case frameCnt:" + frameCnt); - if (frameCnt == EOSFrameNum || frameCnt == ES_LENGTH + 1) { - console.info("case EOS frame seperately") - inputobject.flags = 1; - inputobject.timeMs = 0; - inputobject.length = 0; - sawInputEOS = true; - } else { - console.info("case read frame from file"); - inputobject.timeMs = timestamp; - inputobject.offset = 0; - inputobject.length = ES_SIZE[1]; - getContent(inputobject.data, ES_SIZE[1]); - inputobject.flags = 0; - } - timestamp += 23; - frameCnt += 1; - audioEncodeProcessor.pushInputData(inputobject).then(() => { - console.info('case queueInput success'); - }); - } - } - - async function dequeueOutputs(queue, savepath, done) { - while (queue.length > 0 && !sawOutputEOS) { - let outputobject = queue.shift(); - if (outputobject.flags == 1) { - sawOutputEOS = true; - if (workdoneAtEOS) { - await doneWork(); - done(); - } else { - console.info('sawOutputEOS = true'); - } - } - else{ - console.info("not last frame, continue"); - } - audioEncodeProcessor.freeOutputBuffer(outputobject).then(() => { - console.info('release output success'); - }); - } - } - - function setCallback(savepath, done) { - console.info('case callback'); - audioEncodeProcessor.on('needInputData', async(inBuffer) => { - console.info('inputBufferAvailable'); - inputQueue.push(inBuffer); - await enqueueInputs(inputQueue); - }); - audioEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (needGetMediaDes) { - audioEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes=false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - await dequeueOutputs(outputQueue, savepath, done); - }); - audioEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - audioEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0100 - * @tc.name : 001.create -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0100.es'; - let mySteps = new Array(CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0300 - * @tc.name : 003.start -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, CONFIGURE_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0700.es'; - let mySteps = new Array(RESET, CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0800.es'; - let mySteps = new Array(CONFIGURE, CONFIGURE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_CONFIGURE_PROMISE_0900', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0900.es'; - let mySteps = new Array(CONFIGURE, RESET, CONFIGURE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0100.es'; - let mySteps = new Array(PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, PREPARE_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_PREPARE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, PREPARE_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0100 - * @tc.name : 001.create -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0100.es'; - let mySteps = new Array(START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0200 - * @tc.name : 002.configure -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0200.es'; - let mySteps = new Array(CONFIGURE, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0400 - * @tc.name : 004.start -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0500 - * @tc.name : 005.flush -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0600 - * @tc.name : 006.stop -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, START_ERROR, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0800 - * @tc.name : 008.reset -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_START_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, START_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0100 - * @tc.name : 001.create -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0100.es'; - let mySteps = new Array(FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0200.es'; - let mySteps = new Array(CONFIGURE, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0400 - * @tc.name : 004.start -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, FLUSH, WAITFORALLOUTS); - workdoneAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP ,FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, FLUSH, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_FLUSH_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, FLUSH_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0100 - * @tc.name : 001.create -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0100.es'; - let mySteps = new Array(STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0200.es'; - let mySteps = new Array(CONFIGURE, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0400 - * @tc.name : 004.start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, STOP, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_STOP_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, STOP_ERROR, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0100 - * @tc.name : 001.create -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0100.es'; - let mySteps = new Array(RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0200.es'; - let mySteps = new Array(CONFIGURE, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0400 - * @tc.name : 004.start -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, FLUSH, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0600.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, STOP, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0700.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_RESET_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0800.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, RESET, RESET, END); - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0100.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0200.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, FLUSH, WAITFORALLOUTS); - EOSFrameNum = 2; - flushAtEOS = true; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0300.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, RESET, CONFIGURE, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0400.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, WAITFORALLOUTS); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_AUDIO_ENCODER_API_EOS_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0500.es'; - let mySteps = new Array(CONFIGURE, PREPARE, START, HOLDON, JUDGE_EOS, STOP, START, STOP, END); - EOSFrameNum = 2; - createAudioEncoder(savepath, mySteps, done); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/List.test.js b/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/List.test.js deleted file mode 100644 index 45c9bbdb7..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/js/test/List.test.js +++ /dev/null @@ -1,20 +0,0 @@ -/* - * 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('./AudioEncoderFuncCallbackTest.test.js') -require('./AudioEncoderFuncPromiseTest.test.js') -require('./AudioEncoderReliabilityCallbackTest.test.js') -require('./AudioEncoderReliabilityPromiseTest.test.js') -require('./AudioEncoderMultiInstancesTest.test.js') \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/element/string.json b/multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/element/string.json deleted file mode 100644 index 0bae6bd40..000000000 --- a/multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/element/string.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "string": [ - { - "name": "entry_MainAbility", - "value": "entry_MainAbility" - }, - { - "name": "mainability_description", - "value": "JS_Empty Ability" - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/media/icon.png b/multimedia/media/media_js_standard/audioEncoder/src/main/resources/base/media/icon.png deleted file mode 100644 index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6790 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/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/", - "./resource/media/es/h263_1408_1152.es ->/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/", - "./resource/media/es/MPEG2_720_480.es ->/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/", - "./resource/media/es/mpeg4_320_240.es ->/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/", - "./resource/media/es/out_320_240_10s.h264 ->/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/" - ] - }, - { - "type": "ShellKit", - "run-command": [ - "chmod 777 -R /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder", - "chmod 777 /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/*" - ], - "teardown-command":[ - ] - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/signature/openharmony_sx.p7b b/multimedia/media/media_js_standard/videoDecoder/signature/openharmony_sx.p7b deleted file mode 100644 index 9be1e98fa4c0c28ca997ed660112fa16b194f0f5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3437 zcmcgvX>b$g8MY4FF(5FQyMT=#m||qU)nQ9cId-MBB-<-lvSdq&snM}IENNF>t+bK| zgowuF2vC|SxSZxNN5eHhV%(WPpbeB9Fc3;JDMtzMBv1-XAc2N~c2_tCXW&OCGw6qQ z-s9VS-tT?h=bI0tMS+~WDXqHJyCPmLzdbE-fV8Nd&*MRZfG8(#POFZG3xs@Lb{0ry z=R8j3wWo!5g=yjKx#BoZMFS)uA)H}cTp@-^K`9VV?RC3J59@}eik*>n|pRKOLZ zxdn7G!Yv@9O#y<&eUy{)vMXb;fQR)ffVAADQsEMXm;IBMDLfLD0w^U;6%HVo-0Q_5 zCHEa?DBuauNpZzoF+tK27w#n~?u%toS-DhR4k@Q*{7x^8Q=D6&kd^_~J#VVG2LXkL zaAy=}U*?Jto)9hx5MGjdp9hcQAu@tfk_;l!PeyxPY<8b&+&D!CyaBh9=8BSVKLpk4 z4Ml3yY|&Th)vyK4cpC{!uU8v2YBlVV`d~(nz&<@{G1oe*DHub1z7~J5*;s2bX<)_* zV_GbsPQg`(&rpxRb_*Od7}++3+liSw-$!1 zs5*g}EHWhI3i|!-FcfzYL0`SL-rq>LENC;PMl)G(0(1U2%Va|smp0UFx0xd@soZA* zD5LYc4OlbE7@ARt#h}rr3>K@bf%B#^-c+xz8Hr)0D5ExIFltezN@Hn8>o5d~bSfYtkc+_Z&kI#-N5_GhCg*V-^TSO=!G~ z(fXy{n2XV+k}6w_W`dTOP2a4u0ly;ANZ>4OxSKAzFB!yBzdo`gX zO?o|H@WiAw$y6l?=^3jA_Hy0S)nTYs12;4hKE&ekQ|>?|ZLJ}#F`2BczC7kdE4@xV zZBD_)Otwjhz+NSaz?d45!;FsGSu-#qh#hStD%B}f!mCT!KqzSo>I`NGH_9Dea$1Qi zg29Ydt!~lQVR99_T7#Hije~(12drl-P)SV?QR*9sus`8th-8^OQ7@xI$(Yp|^;bL1 zR50O$mDXw6P>i7B(TJ)ciPzTE>XY%X6HAa)b#OBRXv&~%Bw|J#Y><i4=e%95bjtw|cJp=#P#Pf#*luqI_wR;fISDCJhAqSG6R%xItn%~QtZ@m%&u zjGGLX;t6Ls62eQvNmf@v+}J%54^CygxRZ`?8X#r|wkev7(s;Ou4T#y1XNNf)h;o7z z8a^Lfq<1uH`E{G9E z*(=)Css_LSk=>E9jr)s5^2-!+MN=Ds}>1hRma4`uCIz9%p3O77839E{xf z4c_I?**|1`K2tg4!Hvyrou4BsJQuv*UfF)<%CelYIS>D^o?X)3+MK%la6kooW8&G@BU)Y0hT`+mOm$Z_%rB=a%o>I z!2c6lHyKQN)VjiFwa!eE^p8jc$sy$vB+8i25lI~6KPFFh$!o$avA~rj#L6xvR|Z83 z*WD6T9e+5Pyy=F+)pNTf{ny3cy>7Rkd3o*TS?TZJ`NS^NF2%HMkyS{?uJ$`!P4_L^ z1`NFDUbNyg_qREifgktnp1_v{Jbb`7m}2PTyUdOmtJj~m z9bB=ecw4_^rw1IW=of+>nrW5=d3k`3qHCxsIN_F{T1A545};;+fsyC&qChi+YV zr~M63H8ZLCPYmsjY>ls9cL%I)F|JIW-#+48$+lD4k*(P*kDM%zx_fvu4u5ZYUnI}5 zdrycFq>xFU)&X3p@pP2u%$o}}YcRn(MhJ&B2o?KS@cIVz>Ye%o^xV?CB{_Qhu z;}_q1bvO^g{8<3!gYbo4Di{8qzV+(9 zdlmksohQmRTs@qB;(Wo?dER_ux6XQb@q$tQPW?CMu6GVQd;R=iR;-S{Kr%Zks7>b1 zNs{|-+jhObYE}NR&`TGGr^h^4bjh%c>R#@=8nM&Md>_a+zVulsl;){flFekV1t9ob z+SqfV_Pv3$2f)bQ8%Ul2>fdYR^1zs0BQF~olsOj5AodC&Q_7SMFzsz2 z9newxE&jodk~tNHwl%LBMMDbrk=(^b diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/config.json b/multimedia/media/media_js_standard/videoDecoder/src/main/config.json deleted file mode 100644 index 55c8b32a6..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/config.json +++ /dev/null @@ -1,75 +0,0 @@ -{ - "app": { - "apiVersion": { - "compatible": 6, - "releaseType": "Beta1", - "target": 7 - }, - "vendor": "acts", - "bundleName": "ohos.acts.multimedia.video.videodecoder", - "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.video.videodecoder.MainAbility", - "description": "$string:mainability_description", - "label": "$string:entry_MainAbility", - "type": "page", - "homeAbility": true, - "launchType": "standard" - } - ], - "deviceType": [ - "phone", - "tablet", - "tv", - "wearable" - ], - "mainAbility": "ohos.acts.multimedia.video.videodecoder.MainAbility", - "distro": { - "moduleType": "entry", - "installationFree": false, - "deliveryWithInstall": true, - "moduleName": "entry" - }, - "package": "ohos.acts.multimedia.video.videodecoder", - "name": ".MyApplication", - "js": [ - { - "pages": [ - "pages/index/index", - "pages/display/display" - ], - "name": "default", - "window": { - "designWidth": 720, - "autoDesignWidth": true - } - } - ] - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/app.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/app.js deleted file mode 100644 index 830070d19..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/app.js +++ /dev/null @@ -1,23 +0,0 @@ -/* - * 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'); - } -}; diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/en-US.json b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/en-US.json deleted file mode 100644 index e63c70d97..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/en-US.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "Hello", - "world": "World" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/zh-CN.json b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/zh-CN.json deleted file mode 100644 index de6ee5748..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/i18n/zh-CN.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "您好", - "world": "世界" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.css b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.css deleted file mode 100644 index c9195944a..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.css +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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; - } -} diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.hml b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.hml deleted file mode 100644 index 9e58ed9e3..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.hml +++ /dev/null @@ -1,26 +0,0 @@ - - -
- - {{ $t('strings.hello') }} {{ title }} - - - - -
diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.js deleted file mode 100644 index 5d5b9ac7e..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/display/display.js +++ /dev/null @@ -1,33 +0,0 @@ -/* - * 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() { - console.info('onInit finish') - this.title = this.$t('strings.world'); - }, - onShow() { - }, - onReady() { - }, - LoadXcomponent() { - globalThis.value = this.$element('XcomponentId').getXComponentSurfaceId(); - }, -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.css b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.css deleted file mode 100644 index c3517ad15..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.css +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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; - } -} diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.hml b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.hml deleted file mode 100644 index 8d0e2061b..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.hml +++ /dev/null @@ -1,20 +0,0 @@ - - -
- - {{ $t('strings.hello') }} {{ title }} - -
diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.js deleted file mode 100644 index cfb5ff123..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/default/pages/index/index.js +++ /dev/null @@ -1,42 +0,0 @@ -/* - * 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() { - console.info('onInit finish') - 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 diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/List.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/List.test.js deleted file mode 100644 index 9c483bbce..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/List.test.js +++ /dev/null @@ -1,24 +0,0 @@ -/* - * 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('./VideoDecoderFuncCallbackTest.test.js') -require('./VideoDecoderFuncPromiseTest.test.js') -require('./VideoDecoderReliCallbackTest.test.js') -require('./VideoDecoderReliPromiseTest.test.js') -require('./VideoDecoderSoftwareFuncCallbackTest.test.js') -require('./VideoDecoderSoftwareFuncPromiseTest.test.js') -require('./VideoDecoderSoftwareReliCallbackTest.test.js') -require('./VideoDecoderSoftwareReliPromiseTest.test.js') -require('./VideoDecoderEnumTest.test.js') diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderEnumTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderEnumTest.test.js deleted file mode 100644 index 0781c5ca6..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderEnumTest.test.js +++ /dev/null @@ -1,355 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - - -describe('VideoDecoderEnum', function () { - let videoDecodeProcessor = null; - let videoPlayer = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let inputQueue = []; - let outputQueue = []; - let isCodecData = false; - let inputEosFlag = false; - let surfaceID = ''; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - let ES_FRAME_SIZE = []; - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465]; - beforeAll(function() { - console.info('beforeAll case'); - // getSurfaceID(); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = false; - inputEosFlag = false; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: filepath ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.error('in case readFile' + e); - } - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - - function getContent(buf, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - lengthReal = readStreamSync.readSync( - buf, - {length: len} - ); - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent ' + e); - } - } - function getSurfaceID() { - let surfaceIDTest = new ArrayBuffer(20); - let readSurfaceID = Fileio.createStreamSync('/data/media/surfaceID.txt', 'rb'); - readSurfaceID.readSync(surfaceIDTest, {length: 13}); - let view2 = new Uint8Array(surfaceIDTest); - for (let i = 0; i < 13; i++) { - let value = view2[i] - 48; - surfaceID = surfaceID + '' + value; - } - console.info('in case surfaceID ' + surfaceID); - readSurfaceID.closeSync(); - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.info('in case: enqueueInputs in'); - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 16.67; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length - 1) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - if (frameCountIn == ES_FRAME_SIZE.length / 2) { - videoDecodeProcessor.setParameter({ - 'bitrate': 6400, - }).then(() => { - console.info('in case: setParameter success '); - }, failCallback).catch(failCatch); - } - videoDecodeProcessor.pushInputData(inputObject).then(() => { - console.info('in case: queueInput success '); - }, failCallback).catch(failCatch); - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject){ - if (outputObject.flags == 1) { - nextStep(); - return; - } - frameCountOut++; - await videoDecodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.log('in case: release output count:' + frameCountOut); - }, failCallback).catch(failCatch); - } - - function setCallback(nextStep){ - console.info('in case: setCallback in'); - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - expect(inBuffer.index !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - expect(inBuffer.data !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.data: '+ inBuffer.data); - expect(inBuffer.offset !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.offset: '+ inBuffer.offset); - expect(inBuffer.length !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.length: '+ inBuffer.length); - expect(inBuffer.flags !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.flags: '+ inBuffer.flags); - expect(inBuffer.timeMs !== undefined).assertTrue(); - console.info('in case: inputBufferAvailable inBuffer.timeMs: '+ inBuffer.timeMs); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - videoDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info('get outputMediaDescription : ' + MediaDescription); - }, failCallback).catch(failCatch); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - expect(err.code !== undefined).assertTrue(); - console.info('in case: err.code is ' + err.code); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - console.info('in case: setCallback out'); - } - - async function toCreateVideoDecoderByMime(mime, done) { - await media.createVideoDecoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoDecodeProcessor = processor; - console.info('in case : createVideoDecoderByMime success'); - } else { - console.info('in case : createVideoDecoderByMime fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - async function toGetVideoDecoderCaps() { - await videoDecodeProcessor.getVideoDecoderCaps().then((videoCaps) => { - console.info("case get getVideoDecoderCaps success"); - console.info("print videoCaps: " + videoCaps) - }, failCallback).catch(failCatch); - } - async function toCreateVideoDecoderByName(name, done) { - await media.createVideoDecoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoDecodeProcessor = processor; - console.info('in case : createVideoDecoderByName success'); - } else { - console.info('in case : createVideoDecoderByName fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - async function toConfigure(mediaDescription, srcPath) { - await videoDecodeProcessor.configure(mediaDescription).then(() =>{ - console.info('in case : configure success'); - readFile(srcPath); - }, failCallback).catch(failCatch); - } - async function setSurfaceID(done) { - await media.createVideoPlayer().then((video) => { - if (typeof (video) != 'undefined') { - videoPlayer = video; - console.info('in case : createVideoPlayer success'); - } else { - expect().assertFail(); - console.info('in case error: createVideoPlayer fail'); - done(); - } - }, failCallback).catch(failCatch); - await videoPlayer.getDisplaySurface().then((surface) => { - console.info('in case : getDisplaySurface success and surfaceID is ' + surface); - surfaceID = surface; - }, failCallback).catch(failCatch); - } - async function toSetOutputSurface(isDisplay) { - await videoDecodeProcessor.setOutputSurface(surfaceID, isDisplay).then(() => { - console.info('in case : setOutputSurface success. surfaceID ' + surfaceID); - }, failCallback).catch(failCatch); - } - eventEmitter.on('nextStep', async (done) => { - console.info('in case : nextStep success'); - await videoDecodeProcessor.stop().then(() => { - console.info('in case : stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('in case : reset success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.release().then(() => { - console.info('in case : release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - console.info('in case : done'); - done(); - }); - async function toPrepare() { - await videoDecodeProcessor.prepare().then(() => { - console.info('in case : prepare success'); - }, failCallback).catch(failCatch); - } - async function toStart() { - await videoDecodeProcessor.start().then(() => { - console.info('in case : start success'); - }, failCallback).catch(failCatch); - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_ENUM_CodecBuffer_0100 - * @tc.name : 001.CodecBuffer - * @tc.desc : Test Interface CodecBuffer - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_ENUM_CodecBuffer_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByMime('video/avc', done); - await toGetVideoDecoderCaps(); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_ENUM_CodecMimeType_0100 - * @tc.name : 002.CodecMimeType - * @tc.desc : Test Enumerate CodecMimeType - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_ENUM_CodecMimeType_0100', 0, async function (done) { - expect(media.CodecMimeType.VIDEO_H263).assertEqual('video/h263'); - expect(media.CodecMimeType.VIDEO_AVC).assertEqual('video/avc'); - expect(media.CodecMimeType.VIDEO_MPEG2).assertEqual('video/mpeg2'); - expect(media.CodecMimeType.VIDEO_MPEG4).assertEqual('video/mp4v-es'); - expect(media.CodecMimeType.VIDEO_VP8).assertEqual('video/x-vnd.on2.vp8'); - done(); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncCallbackTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncCallbackTest.test.js deleted file mode 100644 index ba22c5bb7..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncCallbackTest.test.js +++ /dev/null @@ -1,437 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('VideoDecoderFuncCallbackTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let inputQueue = []; - let outputQueue = []; - let isCodecData = false; - let inputEosFlag = false; - let surfaceID = ''; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - let ES_FRAME_SIZE = []; - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - const H263_FRAME_SIZE = - [ 96618, 3515, 4132, 4336, 4646, 3497, 4430, 5437, 7560, 4613, 4876, 4734, 53617, 4079, 4507, 5222, 6244, - 5843, 6601, 6622, 6751, 6539, 7666, 7706, 53977, 7311, 12906, 10308, 26791, 15983, 34794, 22110, 37165, - 24267, 36171, 18330, 53228, 7893, 13088, 9502, 8485, 9207, 8681, 9202, 8537, 7603, 9726, 8191, 51872, - 5535, 6146, 6341, 6933, 9365, 7828, 6547, 7638, 7009, 7025, 8873, 51045, 5056, 4858, 4887, 9614, 5953, - 5972, 6116, 6060, 6296, 6239, 6400, 50928, 4937, 5054, 5371, 6728, 6286, 6524, 6646, 6549, 6036, 6214, - 5866, 51109, 4778, 5273, 6327]; - const MPEG2_FRAME_SIZE = - [ 38462, 55096, 8660, 3417, 1197, 2209, 984, 718, 783, 623, 659, 694, 14174, 580, 421, 495, 480, 476, 534, - 660, 699, 601, 603, 720, 12585, 555, 532, 776, 789, 762, 766, 732, 671, 735, 777, 948, 12650, 827, 766, - 835, 747, 847, 940, 1121, 1092, 1001, 980, 989, 12746, 945, 912, 1046, 1118, 1134, 1050, 1073, 1051, 1195, - 1085, 1182, 12874, 992, 1007, 985, 1040, 1143, 1157, 1150, 1247, 1149, 1246, 1145, 12870, 1041, 1066, 1314, - 1239, 1283, 1223, 1224, 1270, 1427, 1406, 1516, 12949, 1228, 1299, 1439, 1358, 1455, 1311, 1396, 1416, 1470, - 1393, 1502, 12999, 1232, 1400, 1348, 1335, 1461, 1404, 1412, 1426, 1548, 1481, 1488, 12840, 1229, 1342, 1323, - 1353, 1524, 1363, 1475, 1540, 1495, 1489, 1438, 12762, 1291, 1303, 1470, 1494, 1488, 1474, 1453, 1607, 1485, - 1589, 1762, 12548, 1363, 1317, 1435, 1411, 1338, 1373, 1605, 1639, 1429, 1392, 1543, 12332, 1255, 1200, 1291, - 1337, 1341, 1356, 1214, 1456, 1353, 1314, 1502, 12151, 1192, 1290, 1203, 1284, 1154, 1264, 1358, 1390, 1433, - 1194, 1325, 11904, 993, 1007, 1149, 1099, 1182, 1076, 1074, 1092, 1030, 1272, 1178, 11710, 966, 879, 860, 955, - 898, 967, 927, 1066, 997, 1083, 940, 11717, 648, 705, 901, 925, 930, 868, 798, 846, 781, 825, 1027, 11587, 785, - 733, 731, 848, 753, 806, 699, 837, 750, 762, 748, 11541, 678, 742, 667, 735, 702, 837, 695, 773, 849, 869, 769, - 11381, 664, 705, 714, 698, 814, 846, 757, 802, 857, 905, 772, 11265, 718, 643, 597, 687, 774, 843, 747, 785, - 683, 1135, 676, 11259, 616, 595, 773, 746, 798, 722, 798, 790, 959, 771, 907, 11234, 705, 675, 773, 764, 846, - 789, 840, 853, 828, 774, 842, 11263, 758, 758, 757, 820, 847, 834, 884, 842, 988, 750, 952, 11236, 776, 640, 727, - 832, 855, 733, 822, 827, 862, 697, 924, 11176, 675, 615, 688, 818, 783, 746, 901, 834, 892, 759, 923, 11181, 661, - 578, 720, 697]; - const MPEG4_FRAME_SIZE = - [ 11895, 8109, 1578, 1616, 1313, 572, 805, 837, 755, 706, 952, 879, 13193, 422, 389, 509, 725, 465, 479, 959, - 677, 364, 541, 696, 9306, 322, 318, 767, 590, 422, 530, 403, 505, 566, 445, 508, 7783, 460, 405, 343, 451, - 608, 431, 411, 543, 487, 527, 400, 6287, 385, 418, 391, 592, 434, 412, 398, 504, 492, 479, 561, 5413, 317, - 355, 422, 467, 452, 476, 460, 490, 492, 485, 451, 5036, 312, 408, 460, 432, 502, 388, 475, 407, 544, 401, - 487, 4404, 362, 378, 427, 416, 426, 456, 414, 438, 424, 442, 444, 4310, 362, 388, 393, 390, 441, 398, 423, - 369, 443, 406, 392, 4231, 343, 363, 355, 390, 459, 371, 378, 381, 405, 392, 426, 3975, 387, 337, 393, 439, - 378, 355, 374, 484, 381, 373, 423, 3869, 312, 350, 400, 345, 356, 320, 473, 431, 386, 338, 431, 3426, 268, - 315, 416, 383, 373, 381, 354, 383, 328, 348, 418, 3715, 324, 361, 331, 350, 302, 409, 377, 359, 384, 334, - 326, 3439, 266, 324, 329, 353, 405, 303, 357, 332, 292, 361, 333, 3542, 294, 284, 247, 331, 306, 322, 287, - 367, 341, 276, 258, 3980, 246, 245, 259, 309, 333, 250, 275, 334, 281, 253, 371, 3640, 213, 231, 301, 302, - 228, 289, 290, 281, 201, 284, 277, 4242, 205, 328, 237, 283, 295, 266, 230, 321, 348, 212, 308, 4103, 259, - 238, 245, 298, 330, 265, 271, 287, 267, 286, 290, 3856, 269, 242, 209, 314, 267, 278, 280, 314, 250, 433, - 238, 3654, 195, 246, 301, 298, 250, 270, 320, 269, 305, 258, 368, 3810, 231, 212, 279, 289, 252, 303, 287, - 295, 206, 264, 349, 4071, 242, 296, 271, 231, 307, 265, 254, 267, 317, 232, 348, 4077, 259, 222, 268, 235, - 324, 266, 256, 312, 246, 248, 325, 4000, 266, 201, 230, 293, 264, 265, 273, 301, 304, 253, 266, 3978, 228, - 232, 250, 248, 281, 219, 243, 293, 287, 253, 328, 3719]; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = false; - inputEosFlag = false; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: filepath ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case error readFile' + e); - } - } - function getContent(buf, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - lengthReal = readStreamSync.readSync( - buf, - {length: len} - ); - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent: ' + e); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 16.67; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length - 1) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - if (frameCountIn == ES_FRAME_SIZE.length / 2) { - videoDecodeProcessor.setParameter({ - 'bitrate': 6400, - }, (err) => { - expect(err).assertUndefined(); - console.info('in case: setParameter success '); - }); - } - videoDecodeProcessor.pushInputData(inputObject, (err) => { - if (typeof (err) == 'undefined') { - console.info('in case: queueInput success '); - } else { - console.info(`in case queueInput err called,errMessage is ${error.message}`); - } - }) - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject){ - if (outputObject.flags == 1 ) { - nextStep(); - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject, (err) => { - if (typeof (err) == 'undefined') { - console.log('in case: release output count:' + frameCountOut); - } else { - console.info(`in case releaseOutput error called,errMessage is ${error.message}`); - } - }) - } - - function setCallback(nextStep){ - console.info('in case: setCallback in'); - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - videoDecodeProcessor.getOutputMediaDescription((err, MediaDescription) => { - expect(err).assertUndefined(); - console.info('get outputMediaDescription : ' + MediaDescription); - }); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - console.info('in case: setCallback out'); - } - eventEmitter.on('configure', (mediaDescription, srcPath, nextStep, done) => { - console.info('in case : configure in'); - videoDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info('in case : configure success'); - readFile(srcPath); - setCallback(nextStep); - eventEmitter.emit('getVideoDecoderCaps', done); - // eventEmitter.emit('setOutputSurface', done); - }); - }); - eventEmitter.on('getVideoDecoderCaps', (done) => { - videoDecodeProcessor.getVideoDecoderCaps((err, videoCaps) => { - expect(err).assertUndefined(); - console.info('case get getVideoDecoderCaps success'); - console.info(`print videoCaps: - codecInfo.name ${videoCaps.codecInfo.name} - codecInfo.type ${videoCaps.codecInfo.type} - codecInfo.mimeType ${videoCaps.codecInfo.mimeType} - codecInfo.isHardwareAccelerated ${videoCaps.codecInfo.isHardwareAccelerated} - codecInfo.isSoftwareOnly ${videoCaps.codecInfo.isSoftwareOnly} - codecInfo.isVendor ${videoCaps.codecInfo.isVendor} - supportedBitrate [${videoCaps.supportedBitrate.min}, ${videoCaps.supportedBitrate.max}] - supportedFormats ${videoCaps.supportedFormats} - supportedHeightAlignment ${videoCaps.supportedHeightAlignment} - supportedWidthAlignment ${videoCaps.supportedWidthAlignment} - supportedWidth [${videoCaps.supportedWidth.min}, ${videoCaps.supportedWidth.max}] - supportedHeight [${videoCaps.supportedHeight.min}, ${videoCaps.supportedHeight.max}] - supportedProfiles ${videoCaps.supportedProfiles} - supportedLevels ${videoCaps.supportedLevels} - supportedBitrateMode ${videoCaps.supportedBitrateMode} - supportedQuality [${videoCaps.supportedQuality.min}, ${videoCaps.supportedQuality.max}] - supportedComplexity [${videoCaps.supportedComplexity.min}, ${videoCaps.supportedComplexity.max}] - `); - eventEmitter.emit('setOutputSurface', done); - }); - }); - - eventEmitter.on('setOutputSurface', (done) => { - videoDecodeProcessor.setOutputSurface(surfaceID, true, (err) => { - expect(err).assertUndefined(); - console.info('in case : setOutputSurface success, surfaceID ' + surfaceID); - eventEmitter.emit('prepare', done); - }) - }); - eventEmitter.on('prepare', (done) => { - videoDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info('in case : prepare success'); - eventEmitter.emit('start', done); - }); - }); - eventEmitter.on('start', (done) => { - videoDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info('in case : start success'); - }); - }); - eventEmitter.on('stop', (done) => { - videoDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info('in case : stop success'); - eventEmitter.emit('reset', done); - }); - }); - eventEmitter.on('reset', (done) => { - videoDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info('in case : reset success'); - eventEmitter.emit('release', done); - }); - }); - eventEmitter.on('release', (done) => { - videoDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info('in case : release success'); - videoDecodeProcessor = null; - done(); - }); - }); - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_H264_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_H264_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByMime('video/avc', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByMime success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, - done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_MPEG2_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_MPEG2_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG2_FRAME_SIZE; - let srcPath = BASIC_PATH + 'MPEG2_720_480.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mpeg2', - 'width': 720, - 'height': 480, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByMime('video/mpeg2', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByMime success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, - done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_MPEG4_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_MPEG4_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG4_FRAME_SIZE; - let srcPath = BASIC_PATH + 'mpeg4_320_240.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mp4v-es', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByMime('video/mp4v-es', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByMime success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, - done); - }); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncPromiseTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncPromiseTest.test.js deleted file mode 100644 index 625f4a8be..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderFuncPromiseTest.test.js +++ /dev/null @@ -1,487 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - - -describe('VideoDecoderFuncPromiseTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let inputQueue = []; - let outputQueue = []; - let isCodecData = false; - let inputEosFlag = false; - let surfaceID = ''; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - let ES_FRAME_SIZE = []; - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - const H263_FRAME_SIZE = - [ 96618, 3515, 4132, 4336, 4646, 3497, 4430, 5437, 7560, 4613, 4876, 4734, 53617, 4079, 4507, 5222, 6244, - 5843, 6601, 6622, 6751, 6539, 7666, 7706, 53977, 7311, 12906, 10308, 26791, 15983, 34794, 22110, 37165, - 24267, 36171, 18330, 53228, 7893, 13088, 9502, 8485, 9207, 8681, 9202, 8537, 7603, 9726, 8191, 51872, - 5535, 6146, 6341, 6933, 9365, 7828, 6547, 7638, 7009, 7025, 8873, 51045, 5056, 4858, 4887, 9614, 5953, - 5972, 6116, 6060, 6296, 6239, 6400, 50928, 4937, 5054, 5371, 6728, 6286, 6524, 6646, 6549, 6036, 6214, - 5866, 51109, 4778, 5273, 6327]; - const MPEG2_FRAME_SIZE = - [ 38462, 55096, 8660, 3417, 1197, 2209, 984, 718, 783, 623, 659, 694, 14174, 580, 421, 495, 480, 476, 534, - 660, 699, 601, 603, 720, 12585, 555, 532, 776, 789, 762, 766, 732, 671, 735, 777, 948, 12650, 827, 766, - 835, 747, 847, 940, 1121, 1092, 1001, 980, 989, 12746, 945, 912, 1046, 1118, 1134, 1050, 1073, 1051, 1195, - 1085, 1182, 12874, 992, 1007, 985, 1040, 1143, 1157, 1150, 1247, 1149, 1246, 1145, 12870, 1041, 1066, 1314, - 1239, 1283, 1223, 1224, 1270, 1427, 1406, 1516, 12949, 1228, 1299, 1439, 1358, 1455, 1311, 1396, 1416, 1470, - 1393, 1502, 12999, 1232, 1400, 1348, 1335, 1461, 1404, 1412, 1426, 1548, 1481, 1488, 12840, 1229, 1342, 1323, - 1353, 1524, 1363, 1475, 1540, 1495, 1489, 1438, 12762, 1291, 1303, 1470, 1494, 1488, 1474, 1453, 1607, 1485, - 1589, 1762, 12548, 1363, 1317, 1435, 1411, 1338, 1373, 1605, 1639, 1429, 1392, 1543, 12332, 1255, 1200, 1291, - 1337, 1341, 1356, 1214, 1456, 1353, 1314, 1502, 12151, 1192, 1290, 1203, 1284, 1154, 1264, 1358, 1390, 1433, - 1194, 1325, 11904, 993, 1007, 1149, 1099, 1182, 1076, 1074, 1092, 1030, 1272, 1178, 11710, 966, 879, 860, 955, - 898, 967, 927, 1066, 997, 1083, 940, 11717, 648, 705, 901, 925, 930, 868, 798, 846, 781, 825, 1027, 11587, 785, - 733, 731, 848, 753, 806, 699, 837, 750, 762, 748, 11541, 678, 742, 667, 735, 702, 837, 695, 773, 849, 869, 769, - 11381, 664, 705, 714, 698, 814, 846, 757, 802, 857, 905, 772, 11265, 718, 643, 597, 687, 774, 843, 747, 785, - 683, 1135, 676, 11259, 616, 595, 773, 746, 798, 722, 798, 790, 959, 771, 907, 11234, 705, 675, 773, 764, 846, - 789, 840, 853, 828, 774, 842, 11263, 758, 758, 757, 820, 847, 834, 884, 842, 988, 750, 952, 11236, 776, 640, 727, - 832, 855, 733, 822, 827, 862, 697, 924, 11176, 675, 615, 688, 818, 783, 746, 901, 834, 892, 759, 923, 11181, 661, - 578, 720, 697]; - const MPEG4_FRAME_SIZE = - [ 11895, 8109, 1578, 1616, 1313, 572, 805, 837, 755, 706, 952, 879, 13193, 422, 389, 509, 725, 465, 479, 959, - 677, 364, 541, 696, 9306, 322, 318, 767, 590, 422, 530, 403, 505, 566, 445, 508, 7783, 460, 405, 343, 451, - 608, 431, 411, 543, 487, 527, 400, 6287, 385, 418, 391, 592, 434, 412, 398, 504, 492, 479, 561, 5413, 317, - 355, 422, 467, 452, 476, 460, 490, 492, 485, 451, 5036, 312, 408, 460, 432, 502, 388, 475, 407, 544, 401, - 487, 4404, 362, 378, 427, 416, 426, 456, 414, 438, 424, 442, 444, 4310, 362, 388, 393, 390, 441, 398, 423, - 369, 443, 406, 392, 4231, 343, 363, 355, 390, 459, 371, 378, 381, 405, 392, 426, 3975, 387, 337, 393, 439, - 378, 355, 374, 484, 381, 373, 423, 3869, 312, 350, 400, 345, 356, 320, 473, 431, 386, 338, 431, 3426, 268, - 315, 416, 383, 373, 381, 354, 383, 328, 348, 418, 3715, 324, 361, 331, 350, 302, 409, 377, 359, 384, 334, - 326, 3439, 266, 324, 329, 353, 405, 303, 357, 332, 292, 361, 333, 3542, 294, 284, 247, 331, 306, 322, 287, - 367, 341, 276, 258, 3980, 246, 245, 259, 309, 333, 250, 275, 334, 281, 253, 371, 3640, 213, 231, 301, 302, - 228, 289, 290, 281, 201, 284, 277, 4242, 205, 328, 237, 283, 295, 266, 230, 321, 348, 212, 308, 4103, 259, - 238, 245, 298, 330, 265, 271, 287, 267, 286, 290, 3856, 269, 242, 209, 314, 267, 278, 280, 314, 250, 433, - 238, 3654, 195, 246, 301, 298, 250, 270, 320, 269, 305, 258, 368, 3810, 231, 212, 279, 289, 252, 303, 287, - 295, 206, 264, 349, 4071, 242, 296, 271, 231, 307, 265, 254, 267, 317, 232, 348, 4077, 259, 222, 268, 235, - 324, 266, 256, 312, 246, 248, 325, 4000, 266, 201, 230, 293, 264, 265, 273, 301, 304, 253, 266, 3978, 228, - 232, 250, 248, 281, 219, 243, 293, 287, 253, 328, 3719]; - beforeAll(function() { - console.info('beforeAll case'); - // getSurfaceID(); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = false; - inputEosFlag = false; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: filepath ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.error('in case readFile' + e); - } - } - - function getContent(buf, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - lengthReal = readStreamSync.readSync( - buf, - {length: len} - ); - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent ' + e); - } - } - function getSurfaceID() { - let surfaceIDTest = new ArrayBuffer(20); - let readSurfaceID = Fileio.createStreamSync('/data/media/surfaceID.txt', 'rb'); - readSurfaceID.readSync(surfaceIDTest, {length: 13}); - let view2 = new Uint8Array(surfaceIDTest); - for (let i = 0; i < 13; i++) { - let value = view2[i] - 48; - surfaceID = surfaceID + '' + value; - } - console.info('in case surfaceID ' + surfaceID); - readSurfaceID.closeSync(); - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 16.67; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length - 1) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - if (frameCountIn == ES_FRAME_SIZE.length / 2) { - videoDecodeProcessor.setParameter({ - 'bitrate': 6400, - }).then(() => { - console.info('in case: setParameter success '); - }, failCallback).catch(failCatch); - } - videoDecodeProcessor.pushInputData(inputObject).then(() => { - console.info('in case: queueInput success '); - }, failCallback).catch(failCatch); - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1) { - nextStep(); - return; - } - frameCountOut++; - await videoDecodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.log('in case: release output count:' + frameCountOut); - }, failCallback).catch(failCatch); - } - - function setCallback(nextStep){ - console.info('in case: setCallback in'); - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - videoDecodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info('get outputMediaDescription : ' + MediaDescription); - }, failCallback).catch(failCatch); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - console.info('in case: setCallback out'); - } - - async function toCreateVideoDecoderByMime(mime, done) { - await media.createVideoDecoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoDecodeProcessor = processor; - console.info('in case : createVideoDecoderByMime success'); - } else { - console.info('in case : createVideoDecoderByMime fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - async function toGetVideoDecoderCaps() { - await videoDecodeProcessor.getVideoDecoderCaps().then((videoCaps) => { - console.info("case get getVideoDecoderCaps success"); - console.info(`print videoCaps: - codecInfo.name ${videoCaps.codecInfo.name} - codecInfo.type ${videoCaps.codecInfo.type} - codecInfo.mimeType ${videoCaps.codecInfo.mimeType} - codecInfo.isHardwareAccelerated ${videoCaps.codecInfo.isHardwareAccelerated} - codecInfo.isSoftwareOnly ${videoCaps.codecInfo.isSoftwareOnly} - codecInfo.isVendor ${videoCaps.codecInfo.isVendor} - supportedBitrate [${videoCaps.supportedBitrate.min}, ${videoCaps.supportedBitrate.max}] - supportedFormats ${videoCaps.supportedFormats} - supportedHeightAlignment ${videoCaps.supportedHeightAlignment} - supportedWidthAlignment ${videoCaps.supportedWidthAlignment} - supportedWidth [${videoCaps.supportedWidth.min}, ${videoCaps.supportedWidth.max}] - supportedHeight [${videoCaps.supportedHeight.min}, ${videoCaps.supportedHeight.max}] - supportedProfiles ${videoCaps.supportedProfiles} - supportedLevels ${videoCaps.supportedLevels} - supportedBitrateMode ${videoCaps.supportedBitrateMode} - supportedQuality [${videoCaps.supportedQuality.min}, ${videoCaps.supportedQuality.max}] - supportedComplexity [${videoCaps.supportedComplexity.min}, ${videoCaps.supportedComplexity.max}] - `); - }, failCallback).catch(failCatch); - } - async function toConfigure(mediaDescription, srcPath) { - await videoDecodeProcessor.configure(mediaDescription).then(() =>{ - console.info('in case : configure success'); - readFile(srcPath); - }, failCallback).catch(failCatch); - } - async function toSetOutputSurface(isDisplay) { - await videoDecodeProcessor.setOutputSurface(surfaceID, isDisplay).then(() => { - console.info('in case : setOutputSurface success. surfaceID ' + surfaceID); - }, failCallback).catch(failCatch); - } - eventEmitter.on('nextStep', async (done) => { - console.info('in case : nextStep success'); - await videoDecodeProcessor.stop().then(() => { - console.info('in case : stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('in case : reset success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.release().then(() => { - console.info('in case : release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - console.info('in case : done'); - done(); - }); - async function toPrepare() { - await videoDecodeProcessor.prepare().then(() => { - console.info('in case : prepare success'); - }, failCallback).catch(failCatch); - } - async function toStart() { - await videoDecodeProcessor.start().then(() => { - console.info('in case : start success'); - }, failCallback).catch(failCatch); - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_H264_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_H264_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByMime('video/avc', done); - await toGetVideoDecoderCaps(); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_MPEG2_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_MPEG2_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG2_FRAME_SIZE; - let srcPath = BASIC_PATH + 'MPEG2_720_480.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mpeg2', - 'width': 720, - 'height': 480, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByMime('video/mpeg2', done); - await toGetVideoDecoderCaps(); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_MPEG4_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_MPEG4_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG4_FRAME_SIZE; - let srcPath = BASIC_PATH + 'mpeg4_320_240.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mp4v-es', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByMime('video/mp4v-es', done); - await toGetVideoDecoderCaps(); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_MULTIINSTANCE_PROMISE_0100 - * @tc.name : 001.creat multiple video decoders - * @tc.desc : creat multiple video decoders - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_MULTIINSTANCE_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - let array = new Array(); - eventEmitter.on('releaseAllDecoder', async () => { - for (let j = 0; j < 2; j++) { - await array[j].release().then(() => { - array[j] = null; - }, failCallback).catch(failCatch); - } - await videoDecodeProcessor.release().then(() => { - console.info('in case : release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - done(); - }) - for (let i = 0; i < 3; i++) { - await media.createVideoDecoderByMime('video/avc').then((processor) => { - if (typeof (processor) != 'undefined') { - console.info('in case : createVideoDecoderByMime success'); - if (i == 2) { - videoDecodeProcessor = processor; - } else { - array[i] = processor; - } - } else { - console.info('in case : createVideoDecoderByMime fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('releaseAllDecoder', done);} - ); - await toPrepare(); - await toStart(); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliCallbackTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliCallbackTest.test.js deleted file mode 100644 index 3acec6a91..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliCallbackTest.test.js +++ /dev/null @@ -1,1277 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' -export -const DECODE_STEP = { - WAIT_FOR_EOS : 'waitForEOS', - CONFIGURE : 'configure', - SETSURFACE : 'setSurface', - PREPARE : 'prepare', - START : 'start', - FLUSH : 'flush', - STOP : 'stop', - RESET : 'reset', - WAIT_FOR_ALL_OUTS : 'waitForAllOuts', - ERROR : 'error', - RELEASE : 'release', -} - -describe('VideoDecoderReliCallbackTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let position = 0; - let eosFrameId = -1; - let inputQueue = []; - let outputQueue = []; - let isCodecData = true; - let inputEosFlag = false; - let workdoneAtEOS = false; - let surfaceID = ''; - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - const SRCPATH = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60, - 'max_input_size': 150000, - } - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - let ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - workdoneAtEOS = false; - eosFrameId = -1; - inputEosFlag = false; - position = 0; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - function printError(err, expectFail) { - expect((err != undefined) == expectFail).assertTrue(); - if (expectFail == false && err != undefined) { - console.info('in case error failCatch called,err is ' + err); - console.info(`in case error failCatch called,errMessage is ${err.message}`); - } - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: file path ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case readFile' + e); - } - } - - function getContent(buf, pos, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - if (pos == -1) { - lengthReal = readStreamSync.readSync(buf, { - length: len, - }); - } else { - lengthReal = readStreamSync.readSync(buf, { - length: len, - position: pos, - }); - } - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent err ' + err); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, position, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - position = position + ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 1000 / mediaDescription.frame_rate; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length || frameCountIn == eosFrameId) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject, (err) => { - console.info('in case: queueInput success '); - }) - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1 ) { - if (workdoneAtEOS) { - doneWork(nextStep); - } - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject, () => { - console.log('in case: release output count:' + frameCountOut); - }) - } - - function toConfigure(mySteps, done, expectFail) { - videoDecodeProcessor.configure(mediaDescription, (err) => { - console.info(`case configure callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }) - } - function toPrepare(mySteps, done, expectFail) { - videoDecodeProcessor.prepare((err) => { - console.info(`case prepare callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toStart(mySteps, done, expectFail) { - let timeDelay = 0; - videoDecodeProcessor.start((err) => { - console.info(`case start callback`); - printError(err, expectFail); - if (mySteps[0] == DECODE_STEP.FLUSH) { - timeDelay = 500; - } - setTimeout(() => { - toNextStep(mySteps, done); - }, timeDelay); - }); - } - function toFlush(mySteps, done, expectFail) { - videoDecodeProcessor.flush((err) => { - console.info(`case flush callback`); - printError(err, expectFail); - if (expectFail == false) { - inputEosFlag = false; - position = ES_FRAME_SIZE[0]; - inputQueue = []; - timestamp = 0; - frameCountIn = 1; - } - toNextStep(mySteps, done); - }); - } - function toStop(mySteps, done, expectFail) { - videoDecodeProcessor.stop((err) => { - console.info(`case stop callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toReset(mySteps, done, expectFail) { - videoDecodeProcessor.reset((err) => { - console.info(`case reset callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toSetOutputSurface(mySteps, done, expectFail) { - videoDecodeProcessor.setOutputSurface(surfaceID, true, (err) => { - console.info('case setOutputSurface callback, surfaceID ' + surfaceID); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toNextStep(mySteps, done) { - console.info('case myStep[0]: ' + mySteps[0]); - if (mySteps[0] == DECODE_STEP.RELEASE) { - if (videoDecodeProcessor != null){ - videoDecodeProcessor.release((err) => { - printError(err, false); - console.info('in case : videoDecodeProcessor release callback'); - videoDecodeProcessor = null; - console.info('case to done'); - done(); - }); - } - return; - } - switch (mySteps[0]) { - case DECODE_STEP.CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toConfigure(mySteps, done, true); - } else { - toConfigure(mySteps, done, false); - } - break; - case DECODE_STEP.SETSURFACE: - mySteps.shift(); - console.info(`case to setOutputSurface`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toSetOutputSurface(mySteps, done, true); - } else { - toSetOutputSurface(mySteps, done, false); - } - break; - case DECODE_STEP.PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toPrepare(mySteps, done, true); - } else { - toPrepare(mySteps, done, false); - } - break; - case DECODE_STEP.START: - mySteps.shift(); - console.info(`case to start`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStart(mySteps, done, true); - } else { - readStreamSync = undefined; - readFile(SRCPATH); - frameCountIn = 0; - frameCountOut = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - position = 0; - toStart(mySteps, done, false); - } - break; - case DECODE_STEP.FLUSH: - mySteps.shift(); - console.info(`case to flush`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toFlush(mySteps, done, true); - } else { - toFlush(mySteps, done, false); - } - break; - case DECODE_STEP.STOP: - mySteps.shift(); - console.info(`case to stop`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStop(mySteps, done, true); - } else { - toStop(mySteps, done, false); - } - break; - case DECODE_STEP.RESET: - mySteps.shift(); - console.info(`case to reset`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toReset(mySteps, done, true); - } else { - toReset(mySteps, done, false); - } - break; - case DECODE_STEP.WAIT_FOR_EOS: - mySteps.shift(); - setTimeout(() =>{ - expect(inputEosFlag).assertTrue(); - if (inputEosFlag == false) { - console.info(`in case error wait for eos: inputEosFlag = false`); - } - toNextStep(mySteps, done); - }, 7000); // wait 7000 ms for eos - break; - case DECODE_STEP.WAIT_FOR_ALL_OUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - default: - break; - } - } - - function setCallback(nextStep){ - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - } - - function toCreateVideoDecoderByMime(mime, mySteps, done) { - media.createVideoDecoderByMime(mime, (err, processor) => { - console.info(`case createVideoDecoderByMime callback`); - printError(err, false); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }) - } - function toCreateVideoDecoderByName(name, mySteps, done) { - media.createVideoDecoderByName(name, (err, processor) => { - printError(err, false); - console.info(`case createVideoDecoderByName callback`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }) - } - async function doneWork(nextStep) { - videoDecodeProcessor.stop((err) => { - printError(err, false); - console.info('case stop callback'); - videoDecodeProcessor.reset((err) => { - printError(err, false); - console.info('case reset callback'); - videoDecodeProcessor.release((err) => { - printError(err, false); - console.info('case release callback'); - videoDecodeProcessor = null; - nextStep(); - }) - }) - }) - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0100 - * @tc.name : test set EOS manually before last frame and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0200 - * @tc.name : test flush at running state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0300 - * @tc.name : test flush at EOS state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - eosFrameId = 50; - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0400 - * @tc.name : test stop at running state and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0500 - * @tc.name : test stop and restart - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_CALLBACK_01_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0100 - * @tc.name : 001.create -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0300 - * @tc.name : 003.start -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_CALLBACK_0900', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS , - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0100 - * @tc.name : 001.create -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0200 - * @tc.name : 002.configure -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0400 - * @tc.name : 004.start -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0500 - * @tc.name : 005.flush -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0600 - * @tc.name : 006.stop -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.START, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0800 - * @tc.name : 008.reset -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0100 - * @tc.name : 001.create -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.FLUSH, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0400 - * @tc.name : 004.start -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP , DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0100 - * @tc.name : 001.create -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.STOP, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0400 - * @tc.name : 004.start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0100 - * @tc.name : 001.create -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.RESET, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0400 - * @tc.name : 004.start -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) -}) diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliPromiseTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliPromiseTest.test.js deleted file mode 100644 index 8fa0d2eeb..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderReliPromiseTest.test.js +++ /dev/null @@ -1,1268 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' -export -const DECODE_STEP = { - WAIT_FOR_EOS : 'waitForEOS', - CONFIGURE : 'configure', - SETSURFACE : 'setSurface', - PREPARE : 'prepare', - START : 'start', - FLUSH : 'flush', - STOP : 'stop', - RESET : 'reset', - WAIT_FOR_ALL_OUTS : 'waitForAllOuts', - ERROR : 'error', - RELEASE : 'release', -} - -describe('VideoDecoderReliPromiseTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let position = 0; - let eosFrameId = -1; - let inputQueue = []; - let outputQueue = []; - let isCodecData = true; - let inputEosFlag = false; - let workdoneAtEOS = false; - let surfaceID = ''; - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - const SRCPATH = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 4, - 'frame_rate': 60, - 'max_input_size': 150000, - } - const H264_FRAME_SIZE_60FPS_320 = - [2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - let ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - workdoneAtEOS = false; - eosFrameId = -1; - inputEosFlag = false; - position = 0; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let caseCallback = function(err) { - console.info(`in case caseCallback called, caseMessage is ${err.message}`); - } - let failCallback = function(err) { - console.error(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.error(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let callbackExpectOK = function(err, mySteps, done) { - console.error(`in case error callbackExpectOK called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - toNextStep(mySteps, done); - } - let callbackExpectFail = function(err, mySteps, done) { - console.info(`in case callbackExpectFail called, errMessage is ${err.message}`); - expect(err != undefined).assertTrue(); - toNextStep(mySteps, done); - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: file path ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case readFile' + e); - } - } - - function getContent(buf, pos, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - if (pos == -1) { - lengthReal = readStreamSync.readSync(buf, { - length: len, - }); - } else { - lengthReal = readStreamSync.readSync(buf, { - length: len, - position: pos, - }); - } - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent err ' + err); - } - } - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, position, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - position = position + ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 1000 / mediaDescription.frame_rate; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length || frameCountIn == eosFrameId) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject).then(() => { - console.info('in case: queueInput success '); - }, caseCallback).catch(failCatch); - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1 ) { - if (workdoneAtEOS) { - await doneWork(); - nextStep(); - } - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.info('in case: release output success'); - console.log('in case: release output count:' + frameCountOut); - }, caseCallback).catch(failCatch); - } - - function toConfigure(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toPrepare(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.prepare().then(() => { - console.info(`case prepare success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toStart(mySteps, done, failureCallback, catchCallback) { - let timeDelay = 0; - videoDecodeProcessor.start().then(() => { - console.info(`case start success`); - if (mySteps[0] == DECODE_STEP.FLUSH) { - timeDelay = 500; - } - setTimeout(() => { - toNextStep(mySteps, done); - }, timeDelay); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toFlush(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.flush().then(() => { - console.info(`case flush success`); - position = ES_FRAME_SIZE[0]; - inputQueue = []; - timestamp = 0; - inputEosFlag = false; - frameCountIn = 1; - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toStop(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.stop().then(() => { - console.info(`case stop success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toReset(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.reset().then(() => { - console.info(`case reset success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toSetOutputSurface(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.setOutputSurface(surfaceID, true).then(() => { - console.info('in case : setOutputSurface success, surfaceID ' + surfaceID); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toNextStep(mySteps, done) { - console.info('case myStep[0]: ' + mySteps[0]); - if (mySteps[0] == DECODE_STEP.RELEASE) { - if (videoDecodeProcessor != null) { - videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - videoDecodeProcessor = null; - console.info('case to done'); - done(); - }, failCallback).catch(failCatch); - } - return; - } - switch (mySteps[0]) { - case DECODE_STEP.CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toConfigure(mySteps, done, callbackExpectFail, failCatch); - } else { - toConfigure(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.SETSURFACE: - mySteps.shift(); - console.info(`case to setOutputSurface`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toSetOutputSurface(mySteps, done, callbackExpectFail, failCatch); - } else { - toSetOutputSurface(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toPrepare(mySteps, done, callbackExpectFail, failCatch); - } else { - toPrepare(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.START: - mySteps.shift(); - console.info(`case to start`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStart(mySteps, done, callbackExpectFail, failCatch); - } else { - readStreamSync = undefined; - readFile(SRCPATH); - frameCountIn = 0; - frameCountOut = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - position = 0; - toStart(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.FLUSH: - mySteps.shift(); - console.info(`case to flush`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toFlush(mySteps, done, callbackExpectFail, failCatch); - } else { - toFlush(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.STOP: - mySteps.shift(); - console.info(`case to stop`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStop(mySteps, done, callbackExpectFail, failCatch); - } else { - toStop(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.RESET: - mySteps.shift(); - console.info(`case to reset`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toReset(mySteps, done, callbackExpectFail, failCatch); - } else { - toReset(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.WAIT_FOR_EOS: - mySteps.shift(); - setTimeout(() =>{ - expect(inputEosFlag).assertTrue(); - if (inputEosFlag == false) { - console.info(`in case error inputEosFlag == false`); - } - toNextStep(mySteps, done); - }, 7000); // wait 7000 ms for eos - break; - case DECODE_STEP.WAIT_FOR_ALL_OUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - default: - break; - } - } - - function setCallback(nextStep){ - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged', (format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - } - - function toCreateVideoDecoderByMime(mime, mySteps, done) { - media.createVideoDecoderByMime(mime).then((processor) => { - console.info(`case createVideoDecoderByMime success`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - function toCreateVideoDecoderByName(name, mySteps, done) { - media.createVideoDecoderByName(name).then((processor) => { - console.info(`case createVideoDecoderByName success`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - async function doneWork() { - await videoDecodeProcessor.stop().then(() => { - console.info('case stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('case reset success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.release().then(() => { - console.info('case release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0100 - * @tc.name : test set EOS manually before last frame and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0200 - * @tc.name : test flush at running state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0300 - * @tc.name : test flush at EOS state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - eosFrameId = 50; - workdoneAtEOS = true; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0400 - * @tc.name : test stop at running state and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0500 - * @tc.name : test stop and restart - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_FUNCTION_PROMISE_01_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0100 - * @tc.name : 001.create -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0300 - * @tc.name : 003.start -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_CONFIGURE_PROMISE_0900', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS , - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_PREPARE_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0100 - * @tc.name : 001.create -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0200 - * @tc.name : 002.configure -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0400 - * @tc.name : 004.start -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0500 - * @tc.name : 005.flush -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0600 - * @tc.name : 006.stop -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.START, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0800 - * @tc.name : 008.reset -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_START_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0100 - * @tc.name : 001.create -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.FLUSH, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0400 - * @tc.name : 004.start -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP , DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_FLUSH_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0100 - * @tc.name : 001.create -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.STOP, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0400 - * @tc.name : 004.start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_STOP_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0100 - * @tc.name : 001.create -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.RESET, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0400 - * @tc.name : 004.start -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_RESET_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_DECODER_API_EOS_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByMime('video/avc', mySteps, done); - }) -}) diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncCallbackTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncCallbackTest.test.js deleted file mode 100644 index 56e16842d..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncCallbackTest.test.js +++ /dev/null @@ -1,542 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('VideoDecoderFuncCallbackTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let inputQueue = []; - let outputQueue = []; - let isCodecData = false; - let inputEosFlag = false; - let surfaceID = ''; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - let ES_FRAME_SIZE = []; - const H264_FRAME_SIZE_240 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124, - 2049, 180, 122, 128, 1334, 143, 128, 1379, 116, 1884, 149, 122, 150, 1962, 176, 122, 122, 1197, 139, - 1853, 184, 151, 148, 1692, 209, 129, 126, 1736, 149, 135, 104, 1775, 165, 160, 121, 1653, 163, 123, - 112, 1907, 181, 129, 107, 1808, 177, 125, 111, 2405, 166, 144, 114, 1833, 198, 136, 113, 1960, 206, - 139, 116, 1791, 175, 130, 129, 1909, 194, 138, 119, 1807, 160, 156, 124, 1998, 184, 173, 114, 2069, 181, - 127, 139, 2212, 182, 138, 146, 1993, 214, 135, 139, 2286, 194, 137, 120, 2090, 196, 159, 132, 2294, 194, - 148, 137, 2312, 183, 163, 106, 2118, 201, 158, 127, 2291, 187, 144, 116, 2413, 139, 115, 2148, 178, 122, - 103, 2370, 207, 161, 117, 2291, 213, 159, 129, 2244, 243, 157, 133, 2418, 255, 171, 127, 2316, 185, 160, - 132, 2405, 220, 165, 155, 2539, 219, 172, 128, 2433, 199, 154, 119, 1681, 140, 1960, 143, 2682, 202, 153, - 127, 2794, 239, 158, 155, 2643, 229, 172, 125, 2526, 201, 181, 159, 2554, 233, 167, 125, 2809, 205, 164, - 117, 2707, 221, 156, 138, 2922, 240, 160, 146, 2952, 267, 177, 149, 3339, 271, 175, 136, 3006, 242, 168, - 141, 3068, 232, 194, 149, 2760, 214, 208, 143, 2811, 218, 184, 149, 137, 15486, 2116, 235, 167, 157, 2894, - 305, 184, 139, 3090, 345, 179, 155, 3226, 347, 160, 164, 3275, 321, 184, 174, 3240, 269, 166, 170, 3773, - 265, 169, 155, 3023, 301, 188, 161, 3343, 275, 174, 155, 3526, 309, 177, 173, 3546, 307, 183, 149, 3648, - 295, 213, 170, 3568, 305, 198, 166, 3641, 297, 172, 148, 3608, 301, 200, 159, 3693, 322, 209, 166, 3453, - 318, 206, 162, 3696, 341, 200, 176, 3386, 320, 192, 176, 3903, 373, 207, 187, 3305, 361, 200, 202, 3110, - 367, 220, 197, 2357, 332, 196, 201, 1827, 377, 187, 199, 860, 472, 173, 223, 238]; - const H263_FRAME_SIZE = - [ 96618, 3515, 4132, 4336, 4646, 3497, 4430, 5437, 7560, 4613, 4876, 4734, 53617, 4079, 4507, 5222, 6244, - 5843, 6601, 6622, 6751, 6539, 7666, 7706, 53977, 7311, 12906, 10308, 26791, 15983, 34794, 22110, 37165, - 24267, 36171, 18330, 53228, 7893, 13088, 9502, 8485, 9207, 8681, 9202, 8537, 7603, 9726, 8191, 51872, - 5535, 6146, 6341, 6933, 9365, 7828, 6547, 7638, 7009, 7025, 8873, 51045, 5056, 4858, 4887, 9614, 5953, - 5972, 6116, 6060, 6296, 6239, 6400, 50928, 4937, 5054, 5371, 6728, 6286, 6524, 6646, 6549, 6036, 6214, - 5866, 51109, 4778, 5273, 6327]; - const MPEG2_FRAME_SIZE = - [ 38462, 55096, 8660, 3417, 1197, 2209, 984, 718, 783, 623, 659, 694, 14174, 580, 421, 495, 480, 476, 534, - 660, 699, 601, 603, 720, 12585, 555, 532, 776, 789, 762, 766, 732, 671, 735, 777, 948, 12650, 827, 766, - 835, 747, 847, 940, 1121, 1092, 1001, 980, 989, 12746, 945, 912, 1046, 1118, 1134, 1050, 1073, 1051, 1195, - 1085, 1182, 12874, 992, 1007, 985, 1040, 1143, 1157, 1150, 1247, 1149, 1246, 1145, 12870, 1041, 1066, 1314, - 1239, 1283, 1223, 1224, 1270, 1427, 1406, 1516, 12949, 1228, 1299, 1439, 1358, 1455, 1311, 1396, 1416, 1470, - 1393, 1502, 12999, 1232, 1400, 1348, 1335, 1461, 1404, 1412, 1426, 1548, 1481, 1488, 12840, 1229, 1342, 1323, - 1353, 1524, 1363, 1475, 1540, 1495, 1489, 1438, 12762, 1291, 1303, 1470, 1494, 1488, 1474, 1453, 1607, 1485, - 1589, 1762, 12548, 1363, 1317, 1435, 1411, 1338, 1373, 1605, 1639, 1429, 1392, 1543, 12332, 1255, 1200, 1291, - 1337, 1341, 1356, 1214, 1456, 1353, 1314, 1502, 12151, 1192, 1290, 1203, 1284, 1154, 1264, 1358, 1390, 1433, - 1194, 1325, 11904, 993, 1007, 1149, 1099, 1182, 1076, 1074, 1092, 1030, 1272, 1178, 11710, 966, 879, 860, 955, - 898, 967, 927, 1066, 997, 1083, 940, 11717, 648, 705, 901, 925, 930, 868, 798, 846, 781, 825, 1027, 11587, 785, - 733, 731, 848, 753, 806, 699, 837, 750, 762, 748, 11541, 678, 742, 667, 735, 702, 837, 695, 773, 849, 869, 769, - 11381, 664, 705, 714, 698, 814, 846, 757, 802, 857, 905, 772, 11265, 718, 643, 597, 687, 774, 843, 747, 785, - 683, 1135, 676, 11259, 616, 595, 773, 746, 798, 722, 798, 790, 959, 771, 907, 11234, 705, 675, 773, 764, 846, - 789, 840, 853, 828, 774, 842, 11263, 758, 758, 757, 820, 847, 834, 884, 842, 988, 750, 952, 11236, 776, 640, 727, - 832, 855, 733, 822, 827, 862, 697, 924, 11176, 675, 615, 688, 818, 783, 746, 901, 834, 892, 759, 923, 11181, 661, - 578, 720, 697]; - const MPEG4_FRAME_SIZE = - [ 11895, 8109, 1578, 1616, 1313, 572, 805, 837, 755, 706, 952, 879, 13193, 422, 389, 509, 725, 465, 479, 959, - 677, 364, 541, 696, 9306, 322, 318, 767, 590, 422, 530, 403, 505, 566, 445, 508, 7783, 460, 405, 343, 451, - 608, 431, 411, 543, 487, 527, 400, 6287, 385, 418, 391, 592, 434, 412, 398, 504, 492, 479, 561, 5413, 317, - 355, 422, 467, 452, 476, 460, 490, 492, 485, 451, 5036, 312, 408, 460, 432, 502, 388, 475, 407, 544, 401, - 487, 4404, 362, 378, 427, 416, 426, 456, 414, 438, 424, 442, 444, 4310, 362, 388, 393, 390, 441, 398, 423, - 369, 443, 406, 392, 4231, 343, 363, 355, 390, 459, 371, 378, 381, 405, 392, 426, 3975, 387, 337, 393, 439, - 378, 355, 374, 484, 381, 373, 423, 3869, 312, 350, 400, 345, 356, 320, 473, 431, 386, 338, 431, 3426, 268, - 315, 416, 383, 373, 381, 354, 383, 328, 348, 418, 3715, 324, 361, 331, 350, 302, 409, 377, 359, 384, 334, - 326, 3439, 266, 324, 329, 353, 405, 303, 357, 332, 292, 361, 333, 3542, 294, 284, 247, 331, 306, 322, 287, - 367, 341, 276, 258, 3980, 246, 245, 259, 309, 333, 250, 275, 334, 281, 253, 371, 3640, 213, 231, 301, 302, - 228, 289, 290, 281, 201, 284, 277, 4242, 205, 328, 237, 283, 295, 266, 230, 321, 348, 212, 308, 4103, 259, - 238, 245, 298, 330, 265, 271, 287, 267, 286, 290, 3856, 269, 242, 209, 314, 267, 278, 280, 314, 250, 433, - 238, 3654, 195, 246, 301, 298, 250, 270, 320, 269, 305, 258, 368, 3810, 231, 212, 279, 289, 252, 303, 287, - 295, 206, 264, 349, 4071, 242, 296, 271, 231, 307, 265, 254, 267, 317, 232, 348, 4077, 259, 222, 268, 235, - 324, 266, 256, 312, 246, 248, 325, 4000, 266, 201, 230, 293, 264, 265, 273, 301, 304, 253, 266, 3978, 228, - 232, 250, 248, 281, 219, 243, 293, 287, 253, 328, 3719]; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = false; - inputEosFlag = false; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: filepath ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case error readFile' + e); - } - } - function getContent(buf, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - lengthReal = readStreamSync.readSync( - buf, - {length: len} - ); - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent: ' + e); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 16.67; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length - 1) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject, (err) => { - if (typeof (err) == 'undefined') { - console.info('in case: queueInput success '); - - } else { - console.info(`in case queueInput err called,errMessage is ${error.message}`); - } - }) - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1 ) { - nextStep(); - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject, (err) => { - if (typeof (err) == 'undefined') { - console.log('in case: release output count:' + frameCountOut); - } else { - console.info(`in case releaseOutput error called,errMessage is ${error.message}`); - } - }) - } - - function setCallback(nextStep){ - console.info('in case: setCallback in'); - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - console.info('in case: setCallback out'); - } - eventEmitter.on('configure', (mediaDescription, srcPath, nextStep, done) => { - console.info('in case : configure in'); - videoDecodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info('in case : configure success'); - readFile(srcPath); - setCallback(nextStep); - eventEmitter.emit('setOutputSurface', done); - }); - }); - eventEmitter.on('setOutputSurface', (done) => { - videoDecodeProcessor.setOutputSurface(surfaceID, true, (err) => { - expect(err).assertUndefined(); - console.info('in case : setOutputSurface success, surfaceID ' + surfaceID); - eventEmitter.emit('prepare', done); - }) - }); - eventEmitter.on('prepare', (done) => { - videoDecodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info('in case : prepare success'); - eventEmitter.emit('start', done); - }); - }); - eventEmitter.on('start', (done) => { - videoDecodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info('in case : start success'); - }); - }); - eventEmitter.on('stop', (done) => { - videoDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info('in case : stop success'); - eventEmitter.emit('reset', done); - }); - }); - eventEmitter.on('reset', (done) => { - videoDecodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info('in case : reset success'); - eventEmitter.emit('release', done); - }); - }); - eventEmitter.on('release', (done) => { - videoDecodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info('in case : release success'); - videoDecodeProcessor = null; - done(); - }); - }); - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_H264_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_H264_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByName('avdec_h264', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByName success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG2_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG2_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG2_FRAME_SIZE; - let srcPath = BASIC_PATH + 'MPEG2_720_480.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mpeg2', - 'width': 720, - 'height': 480, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByName('avdec_mpeg2video', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByName success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG4_CALLBACK_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG4_CALLBACK_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG4_FRAME_SIZE; - let srcPath = BASIC_PATH + 'mpeg4_320_240.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mp4v-es', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - media.createVideoDecoderByName('avdec_mpeg4', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByName success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0600 - * @tc.name : test reconfigure for new file with the same format - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0600', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - eventEmitter.on('stop_for_callback_01_0600', (done) => { - videoDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info('in case : stop_for_callback_01_0600 success'); - eventEmitter.emit('reset_for_callback_01_0600', done); - }); - }); - eventEmitter.on('reset_for_callback_01_0600', (done) => { - videoDecodeProcessor.reset(async (err) => { - expect(err).assertUndefined(); - console.info('in case : reset_for_callback_01_0600 success'); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - readStreamSync = null; - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - surfaceID = globalThis.value; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, done); - }); - }); - media.createVideoDecoderByName('avdec_h264', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByName success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop_for_callback_01_0600', done); - }, done); - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0700 - * @tc.name : test reconfigure for new file with the different format - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0700', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - eventEmitter.on('stop_for_callback_01_0700', (done) => { - videoDecodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info('in case : stop_for_callback_01_0700 success'); - eventEmitter.emit('reset_for_callback_01_0700', done); - }); - }); - eventEmitter.on('reset_for_callback_01_0700', (done) => { - videoDecodeProcessor.reset(async (err) => { - expect(err).assertUndefined(); - console.info('in case : reset_for_callback_01_0700 success'); - srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - readStreamSync = null; - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - surfaceID = globalThis.value; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop', done); - }, done); - }); - }); - media.createVideoDecoderByName('avdec_h264', (err, processor) => { - expect(err).assertUndefined(); - console.info('in case : createVideoDecoderByName success'); - videoDecodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription, srcPath, - function() { - eventEmitter.emit('stop_for_callback_01_0700', done); - }, done); - }); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncPromiseTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncPromiseTest.test.js deleted file mode 100644 index 91649e34d..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareFuncPromiseTest.test.js +++ /dev/null @@ -1,537 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - - -describe('VideoDecoderFuncPromiseTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let inputQueue = []; - let outputQueue = []; - let isCodecData = false; - let inputEosFlag = false; - let surfaceID = ''; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - let ES_FRAME_SIZE = []; - const H264_FRAME_SIZE_240 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124, - 2049, 180, 122, 128, 1334, 143, 128, 1379, 116, 1884, 149, 122, 150, 1962, 176, 122, 122, 1197, 139, - 1853, 184, 151, 148, 1692, 209, 129, 126, 1736, 149, 135, 104, 1775, 165, 160, 121, 1653, 163, 123, - 112, 1907, 181, 129, 107, 1808, 177, 125, 111, 2405, 166, 144, 114, 1833, 198, 136, 113, 1960, 206, - 139, 116, 1791, 175, 130, 129, 1909, 194, 138, 119, 1807, 160, 156, 124, 1998, 184, 173, 114, 2069, 181, - 127, 139, 2212, 182, 138, 146, 1993, 214, 135, 139, 2286, 194, 137, 120, 2090, 196, 159, 132, 2294, 194, - 148, 137, 2312, 183, 163, 106, 2118, 201, 158, 127, 2291, 187, 144, 116, 2413, 139, 115, 2148, 178, 122, - 103, 2370, 207, 161, 117, 2291, 213, 159, 129, 2244, 243, 157, 133, 2418, 255, 171, 127, 2316, 185, 160, - 132, 2405, 220, 165, 155, 2539, 219, 172, 128, 2433, 199, 154, 119, 1681, 140, 1960, 143, 2682, 202, 153, - 127, 2794, 239, 158, 155, 2643, 229, 172, 125, 2526, 201, 181, 159, 2554, 233, 167, 125, 2809, 205, 164, - 117, 2707, 221, 156, 138, 2922, 240, 160, 146, 2952, 267, 177, 149, 3339, 271, 175, 136, 3006, 242, 168, - 141, 3068, 232, 194, 149, 2760, 214, 208, 143, 2811, 218, 184, 149, 137, 15486, 2116, 235, 167, 157, 2894, - 305, 184, 139, 3090, 345, 179, 155, 3226, 347, 160, 164, 3275, 321, 184, 174, 3240, 269, 166, 170, 3773, - 265, 169, 155, 3023, 301, 188, 161, 3343, 275, 174, 155, 3526, 309, 177, 173, 3546, 307, 183, 149, 3648, - 295, 213, 170, 3568, 305, 198, 166, 3641, 297, 172, 148, 3608, 301, 200, 159, 3693, 322, 209, 166, 3453, - 318, 206, 162, 3696, 341, 200, 176, 3386, 320, 192, 176, 3903, 373, 207, 187, 3305, 361, 200, 202, 3110, - 367, 220, 197, 2357, 332, 196, 201, 1827, 377, 187, 199, 860, 472, 173, 223, 238]; - const H263_FRAME_SIZE = - [ 96618, 3515, 4132, 4336, 4646, 3497, 4430, 5437, 7560, 4613, 4876, 4734, 53617, 4079, 4507, 5222, 6244, - 5843, 6601, 6622, 6751, 6539, 7666, 7706, 53977, 7311, 12906, 10308, 26791, 15983, 34794, 22110, 37165, - 24267, 36171, 18330, 53228, 7893, 13088, 9502, 8485, 9207, 8681, 9202, 8537, 7603, 9726, 8191, 51872, - 5535, 6146, 6341, 6933, 9365, 7828, 6547, 7638, 7009, 7025, 8873, 51045, 5056, 4858, 4887, 9614, 5953, - 5972, 6116, 6060, 6296, 6239, 6400, 50928, 4937, 5054, 5371, 6728, 6286, 6524, 6646, 6549, 6036, 6214, - 5866, 51109, 4778, 5273, 6327]; - const MPEG2_FRAME_SIZE = - [ 38462, 55096, 8660, 3417, 1197, 2209, 984, 718, 783, 623, 659, 694, 14174, 580, 421, 495, 480, 476, 534, - 660, 699, 601, 603, 720, 12585, 555, 532, 776, 789, 762, 766, 732, 671, 735, 777, 948, 12650, 827, 766, - 835, 747, 847, 940, 1121, 1092, 1001, 980, 989, 12746, 945, 912, 1046, 1118, 1134, 1050, 1073, 1051, 1195, - 1085, 1182, 12874, 992, 1007, 985, 1040, 1143, 1157, 1150, 1247, 1149, 1246, 1145, 12870, 1041, 1066, 1314, - 1239, 1283, 1223, 1224, 1270, 1427, 1406, 1516, 12949, 1228, 1299, 1439, 1358, 1455, 1311, 1396, 1416, 1470, - 1393, 1502, 12999, 1232, 1400, 1348, 1335, 1461, 1404, 1412, 1426, 1548, 1481, 1488, 12840, 1229, 1342, 1323, - 1353, 1524, 1363, 1475, 1540, 1495, 1489, 1438, 12762, 1291, 1303, 1470, 1494, 1488, 1474, 1453, 1607, 1485, - 1589, 1762, 12548, 1363, 1317, 1435, 1411, 1338, 1373, 1605, 1639, 1429, 1392, 1543, 12332, 1255, 1200, 1291, - 1337, 1341, 1356, 1214, 1456, 1353, 1314, 1502, 12151, 1192, 1290, 1203, 1284, 1154, 1264, 1358, 1390, 1433, - 1194, 1325, 11904, 993, 1007, 1149, 1099, 1182, 1076, 1074, 1092, 1030, 1272, 1178, 11710, 966, 879, 860, 955, - 898, 967, 927, 1066, 997, 1083, 940, 11717, 648, 705, 901, 925, 930, 868, 798, 846, 781, 825, 1027, 11587, 785, - 733, 731, 848, 753, 806, 699, 837, 750, 762, 748, 11541, 678, 742, 667, 735, 702, 837, 695, 773, 849, 869, 769, - 11381, 664, 705, 714, 698, 814, 846, 757, 802, 857, 905, 772, 11265, 718, 643, 597, 687, 774, 843, 747, 785, - 683, 1135, 676, 11259, 616, 595, 773, 746, 798, 722, 798, 790, 959, 771, 907, 11234, 705, 675, 773, 764, 846, - 789, 840, 853, 828, 774, 842, 11263, 758, 758, 757, 820, 847, 834, 884, 842, 988, 750, 952, 11236, 776, 640, 727, - 832, 855, 733, 822, 827, 862, 697, 924, 11176, 675, 615, 688, 818, 783, 746, 901, 834, 892, 759, 923, 11181, 661, - 578, 720, 697]; - const MPEG4_FRAME_SIZE = - [ 11895, 8109, 1578, 1616, 1313, 572, 805, 837, 755, 706, 952, 879, 13193, 422, 389, 509, 725, 465, 479, 959, - 677, 364, 541, 696, 9306, 322, 318, 767, 590, 422, 530, 403, 505, 566, 445, 508, 7783, 460, 405, 343, 451, - 608, 431, 411, 543, 487, 527, 400, 6287, 385, 418, 391, 592, 434, 412, 398, 504, 492, 479, 561, 5413, 317, - 355, 422, 467, 452, 476, 460, 490, 492, 485, 451, 5036, 312, 408, 460, 432, 502, 388, 475, 407, 544, 401, - 487, 4404, 362, 378, 427, 416, 426, 456, 414, 438, 424, 442, 444, 4310, 362, 388, 393, 390, 441, 398, 423, - 369, 443, 406, 392, 4231, 343, 363, 355, 390, 459, 371, 378, 381, 405, 392, 426, 3975, 387, 337, 393, 439, - 378, 355, 374, 484, 381, 373, 423, 3869, 312, 350, 400, 345, 356, 320, 473, 431, 386, 338, 431, 3426, 268, - 315, 416, 383, 373, 381, 354, 383, 328, 348, 418, 3715, 324, 361, 331, 350, 302, 409, 377, 359, 384, 334, - 326, 3439, 266, 324, 329, 353, 405, 303, 357, 332, 292, 361, 333, 3542, 294, 284, 247, 331, 306, 322, 287, - 367, 341, 276, 258, 3980, 246, 245, 259, 309, 333, 250, 275, 334, 281, 253, 371, 3640, 213, 231, 301, 302, - 228, 289, 290, 281, 201, 284, 277, 4242, 205, 328, 237, 283, 295, 266, 230, 321, 348, 212, 308, 4103, 259, - 238, 245, 298, 330, 265, 271, 287, 267, 286, 290, 3856, 269, 242, 209, 314, 267, 278, 280, 314, 250, 433, - 238, 3654, 195, 246, 301, 298, 250, 270, 320, 269, 305, 258, 368, 3810, 231, 212, 279, 289, 252, 303, 287, - 295, 206, 264, 349, 4071, 242, 296, 271, 231, 307, 265, 254, 267, 317, 232, 348, 4077, 259, 222, 268, 235, - 324, 266, 256, 312, 246, 248, 325, 4000, 266, 201, 230, 293, 264, 265, 273, 301, 304, 253, 266, 3978, 228, - 232, 250, 248, 281, 219, 243, 293, 287, 253, 328, 3719]; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = false; - inputEosFlag = false; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${error.message}`); - expect(err).assertUndefined(); - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: filepath ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.error('in case readFile' + e); - } - } - - function getContent(buf, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - lengthReal = readStreamSync.readSync( - buf, - {length: len} - ); - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent ' + e); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 16.67; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length - 1) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject).then(() => { - console.info('in case: queueInput success '); - }, failCallback).catch(failCatch); - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1) { - nextStep(); - return; - } - frameCountOut++; - await videoDecodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.log('in case: release output count:' + frameCountOut); - }, failCallback).catch(failCatch); - } - - function setCallback(nextStep){ - console.info('in case: setCallback in'); - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - console.info('in case: setCallback out'); - } - - async function toCreateVideoDecoderByMime(mime, done) { - await media.createVideoDecoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoDecodeProcessor = processor; - console.info('in case : createVideoDecoderByMime success'); - } else { - console.info('in case : createVideoDecoderByMime fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - async function toCreateVideoDecoderByName(name, done) { - await media.createVideoDecoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoDecodeProcessor = processor; - console.info('in case : createVideoDecoderByName success'); - } else { - console.info('in case : createVideoDecoderByName fail'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - async function toConfigure(mediaDescription, srcPath) { - await videoDecodeProcessor.configure(mediaDescription).then(() =>{ - console.info('in case : configure success'); - readFile(srcPath); - }, failCallback).catch(failCatch); - } - async function toSetOutputSurface(isDisplay) { - await videoDecodeProcessor.setOutputSurface(surfaceID, isDisplay).then(() => { - console.info('in case : setOutputSurface success. surfaceID ' + surfaceID); - }, failCallback).catch(failCatch); - } - eventEmitter.on('nextStep', async (done) => { - console.info('in case : nextStep success'); - await videoDecodeProcessor.stop().then(() => { - console.info('in case : stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('in case : reset success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.release().then(() => { - console.info('in case : release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - console.info('in case : done'); - done(); - }); - async function toPrepare() { - await videoDecodeProcessor.prepare().then(() => { - console.info('in case : prepare success'); - }, failCallback).catch(failCatch); - } - async function toStart() { - await videoDecodeProcessor.start().then(() => { - console.info('in case : start success'); - }, failCallback).catch(failCatch); - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_H264_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_H264_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByName('avdec_h264', done); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG2_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG2_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG2_FRAME_SIZE; - let srcPath = BASIC_PATH + 'MPEG2_720_480.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mpeg2', - 'width': 720, - 'height': 480, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByName('avdec_mpeg2video', done); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG4_PROMISE_0100 - * @tc.name : 001.basic Video decode function - * @tc.desc : start-> EOS -> stop -> reset - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_MPEG4_PROMISE_0100', 0, async function (done) { - ES_FRAME_SIZE = MPEG4_FRAME_SIZE; - let srcPath = BASIC_PATH + 'mpeg4_320_240.es'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/mp4v-es', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByName('avdec_mpeg4', done); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0600 - * @tc.name : test reconfigure for new file with the same format - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0600', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByName('avdec_h264', done); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - eventEmitter.once('reConfigure_for_promise_01_0600', async (done) => { - console.info('in case : reConfigure_for_promise_01_0600 success'); - await videoDecodeProcessor.stop().then(() => { - console.info('in case : stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('in case : reset success'); - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - readStreamSync = null; - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - surfaceID = globalThis.value; - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }); - setCallback( - function(){eventEmitter.emit('reConfigure_for_promise_01_0600', done);} - ); - await toPrepare(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0700 - * @tc.name : test reconfigure for new file with the different format - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0700', 0, async function (done) { - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - isCodecData = true; - let srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - await toCreateVideoDecoderByName('avdec_h264', done); - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - srcPath = BASIC_PATH + 'out_320_240_10s.h264'; - mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60.00, - 'max_input_size': 150000, - } - eventEmitter.on('reConfigure_for_promise_01_0700', async (done) => { - console.info('in case : reConfigure_for_promise_01_0700 success'); - await videoDecodeProcessor.stop().then(() => { - console.info('in case : stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('in case : reset success'); - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - readStreamSync = null; - ES_FRAME_SIZE = H264_FRAME_SIZE_240; - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - surfaceID = globalThis.value; - await toConfigure(mediaDescription, srcPath); - await toSetOutputSurface(true); - setCallback( - function(){eventEmitter.emit('nextStep', done);} - ); - await toPrepare(); - await toStart(); - }); - setCallback( - function(){eventEmitter.emit('reConfigure_for_promise_01_0700', done);} - ); - await toPrepare(); - await toStart(); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliCallbackTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliCallbackTest.test.js deleted file mode 100644 index a17198490..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliCallbackTest.test.js +++ /dev/null @@ -1,1278 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' -export -const DECODE_STEP = { - WAIT_FOR_EOS : 'waitForEOS', - CONFIGURE : 'configure', - SETSURFACE : 'setSurface', - PREPARE : 'prepare', - START : 'start', - FLUSH : 'flush', - STOP : 'stop', - RESET : 'reset', - WAIT_FOR_ALL_OUTS : 'waitForAllOuts', - ERROR : 'error', - RELEASE : 'release', -} - -describe('VideoDecoderSoftwareReliCallbackTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let position = 0; - let eosFrameId = -1; - let inputQueue = []; - let outputQueue = []; - let isCodecData = true; - let inputEosFlag = false; - let workdoneAtEOS = false; - let surfaceID = ''; - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - const SRCPATH = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60, - 'max_input_size': 150000, - } - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - let ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - workdoneAtEOS = false; - eosFrameId = -1; - inputEosFlag = false; - position = 0; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let failCallback = function(err) { - console.info(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.info(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - function printError(err, expectFail) { - expect((err != undefined) == expectFail).assertTrue(); - if (expectFail == false && err != undefined) { - console.info('in case error failCatch called,err is ' + err); - console.info(`in case error failCatch called,errMessage is ${err.message}`); - } - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: file path ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case readFile' + e); - } - } - - function getContent(buf, pos, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - if (pos == -1) { - lengthReal = readStreamSync.readSync(buf, { - length: len, - }); - } else { - lengthReal = readStreamSync.readSync(buf, { - length: len, - position: pos, - }); - } - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent err ' + err); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, position, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - position = position + ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 1000 / mediaDescription.frame_rate; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length || frameCountIn == eosFrameId) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject, (err) => { - console.info('in case: queueInput success '); - }) - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1 ) { - if (workdoneAtEOS) { - doneWork(nextStep); - } - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject, () => { - console.log('in case: release output count:' + frameCountOut); - }) - } - - function toConfigure(mySteps, done, expectFail) { - videoDecodeProcessor.configure(mediaDescription, (err) => { - console.info(`case configure callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }) - } - function toPrepare(mySteps, done, expectFail) { - videoDecodeProcessor.prepare((err) => { - console.info(`case prepare callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toStart(mySteps, done, expectFail) { - let timeDelay = 0; - videoDecodeProcessor.start((err) => { - console.info(`case start callback`); - printError(err, expectFail); - if (mySteps[0] == DECODE_STEP.FLUSH) { - timeDelay = 500; - } - setTimeout(() => { - toNextStep(mySteps, done); - }, timeDelay); - }); - } - function toFlush(mySteps, done, expectFail) { - videoDecodeProcessor.flush((err) => { - console.info(`case flush callback`); - printError(err, expectFail); - if (expectFail == false) { - inputEosFlag = false; - position = ES_FRAME_SIZE[0]; - inputQueue = []; - timestamp = 0; - frameCountIn = 1; - } - toNextStep(mySteps, done); - }); - } - function toStop(mySteps, done, expectFail) { - videoDecodeProcessor.stop((err) => { - console.info(`case stop callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toReset(mySteps, done, expectFail) { - videoDecodeProcessor.reset((err) => { - console.info(`case reset callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toSetOutputSurface(mySteps, done, expectFail) { - videoDecodeProcessor.setOutputSurface(surfaceID, true, (err) => { - console.info('case setOutputSurface callback, surfaceID ' + surfaceID); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - - function toNextStep(mySteps, done) { - console.info('case myStep[0]: ' + mySteps[0]); - if (mySteps[0] == DECODE_STEP.RELEASE) { - if (videoDecodeProcessor != null){ - videoDecodeProcessor.release((err) => { - printError(err, false); - console.info('in case : videoDecodeProcessor release callback'); - videoDecodeProcessor = null; - console.info('case to done'); - done(); - }); - } - return; - } - switch (mySteps[0]) { - case DECODE_STEP.CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toConfigure(mySteps, done, true); - } else { - toConfigure(mySteps, done, false); - } - break; - case DECODE_STEP.SETSURFACE: - mySteps.shift(); - console.info(`case to setOutputSurface`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toSetOutputSurface(mySteps, done, true); - } else { - toSetOutputSurface(mySteps, done, false); - } - break; - case DECODE_STEP.PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toPrepare(mySteps, done, true); - } else { - toPrepare(mySteps, done, false); - } - break; - case DECODE_STEP.START: - mySteps.shift(); - console.info(`case to start`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStart(mySteps, done, true); - } else { - readStreamSync = undefined; - readFile(SRCPATH); - frameCountIn = 0; - frameCountOut = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - position = 0; - toStart(mySteps, done, false); - } - break; - case DECODE_STEP.FLUSH: - mySteps.shift(); - console.info(`case to flush`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toFlush(mySteps, done, true); - } else { - toFlush(mySteps, done, false); - } - break; - case DECODE_STEP.STOP: - mySteps.shift(); - console.info(`case to stop`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStop(mySteps, done, true); - } else { - toStop(mySteps, done, false); - } - break; - case DECODE_STEP.RESET: - mySteps.shift(); - console.info(`case to reset`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toReset(mySteps, done, true); - } else { - toReset(mySteps, done, false); - } - break; - case DECODE_STEP.WAIT_FOR_EOS: - mySteps.shift(); - setTimeout(() =>{ - expect(inputEosFlag).assertTrue(); - if (inputEosFlag == false) { - console.info(`in case error wait for eos: inputEosFlag = false`); - } - toNextStep(mySteps, done); - }, 7000); // wait 7000 ms for eos - break; - case DECODE_STEP.WAIT_FOR_ALL_OUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - default: - break; - } - } - - function setCallback(nextStep){ - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged',(format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - } - - function toCreateVideoDecoderByMime(mime, mySteps, done) { - media.createVideoDecoderByMime(mime, (err, processor) => { - console.info(`case createVideoDecoderByMime callback`); - printError(err, false); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }) - } - function toCreateVideoDecoderByName(name, mySteps, done) { - media.createVideoDecoderByName(name, (err, processor) => { - printError(err, false); - console.info(`case createVideoDecoderByName callback`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }) - } - async function doneWork(nextStep) { - videoDecodeProcessor.stop((err) => { - printError(err, false); - console.info('case stop callback'); - videoDecodeProcessor.reset((err) => { - printError(err, false); - console.info('case reset callback'); - videoDecodeProcessor.release((err) => { - printError(err, false); - console.info('case release callback'); - videoDecodeProcessor = null; - nextStep(); - }) - }) - }) - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0100 - * @tc.name : test set EOS manually before last frame and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0200 - * @tc.name : test flush at running state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0300 - * @tc.name : test flush at EOS state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - eosFrameId = 50; - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0400 - * @tc.name : test stop at running state and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0500 - * @tc.name : test stop and restart - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_CALLBACK_01_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0100 - * @tc.name : 001.create -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0300 - * @tc.name : 003.start -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_CALLBACK_0900', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS , - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0100 - * @tc.name : 001.create -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0200 - * @tc.name : 002.configure -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0400 - * @tc.name : 004.start -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0500 - * @tc.name : 005.flush -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0600 - * @tc.name : 006.stop -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.START, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0800 - * @tc.name : 008.reset -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0100 - * @tc.name : 001.create -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.FLUSH, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0400 - * @tc.name : 004.start -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP , DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0100 - * @tc.name : 001.create -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.STOP, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0400 - * @tc.name : 004.start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0100 - * @tc.name : 001.create -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.RESET, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0400 - * @tc.name : 004.start -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_CALLBACK_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_CALLBACK_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) -}) diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliPromiseTest.test.js b/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliPromiseTest.test.js deleted file mode 100644 index bddb11fc0..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/js/test/VideoDecoderSoftwareReliPromiseTest.test.js +++ /dev/null @@ -1,1271 +0,0 @@ -/* - * 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 Fileio from '@ohos.fileio' -import router from '@system.router' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' -export -const DECODE_STEP = { - WAIT_FOR_EOS : 'waitForEOS', - CONFIGURE : 'configure', - SETSURFACE : 'setSurface', - PREPARE : 'prepare', - START : 'start', - FLUSH : 'flush', - STOP : 'stop', - RESET : 'reset', - WAIT_FOR_ALL_OUTS : 'waitForAllOuts', - ERROR : 'error', - RELEASE : 'release', -} - -describe('VideoDecoderSoftwareReliPromiseTest', function () { - let videoDecodeProcessor = null; - let readStreamSync = undefined; - let frameCountIn = 0; - let frameCountOut = 0; - let timestamp = 0; - let position = 0; - let eosFrameId = -1; - let inputQueue = []; - let outputQueue = []; - let isCodecData = true; - let inputEosFlag = false; - let workdoneAtEOS = false; - let surfaceID = ''; - const BASIC_PATH = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videodecoder/'; - const SRCPATH = BASIC_PATH + 'out_320_240_10s.h264'; - let mediaDescription = { - 'track_type': 1, - 'codec_mime': 'video/avc', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 60, - 'max_input_size': 150000, - } - const H264_FRAME_SIZE_60FPS_320 = - [ 2106, 11465, 321, 72, 472, 68, 76, 79, 509, 90, 677, 88, 956, 99, 347, 77, 452, 681, 81, 1263, 94, 106, 97, - 998, 97, 797, 93, 1343, 150, 116, 117, 926, 1198, 128, 110, 78, 1582, 158, 135, 112, 1588, 165, 132, - 128, 1697, 168, 149, 117, 1938, 170, 141, 142, 1830, 106, 161, 122, 1623, 160, 154, 156, 1998, 230, - 177, 139, 1650, 186, 128, 134, 1214, 122, 1411, 120, 1184, 128, 1591, 195, 145, 105, 1587, 169, 140, - 118, 1952, 177, 150, 161, 1437, 159, 123, 1758, 180, 165, 144, 1936, 214, 191, 175, 2122, 180, 179, - 160, 1927, 161, 184, 119, 1973, 218, 210, 129, 1962, 196, 127, 154, 2308, 173, 127, 1572, 142, 122, - 2065, 262, 159, 206, 2251, 269, 179, 170, 2056, 308, 168, 191, 2090, 303, 191, 110, 1932, 272, 162, - 122, 1877, 245, 167, 141, 1908, 294, 162, 118, 1493, 132, 1782, 273, 184, 133, 1958, 274, 180, 149, - 2070, 216, 169, 143, 1882, 224, 149, 139, 1749, 277, 184, 139, 2141, 197, 170, 140, 2002, 269, 162, - 140, 1862, 202, 179, 131, 1868, 214, 164, 140, 1546, 226, 150, 130, 1707, 162, 146, 1824, 181, 147, - 130, 1898, 209, 143, 131, 1805, 180, 148, 106, 1776, 147, 141, 1572, 177, 130, 105, 1776, 178, 144, - 122, 1557, 142, 124, 114, 1436, 143, 126, 1326, 127, 1755, 169, 127, 105, 1807, 177, 131, 134, 1613, - 187, 137, 136, 1314, 134, 118, 2005, 194, 129, 147, 1566, 185, 132, 131, 1236, 174, 137, 106, 11049, - 574, 126, 1242, 188, 130, 119, 1450, 187, 137, 141, 1116, 124, 1848, 138, 122, 1605, 186, 127, 140, - 1798, 170, 124, 121, 1666, 157, 128, 130, 1678, 135, 118, 1804, 169, 135, 125, 1837, 168, 124, 124]; - let ES_FRAME_SIZE = H264_FRAME_SIZE_60FPS_320; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await toDisplayPage().then(() => { - }, failCallback).catch(failCatch); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - frameCountIn = 0; - frameCountOut = 0; - timestamp = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - workdoneAtEOS = false; - eosFrameId = -1; - inputEosFlag = false; - position = 0; - surfaceID = globalThis.value; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoDecodeProcessor != null) { - await videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - await router.clear().then(() => { - }, failCallback).catch(failCatch); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let caseCallback = function(err) { - console.info(`in case caseCallback called, caseMessage is ${err.message}`); - } - let failCallback = function(err) { - console.error(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.error(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let callbackExpectOK = function(err, mySteps, done) { - console.error(`in case error callbackExpectOK called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - toNextStep(mySteps, done); - } - let callbackExpectFail = function(err, mySteps, done) { - console.info(`in case callbackExpectFail called, errMessage is ${err.message}`); - expect(err != undefined).assertTrue(); - toNextStep(mySteps, done); - } - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - async function toDisplayPage() { - let path = 'pages/display/display'; - let options = { - uri: path, - } - try { - await router.push(options); - } catch (e) { - console.error('in case toDisplayPage' + e); - } - } - function readFile(path){ - console.info('in case : read file start execution'); - try { - console.info('in case: file path ' + path); - readStreamSync = Fileio.createStreamSync(path, 'rb'); - } catch(e) { - console.info('in case readFile' + e); - } - } - - function getContent(buf, pos, len) { - console.info('start get content, len ' + len + ' buf.byteLength ' + buf.byteLength); - let lengthReal = -1; - try { - if (pos == -1) { - lengthReal = readStreamSync.readSync(buf, { - length: len, - }); - } else { - lengthReal = readStreamSync.readSync(buf, { - length: len, - position: pos, - }); - } - console.info('in case: lengthReal: ' + lengthReal); - } catch(e) { - console.error('in case error getContent err ' + err); - } - } - - /* push inputbuffers into codec */ - async function enqueueInputs(inputObject) { - console.log('in case: inputObject.index: ' + inputObject.index); - if (frameCountIn < ES_FRAME_SIZE.length) { - getContent(inputObject.data, position, ES_FRAME_SIZE[frameCountIn]); - inputObject.timeMs = timestamp; - inputObject.offset = 0; - inputObject.length = ES_FRAME_SIZE[frameCountIn]; - position = position + ES_FRAME_SIZE[frameCountIn]; - console.info('in case: frameCountIn ' + frameCountIn); - frameCountIn++; - timestamp += 1000 / mediaDescription.frame_rate; - } - if (isCodecData) { - inputObject.flags = 8; - isCodecData = false; - timestamp = 0; - } else if (frameCountIn >= ES_FRAME_SIZE.length || frameCountIn == eosFrameId) { - inputObject.flags = 1; - inputEosFlag = true; - } else { - inputObject.flags = 4; - } - videoDecodeProcessor.pushInputData(inputObject).then(() => { - console.info('in case: queueInput success '); - }, caseCallback).catch(failCatch); - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(nextStep, outputObject) { - if (outputObject.flags == 1 ) { - if (workdoneAtEOS) { - await doneWork(); - nextStep(); - } - return; - } - frameCountOut++; - videoDecodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.info('in case: release output success'); - console.log('in case: release output count:' + frameCountOut); - }, caseCallback).catch(failCatch); - } - - function toConfigure(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toPrepare(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.prepare().then(() => { - console.info(`case prepare success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toStart(mySteps, done, failureCallback, catchCallback) { - let timeDelay = 0; - videoDecodeProcessor.start().then(() => { - console.info(`case start success`); - if (mySteps[0] == DECODE_STEP.FLUSH) { - timeDelay = 500; - } - setTimeout(() => { - toNextStep(mySteps, done); - }, timeDelay); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toFlush(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.flush().then(() => { - console.info(`case flush success`); - position = ES_FRAME_SIZE[0]; - inputQueue = []; - timestamp = 0; - inputEosFlag = false; - frameCountIn = 1; - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toStop(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.stop().then(() => { - console.info(`case stop success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toReset(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.reset().then(() => { - console.info(`case reset success`); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - function toSetOutputSurface(mySteps, done, failureCallback, catchCallback) { - videoDecodeProcessor.setOutputSurface(surfaceID, true).then(() => { - console.info('in case : setOutputSurface success, surfaceID ' + surfaceID); - toNextStep(mySteps, done); - }, (err) => {failureCallback(err, mySteps, done)}).catch(catchCallback); - } - - function toNextStep(mySteps, done) { - console.info('case myStep[0]: ' + mySteps[0]); - if (mySteps[0] == DECODE_STEP.RELEASE) { - if (videoDecodeProcessor != null) { - videoDecodeProcessor.release().then(() => { - console.info('in case : videoDecodeProcessor release success'); - videoDecodeProcessor = null; - console.info('case to done'); - done(); - }, failCallback).catch(failCatch); - } - return; - } - switch (mySteps[0]) { - case DECODE_STEP.CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toConfigure(mySteps, done, callbackExpectFail, failCatch); - } else { - toConfigure(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.SETSURFACE: - mySteps.shift(); - console.info(`case to setOutputSurface`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toSetOutputSurface(mySteps, done, callbackExpectFail, failCatch); - } else { - toSetOutputSurface(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toPrepare(mySteps, done, callbackExpectFail, failCatch); - } else { - toPrepare(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.START: - mySteps.shift(); - console.info(`case to start`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStart(mySteps, done, callbackExpectFail, failCatch); - } else { - readStreamSync = undefined; - readFile(SRCPATH); - frameCountIn = 0; - frameCountOut = 0; - inputQueue = []; - outputQueue = []; - isCodecData = true; - inputEosFlag = false; - position = 0; - toStart(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.FLUSH: - mySteps.shift(); - console.info(`case to flush`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toFlush(mySteps, done, callbackExpectFail, failCatch); - } else { - toFlush(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.STOP: - mySteps.shift(); - console.info(`case to stop`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toStop(mySteps, done, callbackExpectFail, failCatch); - } else { - toStop(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.RESET: - mySteps.shift(); - console.info(`case to reset`); - if (mySteps[0] == DECODE_STEP.ERROR) { - mySteps.shift(); - toReset(mySteps, done, callbackExpectFail, failCatch); - } else { - toReset(mySteps, done, callbackExpectOK, failCatch); - } - break; - case DECODE_STEP.WAIT_FOR_EOS: - mySteps.shift(); - setTimeout(() =>{ - expect(inputEosFlag).assertTrue(); - if (inputEosFlag == false) { - console.info(`in case error inputEosFlag == false`); - } - toNextStep(mySteps, done); - }, 7000); // wait 7000 ms for eos - break; - case DECODE_STEP.WAIT_FOR_ALL_OUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - default: - break; - } - } - - function setCallback(nextStep){ - videoDecodeProcessor.on('needInputData', async (inBuffer) => { - console.info('in case: inputBufferAvailable inBuffer.index: '+ inBuffer.index); - enqueueInputs(inBuffer); - }); - - videoDecodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - dequeueOutputs(nextStep, outBuffer); - }); - - videoDecodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoDecodeProcessor.on('streamChanged', (format) => { - console.info('in case: Output format changed: ' + format.toString()); - }); - } - - function toCreateVideoDecoderByMime(mime, mySteps, done) { - media.createVideoDecoderByMime(mime).then((processor) => { - console.info(`case createVideoDecoderByMime success`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - function toCreateVideoDecoderByName(name, mySteps, done) { - media.createVideoDecoderByName(name).then((processor) => { - console.info(`case createVideoDecoderByName success`); - videoDecodeProcessor = processor; - setCallback(done); - toNextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - async function doneWork() { - await videoDecodeProcessor.stop().then(() => { - console.info('case stop success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.reset().then(() => { - console.info('case reset success'); - }, failCallback).catch(failCatch); - await videoDecodeProcessor.release().then(() => { - console.info('case release success'); - }, failCallback).catch(failCatch); - videoDecodeProcessor = null; - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0100 - * @tc.name : test set EOS manually before last frame and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0200 - * @tc.name : test flush at running state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.WAIT_FOR_ALL_OUTS); - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0300 - * @tc.name : test flush at EOS state - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_ALL_OUTS); - eosFrameId = 50; - workdoneAtEOS = true; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0400 - * @tc.name : test stop at running state and reset - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0500 - * @tc.name : test stop and restart - * @tc.desc : test basic function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_FUNCTION_PROMISE_01_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0100 - * @tc.name : 001.create -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0300 - * @tc.name : 003.start -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.CONFIGURE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_CONFIGURE_PROMISE_0900', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS , - DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_PREPARE_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.PREPARE, DECODE_STEP.ERROR, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0100 - * @tc.name : 001.create -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0200 - * @tc.name : 002.configure -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0400 - * @tc.name : 004.start -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0500 - * @tc.name : 005.flush -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0600 - * @tc.name : 006.stop -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.START, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0800 - * @tc.name : 008.reset -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_START_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.START, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0100 - * @tc.name : 001.create -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.FLUSH, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0400 - * @tc.name : 004.start -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP , DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_FLUSH_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.FLUSH, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0100 - * @tc.name : 001.create -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.STOP, - DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0400 - * @tc.name : 004.start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_STOP_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.STOP, DECODE_STEP.ERROR, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0100 - * @tc.name : 001.create -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.RESET, - DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0400 - * @tc.name : 004.start -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.FLUSH, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0600', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.STOP, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0700', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_RESET_PROMISE_0800', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.RESET, DECODE_STEP.RESET, DECODE_STEP.RELEASE); - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0100', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0200', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.FLUSH, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0300', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.RESET, DECODE_STEP.CONFIGURE, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0400', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_DECODER_API_EOS_PROMISE_0500', 0, async function (done) { - let mySteps = new Array(DECODE_STEP.CONFIGURE, DECODE_STEP.SETSURFACE, DECODE_STEP.PREPARE, DECODE_STEP.START, - DECODE_STEP.WAIT_FOR_EOS, DECODE_STEP.STOP, DECODE_STEP.START, DECODE_STEP.STOP, DECODE_STEP.RELEASE); - eosFrameId = 50; - toCreateVideoDecoderByName('avdec_h264', mySteps, done); - }) -}) diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/element/string.json b/multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/element/string.json deleted file mode 100644 index 0bae6bd40..000000000 --- a/multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/element/string.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "string": [ - { - "name": "entry_MainAbility", - "value": "entry_MainAbility" - }, - { - "name": "mainability_description", - "value": "JS_Empty Ability" - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/media/icon.png b/multimedia/media/media_js_standard/videoDecoder/src/main/resources/base/media/icon.png deleted file mode 100644 index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6790 zcmX|G1ymHk)?T_}Vd;>R?p|tHQo6fg38|$UVM!6BLrPFWk?s;$LOP{GmJpBl$qoSA!PUg~PA65-S00{{S`XKG6NkG0RgjEntPrmV+?0|00mu7;+5 zrdpa{2QLqPJ4Y{j7=Mrl{BaxrkdY69+c~(w{Fv-v&aR%aEI&JYSeRTLWm!zbv;?)_ ziZB;fwGbbeL5Q}YLx`J$lp~A09KK8t_z}PZ=4ZzgdeKtgoc+o5EvN9A1K1_<>M?MBqb#!ASf&# zEX?<)!RH(7>1P+j=jqG(58}TVN-$psA6K}atCuI!KTJD&FMmH-78ZejBm)0qc{ESp z|LuG1{QnBUJRg_E=h1#XMWt2%fcoN@l7eAS!Es?Q+;XsRNPhiiE=@AqlLkJzF`O18 zbsbSmKN=aaq8k3NFYZfDWpKmM!coBU0(XnL8R{4=i|wi{!uWYM2je{U{B*K2PVdu&=E zTq*-XsEsJ$u5H4g6DIm2Y!DN`>^v|AqlwuCD;w45K0@eqauiqWf7l&o)+YLHm~|L~ z7$0v5mkobriU!H<@mVJHLlmQqzQ3d6Rh_-|%Yy2li*tHO>_vcnuZ7OR_xkAIuIU&x z-|8Y0wj|6|a6_I(v91y%k_kNw6pnkNdxjqG8!%Vz_d%c_!X+6-;1`GC9_FpjoHev5fEV7RhJ>r=mh-jp$fqbqRJ=obwdgLDVP5+s zy1=_DWG0Y-Jb3t^WXmkr(d9~08k-|#Ly zaNOmT(^9tIb&eb4%CzIT zAm3CUtWSr1t4?h1kk#NBi{U|pJslvME{q|_eS^3En>SOqSxyuN1x;Is@8~m?*>}** znrRFArP!K_52RpX*&JHMR<^lVdm8ypJ}0R(SD(51j;6@ni$6bQ+2XL+R^|NnSp5}(kzvMZ^(@4fD_{QVu$(&K6H|C37TG1Am9Re{<<3gd zh@`>;BqkXMW&p0T6rt|iB$)~CvFe(XC)F9WgAZn*0@t$oZo;!*}r@_`h?KKH&6A@3= zISXoQB+~`op>NP-buiA*^0n{@i{_?MRG)&k)c)k_F+-2Lud!S9pc+i`s74NpBCaGF zXN+pHkubw*msGBTY27BKHv)RRh3;nMg4&$fD_6X9Vt~;_4D+5XPH~#Kn-yjcy!$}1 zigv#FNY>TqMhtIBb@UoF!cE~Q8~;!Pek>SQQwHnHuWKoVBosAiOr}q>!>aE*Krc)V zBUMEcJ5NU0g8}-h6i1zpMY9>m4ne?=U2~`w7K7Q0gB_=p@$5K7p6}thw z-~3dMj?YNX2X$lZ+7ngQ$=s}3mizNN@kE%OtB)?c&i~2L55z8^=yz;xMHLmlY>&Q# zJj?!)M#q_SyfkQh)k?j8IfLtB)ZCp|*vf4_B zos?73yd^h-Ac+;?E4*bpf=o*^3x3-`TVjbY4n6!EN10K6o@fxdyps05Vo3PU)otB} z`3kR+2w7_C#8Z!q`J)p{Vh!+m9-UP!$STp+Hb}}#@#_u^SsUQg<}59< zTvH3%XS4G+6FF^(m6bVF&nSUIXcl;nw{=H$%fgeJ>CgDYiLdpDXr{;-AnG z8dvcrHYVMI&`R6;GWekI@Ir3!uo)oz4^{6q0m^}@f2tM9&=YHNi6-?rh0-{+k@cQm zdp`g#YdQn%MDVg2GR>wZ`n2<0l4)9nx1Wfr&!Dvz=bPwU!h2S?ez6MVc5APE4-xLB zi&W9Q8k2@0w!C53g?iAIQ}~p*3O(@zja6KQ=M3zfW*_6o5SwR-)6VBh~m7{^-=MC-owYH5-u40a}a0liho3QZZ5L{bS_xM1)4}19)zTU$$MY zq3eZML1WC{K%YFd`Be0M-rkO^l?h{kM{$2oK1*A@HVJ57*yhDkUF!2WZ&oA4Y-sK( zCY69%#`mBCi6>6uw(x4gbFaP0+FD*JKJ-q!F1E?vLJ+d35!I5d7@^eU?(CS|C^tmI5?lv@s{{*|1F zFg|OzNpZ0hxljdjaW%45O0MOttRrd(Z?h{HYbB-KFUx&9GfFL3b8NwZ$zNu)WbBD` zYkj$^UB5%3Pj1MDr>S2Ejr9pUcgA!;ZG!@{uAy12)vG=*^9-|dNQBc8&`oxBlU~#y zs!anJX&T?57Jdr^sb>e+V`MVfY>Y0ESg7MG<7W0g&bR-ZYzzZ%2H&Etcp zcd6QeXO1D!5A#zM0lx*GH}`M)2~ZFLE;sP^RSB5wVMNfiZXPd(cmO>j=OSA3`o5r& zna(|^jGXbdN7PK)U8b7^zYtYkkeb%<%F~=OqB~kXMQkq}ii|skh@WSRt>5za;cjP0 zZ~nD%6)wzedqE}BMLt~qKwlvTr33))#uP~xyw#*Eaa|DbMQ_%mG0U8numf8)0DX`r zRoG2bM;#g|p-8gWnwRV5SCW0tLjLO&9Z?K>FImeIxlGUgo0Zk`9Qzhj1eco~7XZy+hXc@YF&ZQ=? zn*^1O56yK^x{y}q`j7}blGCx%dydV!c7)g~tJzmHhV=W~jbWRRR{1<^oDK+1clprm zz$eCy7y9+?{E|YgkW~}}iB#I4XoJ*xr8R?i_Hv$=Cof5bo-Nj~f`-DLebH}&0% zfQj9@WGd4;N~Y?mzQsHJTJq6!Qzl^-vwol(+fMt#Pl=Wh#lI5Vmu@QM0=_r+1wHt` z+8WZ~c2}KQQ+q)~2Ki77QvV&`xb|xVcTms99&cD$Zz4+-^R4kvUBxG8gDk7Y`K*)JZ^2rL(+ZWV~%W(@6 z)0bPArG#BROa_PHs~&WplQ_UIrpd)1N1QGPfv!J(Z9jNT#i%H?CE6|pPZb9hJ1JW4 z^q;ft#!HRNV0YgPojzIYT`8LuET2rUe-J|c!9l4`^*;4WtY@Ew@pL>wkjmMgGfN7 ze}}GtmU0@<_#08~I-Suk=^*9GLW=H4xhsml;vAV{%hy5Eegl@!6qKqbG024%n2HHw zCc@ivW_$@5ZoHP70(7D+(`PvgjW1Pd`wsiuv-aCukMrafwDm)B!xXVy*j2opohhoU zcJz%ADmj>i3`-3-$7nQKBQQuGY;2Qt&+(L~C>vSGFj5{Mlv?T_^dql;{zkpe4R1}R z%XfZyQ}wr*sr>jrKgm*PWLjuVc%6&&`Kbf1SuFpHPN&>W)$GmqC;pIoBC`=4-hPY8 zT*>%I2fP}vGW;R=^!1be?ta2UQd2>alOFFbVl;(SQJ4Jk#)4Z0^wpWEVvY4=vyDk@ zqlModi@iVPMC+{?rm=4(n+<;|lmUO@UKYA>EPTS~AndtK^Wy^%#3<;(dQdk3WaUkRtzSMC9}7x2||CNpF#(3T4C)@ z$~RWs`BNABKX|{cmBt>Q=&gkXl&x!!NK_%5hW0LS)Z4PB>%sV?F-{Wyj#s7W%$F{D zXdK^Fp3wvy+48+GP6F_|^PCRx=ddcTO3sG;B23A49~Qaw31SZ0Rc~`r4qqt%#OGW{ zCA_(LG5^N>yzUn&kAgVmxb=EA8s&tBXC}S1CZ(KoW)(%^JjLTPo^fs`Va;`=YlVPgmB$!yB}<(4ym6OeZ3xAJJ#;)2+B%p3P1Wt+d$eo`vz`T zXfUP2))kBDPoscH;Jc7I3NU<({|@wM$&GaDt`n7WLgIY3IA7A6-_R?z8N3mz|}*i z(zl5ot--Oq@f2-nv{X(ujT2T(k1vY_qh93pK@>H-qc%2Xta)IP0Q%zt%bqYgI`o!wv!0QerB`nCN^1n|@$sVOQ!V0teVG!I z_fD%JvfDeT1cK#-{o6Gv7}& zY0#NWin~kVaf$aufV&;63Hbs|`QVZWpDX6IMk1Hj2G}fiH9e-^6u2zf^FIr^BwD<6zjw63+{yUe8PUFvk8v{sJ=R{d#`O!sz`Q13~< zPT$JS(w=yQfU2`zPCNfSw=&zup@DXc(98afjhv@1w_f!m2Z>rMJ19AB&dB%P#Ls3b z=lK7OILM+SQ&VEd=1GN6o&>YVVtIzoZ%=Z_SdqJN2}E43{bE`>w+A;=y->@^k{oCC z$F*WTY&?34;kfyFV?b*Xb1Pq`Z=%OgwEg)Rz)tx=`f%5#w_INP=x&z5!jI;#;N$ma zhO)+MDm;SxOEVL15; zGq(v2pL3&P1Sl)8P*;G-fd{l1QJsv@e@d8)1PK4w2m*M%V3j-V~L^$i|&C@b?D?9tfwE{B^}Z$k8e5FmQ>v7Xz)sG32g9t}YBt zyR$+*_00RmPx+0mW+vVG4mxd(n$(eQf3-w>JPl2UJpafrPaL5@2j}%{VE-) zBI%6Qpj*dsdH<;g!S!avA~bv^0E+ zfyJbSjPb+j;J52U)<|cIcntQBI2T#>2;tOxu{%D?kML476AErF(qN9hPva5Nkc@BF zC-tLF@3ZFb%Kpj)M<{)x*l|*Ia@ECeXo2E4h2f!aV=cHAhi_E_mfUth(sM4^hJq7B zQsGWqdZUm9S%F`$nQ*_#NcuD`&)Ek%_s{&^78{9Hm ztri&rYLOxgFdG>O@+XHy z9#;|&vBCPXH5Mon^I`jSuR$&~ZWtyB67ujzFSj!51>#C}C17~TffQ{c-!QFQkTQ%! zIR^b1`zHx|*1GU?tbBx23weFLz5H?y_Q%N&t$}k?w+``2A=aotj0;2v$~AL z{scF-cL{wsdrmPvf#a9OHyYLcwQD4Kcm)`LLwMh4WT~p29f7M!iafJSU`IV}QY5Wa z(n44-9oA}?J{a+ah*@31WTs#&J#o1`H98#6IQf;Wv0N_!);f&9g7o-k(lW5rWnDUR zQBFIRG+X=6NnsI@mxnwm;tf5;_Uxg?jZ8m-m0}&6+DA!qam(p$mN5R})yA_7m$q@| zFEd|dpS595rxQr-n#GjI5i-AhnUE>Cr;jpCqSrD~EwK_DqI^7%3#p5)%T_od!t3SOmH9MyXeeGO2(UQL;ax|x?Ncixmeo1=$ z{-);Au{*tfzOG?KQ~K|ak8-HQ?`Pekhe2WM(8s{xv-p>Zmu_6{G!-oE$7$mY`MOJorI=+mMx?H;`pr!;fVYz?5~yXBACruWB`Ph zZM}90_<^OBxIhyZ9BW$`>6JvO;%VFpqVr8|7t3~AmxYak6?`Pp#c;**_SYmi`&z23 z`p6_~ePvH)C6x-G9$hgL=eVALq`-AiamN>!3~Lxw&{H(b{B(7xSRm6<3<{%{yXiH# zos5Rv1L+8fUKJLo%P>4I&$}yXCZ(XJp<`rbEFvm8E+IKBJu5fAsJNuOs;0iFrLD8;b^qJJk+I2{xetrW zYa5$icJ~iYzJ5QyxW4&&|JeD%80{X$$S3gsjpU)gi1EL>hjCy$TWR_42KiTa6hKLo zlw)>6D1a$G2h^v^M+^jNj4xhp<`X_txVT3zA!tv_XU@dSsn)+-l4b$l$+M6pLc2W_5%`wtUHuGV<5`b%yDE zxZ}|k-)Z}GU0A)j?KAakRM_cIKrOx~znJ>2?7Z0toXiNY9i|$ED|P-Uvs*s`;Q~-{ zBladT9Z+x`v;773F|2IohD$`#+bU3A$-*?w^_Q5{8A=bG=QPo`=ee%#v!D9bpU{7~ zUeLq#4{vy;bbwUsBQMr(Bs1$1Dz0D`GSxK%=dsdJuQ?i{9Lvq3$hR^d9q-GMqT3ip zFwHBqrIEm>iD|q|la~siqT@g8DF$Yrcl_*63F2+RPdEJD@-^V{^S*<4`N_BIe~B-U z9CtD+8~U!}Se1-P_>vt{u~{pfVn7`#Ff}!<8_Z|3ihu2DkFM*+-BE$?UVa3EMr+RL zan6$IM1?gt%$1hzgaf6 z_Hp?3QLbyp-5I@V=2;P_NjFQ4(v80m$bdKB8UZL67&)*hJCe-%2pA5^DQF@u~;7i6law zPVX~5%BrpW3w;%-OAW5p+%RlcX->!64P8-ghbd6(R@8^K7niQ6QVNFNMm|gopWH!% z0hADeNRmbk`)CA#s;o;BCdN_{KaaB>y_6NiYMC7tZUmlqEoY_FL0z=m(MTn(o$;au z!zgU&KH{p9U0me1dc;~|CKJ?AIgkMBzFq&0pB-h+y#atj?E&lj(Yi+j)3RBrIaOAibTbJZuz&V?gQX0B^yA>zxT`@x@fmMxe0bSE&WRpXk^ zROGAo4SGNQh-kd}Yu50?zj9+E;LDX8#7Vg;s-alGunLE3iE(5Q?awI&g*_U^g26XS ze9{awOg`!<Q6JTj!xA12TMc~;4YH?mp-u_?>T%EVnh! zDR)bePkuAFpQ!q4PKWxKeqwvyO6CGEZ?JEfuAHFQE!#JNMC&K zX&#!nKAF4}G+%_AZmOlP9+Zt&v;_vqeoQR_(Zg|C8vvec#3K+o04Wy|OGwq*vB`7x zzlJ`?A@=^olRh&X`;X3DRlRM_Rg#jWR1p@7ZAh9VJ6tS^T$?TY_prAo*Nw|=7#B5^4c**)k^pAx4Ama4}^v8-9%tx zd>m+k5$5Tb=FLIAN~-)DaxqbTYh8sxc43tDp2$^q&58U^{)m%Yc5};&0Ic|=KFElQ zF`xEko628su1RcNsNrxwr|n2CfTB{AlUkpULSUPg-#wf8pM?N$QzIW|l?Nz-xz;Bt z+5d}z%Bx)dl{cr;A3>k{i1QSu#%#!iDiAZbjoyuYgx`FtGtK;F5|*To2JZ84J6Fa$ zmA*@MUh_$-oyhyn;IJ5McYL@g!;nks>zC(5sOK&H+aLJ(wd%(>3*E=!2&!P4KmR@l zFK7t$U7-)DbfjW}(}iP{wdqWl#`gS9@p*J~N=K;)+fTjC2SP31rnOfRb5#%Aw`?td z_k9X@{4zL*$(T5n0aSfgU3gxD9r_Zr5OK3h6~deJjl@f7v@25r^!{CT2jxL@&M?7bU*BZAIzqEf)!t?_%%^9quERZn6Y`WmzFTtfsc znLL@(eYmh9!vv)gN6${SY*G|o_x2%*R!5X;#wZq<4ak~$ceX4uo9Cey>zV@JLn|dA zvauqk9*ywqs)W8BoY&+k`ncp*lhqL&Y)@SY2PUaBEBJirOfhmqCBt;P-kItIb)D{pF{ix8 z?r66%qQ64nASfdyqF|EkL0F&41ed7UL- z$|2Lv1ueyBV+iB2ER+L1&$qFM=7|pmeNn=X&+oVbNqrPi&I5`0{Q2+n43AASc**Ht zjN&WRgInq#um<4duHi1g!$noV3 zULp?1_ac{JPKlFSRQc{vUd9EZ5v4(QYx-E?cl@D`Km-8TUg5z)<3m1_4~qiP958OhUf|2>1oGtyX$||lEZhDC?dtY2OE4WXsio9IjcgOkdu_a*;1k3YN6Tfpd z=-6P`TMuQ~EN#dgioQdEPkq7vGqK$IT8FC#$I~!m^k_RsgKgtY|MJn94?u^el)2S) zwsJ8p=qWgrp&WGYZeLLR*FUT+7<M$D^bQJLYyO;l0wskBR!P}MmwVgQ}+|xbDGBogDj-GWE76Gz){^K@d zGFlxJ4R?HCY@&g8`LrOT@$^`?+nGkI$BV>dJ})leNgQ>AUEhydPzt&|-_#0>BEpU! zxQ_GGI|hm-_w>dA+1PT{GBn{=#5X72x>jI0`-DV#0J%`BWvWplM@KBuxdNb|4RW?( z$L&&Q)bEsHEpacQl5Pa7wCnVCX45{&j}dQq1i}X(cTx(Ph{ma~+OLe4;J|T~@RX-d zS4={8&cki*MXP($y*mxP28y>&rHf8cyK6_lx0F$n~!haso(|nFVPl>*e7DA zJT_lRDh~_Gh5_1FGD6sR*naPLkO7g0KGuKnAreLJxm$0G6^HkL?T%(F?UEN-3$Wo> z`T91!l?H4WppBLc9^Vs0sd9>+tVG97g@N`z51Z%4{-UoDld$)81&FvZUD9}x>YCQV zvfpmwp!y+W%I)7fdi=eEI@XIza+GDUi3UU_8J|DJZaNRhSFNkVQJLwTa(HeEkO2Va z3ye2w*zfqTXbOghM59!&RSY31X**S)AAxY;VBHV}&1xr*an^BHJoF4#K!C|CBmP$M zvfb$4zh8@TuSsBvwc>B*4}N~wSD3&c(jN}mlfdQu=^x$Ga~(y#S63v?nE?px!Q{*q zNuwxm`Fgf-<{NJ=)ViLQcdRbQCN zJRxo7;0hVbTxQK8eo+N8@19oCQ~YmHAOj#+dooQ36*|9~+N;c@Z`39|ME2RgX=w|u zYzjLaWBK(=!SBQ0bU(MQ#7x*XNnfD?^aA|Z{=(67_1QG&RK=}HRC1+P!?x^;14#n} zd|%JmwkJyaVvIn^RcHn;Ru1#X7&{Uf$-z}=F%pQ1x#_d%lZw!Cvm@~~vmUQcT~FjU z)2}#?D;Hmk6_TJk309GU5er6G!=Rcy#W)vyM3vYO=%Z0;I6i3@j2c&7z;4g3OExP? z6Mua0?whm72DeO_@EbHGSo~7k>Z64y0Z4JFh!$cp$`jA&BoBvoveMx1{U00i(rmkA zv=MbdEqc-pTNpk{AAVrlWXZjMQA|99v2PI|?Q$6}#x}IkZB3tFP%RkB{1OQJmYJ-c z2%R1ZSqUH%0AGFm%GLv=wT{;OH5G+b;G^hRzzZC^a0&Ls5DT>5bib~i z;qDC7h>^SOtsr{C+tvWMs|znFVV0$F4Fz)9Ne(d?ceI5B`%^EG;6B&H2n?0*=PDL= zyll0JRESLK(+hQonpfqtFA*_$1fqgNdBasycHrgKc*oSWZLIqXuf-RiBe+2Xty#gn zwQX_9f`yQpO>^*x-9UC9U~}JFmBt3# z=P96CJ1kJENT5DLwgfrd!XAOB;b7;XXSD^oZBH3p>f?#|fkxazjN40b2mJ`xST>(d#Md46H_dSEUdCd%(6Nmj6zmZ_7wJhE@#LIZ`<=(JPG4wY0ZXp6WJabqlN+^WYeNQmI1EEp@Ct4f}jzl7K4b zPW!^1AXp4&g~Yw35|Aj4 zaDH`T;bzPrsF{4RuV>2^+_{tEC|>wEw@^<-f>MPKBnlBhp6cAcAjYk){d&K+ox#C# z5^b3=LGmuA>=_94YwjZu2OP{qt)bbZ8>L#)a1cveliT&f_FV~DQdLTCI$;RytGr7x zT`ovM)V|kVkitNo5$$@|77&0m7D_(j_q zY`;4YS+95@GpzeW{M8#PLL-m0?UM0f$ud<4{8Ly`Bbii17r!_vEy_MyCs8wETVyx8 zda{bqK(?(MRz?fAI8`W-oTVwj$_l+V3R1t`Y^YG5a+BTx`S0*9&b=4!nabV zPA2}n;jp@U24e6CBnyDch0JTKYH#G2Pub$JPNg0AQ;`4S30V6EnB?l#kXue!Dt4x% z$g3as;~0TT){a=o#rrD&2!>XJu`0XpRQDuB*^7=!!FgJx>f3ARz9w2~2I~`I?7Y0G z6E(1KoBn4jj{*lU5$IKi86$gi`i)%~X<;HJ2KwD0i8YO=%Qu}1I%29Mx$GKhy8<<* zI5@zrnr3cev_Qp9drU7&Mw6#joDm&s+eR0)@2lf?@b+P*+r`9_eft~gsMZZ%D{PC$ z5O{V?>+NTq@d%^=Kvcuzni$t@i!h|E}BRmXA*Gmon*aZeVU zggxM`#@o=OkWN=E3`Y*zQDzeP;^k_qwy{_D8DRvUtlSKCiq3QT=DW~v(cfK08R5Za zF;pZa!%iic#AE1`y5AV63xnE;Ag6$`R;Q&FXc1yf4>K9z%y`FKaI%2WJ;Rroq%uNx zm2?GN*49*Ir4)5i89VP_%;y)XF`B3SfJDBzI1&5D!p=#zmjp$M?{7|sX5WAEfIPQu z2G9!QL4_Vf#+5v3XU)$Q-=5`!e@s`;rH4UPx&~767+Kt`5uV zeQnHB-9V3m&kzP$ArC1qf$jEZRd@JQjG zWdxG19)WBCuy=@D6R#7UKFR6j2(Dw1PX{E8{rN$~3nS%TfDluu>&}dJ<0%bCx&aHf zi8sFJan|eZ2__WZgfX?NH+BWDd$e90>SCvZRf-MMI@|!zM;K=_9C26=GJjA7l<)&d zB%i!KpBr1srZp5xqF{C^D@8$&)L@0v7R4g zMXNjlxd9N`aD^s5tQ~z4C$^lVGIx)gm+BuA>lC<(Q{xoUu~Wm5V?Dyh+WTbaHYE*o z`lr|t@7ee3!0sf%h7E4Zg8+bT#wcch9qOnolrasrN5#pu-Xl|p*CX9|=db{H`7=+E ze6`m^9FHB#{Ze*qE=KI(fnd7IktFoVSjhX_rmr>?3Rsys%U9Z90i>a7_F=&<9=;F) zSH^s!ZsmOh9}qiCkK19rB>rB0+m8`#4BeXlSdBoyy!QUz%Ghik)Ii^CnQAcF+5eR7 z5y%$+|Ljs|Vr;ar%X12-$}RINj=Xz|&!guCGYn>>V?Vjn4b~(8h@Fs4iJ!>uq_Bvw zayGkas?+GON}(tOTAFnKd`rL~2CeD)ViavzD!BBngvhBZxVgY}*WcMfb&L1Q5Uhe4 znfEz_mC86FoHxnunVZSZ z2o8pKSk_iG`lym}2wo5$GLort`&WD<0Rb+aT_E)09U|uAihqJ%2a?EgT$2BlG~>aD zN(lo+$da1KEh{;4n)6%KCAK8;Ba%U+D9KeuHvPtBiF&O8?DX~kpGR-q-!3oj$?Kqr zB`p#RX5SzG$|_)6Ci(lhYK^$5kb}zII!E!mF|}7Ve)FR}RF;c>=f@TQ66A{N9#SQe z=ip=N^C=C<8DkZ}J4dX>7dTAjCyiA$E8c~ie!dF*j-F+ncGX@U7#Q51Km3Yl{t+k| z4yM%-(L^|bl+zs@@^DN%1uHA**OwQEY&zL{BukA}gBlJtwZ4CE75%yG#UP0dty24f zrdtm0w%|eH`mvGd+{?sZV_YkXTQN&I8oDq4K4v_1F^8c>8T_a5ix z0_~24>SsDn4^JT-dg3OnBvW(B!bQiMQ&`Wg$psI)!MDP{hm(y6u~Ny}UILW}@yuL| z&#d&4I3e#eY=^9JPyUv!W@ED{>oaNwN-fVj$O9l+m}VLgEB5%H-kn1|2}S-RP%!}Z zZetGV2i0#aY4icF=r4Wq zO{&z#v6kitE8@oXn)uDnii^F_XSV`II8J7bME9kaKa|yM{r_H2EB?PREsubOeN|51pO+MrMwk%bMq>9Zg7c* zsQx&_kQ;K+N$=a>-nY+v;Ss0Ft$!Wt?QrRz zO_Gv;+pAnr6y$+&ILegl3E9Je5wGS80owMC9>dTA0L_wNy%Xa|HY<2s?hz>GVfzpw z)AS&x*swSqUy#swv#Ov-co9WQjxrl*HTLA9lj$W#evx=3rn@eRNeD`X(O9EmW1>eQ zk8WPDS=B$gTXiDD>wh&kFJ@F!(bFXWZ^PkQ0A>1E`x z^^mcGj6q`oe#u;X?M=d0$J#hznN{a{0-M*lw3yTT<}YMj0Y-~_a!scHrW_o?g({{= zrUzQwaYFS!wQVS5b*0+O|71fJdML0Frp4qRFTS zdiuo8`GWX!qlas_x;UPpwmvjDt?9_7N37zt6d@9M9yUz1tqqgB0MqJlbJ`4MD#q;J zg|Hq`a|$bpe%{V}c%0+F{EL#yMpFJj{}?i`0JA0vs!{^${8TUb3w0ScHZr6-elikV z3x*}$;LVSaHeW|_{@fx5hnv(fk`ah^4VubahA6$M;rV{IwL<;vw1Z;|jh#x>Z&*;z zYl<^0E>@h-ptR!oK9jNmOwKp&_%fNbYSw2ks>D%dPHZ*Gq5uQq5$F{Fq2|)j_*&tXmPKCJ#V`>A5=U*^p4d*chkd6}%`P^R+5ggvAIYKB@up$! z^s`p(bUipn4O#W>=#5~B5X2d4vpg=wqJMCqiXJ_2X<}uX{N+ zB?h#uT@XJ5&(6sp+RA^kl2tT9rq{)ws=4G8p?I8ppG0l&)mltFmv$jJ;WR>ZP_lSE6>Kji{q5pjZDvg0&-pFZTi^#c@ z9H(Vcbb4I2UukjnPOyGA#csZ%E3UR*_?R@WTIF<~qZZWjeT+QuL|<&_Hf#%8%bJ~0 zkGwBTuw4TY)f_YeTrBk7{DK|&xrya--n4oeZ6?32=eV+uOy8<$M53F(T}->JLq3BM z{=WC>!*hJyX8$^g+M;8UW$rIk_J1sxI+FY15y;$LsyFnfW9QhQYal;&m_#>t)s+Zj zXGNz~GWZS`6udre;{HLBxFARyuP->D{r(D3m{QK{k~i2MJNKUt#Xxddq&;Z$hg_b?3NoBQq3wu7t`d2fcTTay+ksz@Z0a@H58%B4A! zN%4oCw^t*Xlsxc7IA&bLD|uZ+t?>pmwvD^FNcLRP#ftSi4bpwGL@B(w8=a?0X}Dng zN`;X)^vHWX79)-#Gh6+b$Bl`Hl__p!18*^-*sB*f27(}T=htEwk<4jUHd{_CD4(l-$&eA ze!A(YaN+3%Dp5aLIQeKM+e8=4Y7^f3U?tWQ4@i%Ee)?7TsDJ#|#r{}!By1-nC9#RN zt7w<96|mjrf|EtlJB4n71pH(Yx$yz&DM~w!hRENY zyu3H<(ofXSPUTsU{dBWve6LFHuu?Yf_rp9a2hO?#CkXT&ff^ricomea#J)21-fS%|KkHD{4Jz%zvEiLy$C znLIqD5Fd~t^?j#}%}BA!J_ik+tBUY1=V6Y~5-br-8vIX^>;fRo0^&_%9#c=N>jlqq ze?p;nBSVF|KD3g!i^8T>xpA+5<*4>yKsCAf$_t(Ng@!8KN*qdvFglXZjX9cdQ^D(E z%o?alC>jiz&rVGeTlaGwPTH(rSAr>^^%~d;I_&@nj6KnU=tSPU>}=#$QtyNM1>=U7 zRQe5jEX7C~P-+GIMY>lmTDd)s{NTdT^4S`S6i-plP%xP-4SOkiyo#|bbCAd76gLolh7tr zI02CJn_Yh8p(SZ%wS~umX2?B`LEYDZ_YHYS8h*vQPVPb)-BZkbqU$ zhj)-y+vpl}-HET{H(h-UBcTGLsPsGs7_W?bT!9R7{kK&02o~EcSwiKZno247Sz!HV zJauEqcp}0w4x*1XmoxL<5;~$qZ8HY?EV1*VMQk5|M&V$Ke2D~vlbjum(@8e=Pr*OR z#E$UT9}I~EhmrF&F_eukKvouR+h%G~moXMPrmf#{eMy&L!6CHCn_b;% zi650rFUVa5d|r%iZ+yo=Qv0sscP@RGeK)H}^drzL9Q^S@MUz*JP6_u!@I0A_yhMBz zptb&~$ZJ1Z=@DC{Y50eFAyLZ(xAJ4>f~g55<_UG?WXwN1rA^_1)I)=>jYrd7H?xXx zeupx{J&&>m)ywD$T1-7~(+@sLg1QJ+mhS1qE|naXNrfZ{e`nx-{4bx0vNgPZEoiasq&~X0>e6P^?=k*w^}#}EYPD7FI|{hRmlrs*SKZgl zv9tle&yIMjd83Oy2CzH-cqa^>lLE3_2+P5n(SBNt#2vIR5Fw`6wvI|0RX_CWaDZNm zEzsl0<7%D-E|~@u5>Sgrq9n-UpFn%kyUZjP>30c0mk>)u} zoAQsXj;>k+QrMmemdTUHj;rRprC1|yn|W!Vv|3oMK-*TErS56eK4*Gj#Httpx&4x> z6GNxNuWpx^$9+l{C$)Qa2FHwUkzP+QIU#*C&@KRG3{a{?sM)v@FcZg<>;5XE6+88W z3*D|(@m~tc|0%L-1q-?$mJ3_Vt zxwxN!If-pi?KTH{XEGpGImVM6zNldn(Yq~&VmMNcsA>A|f?u&Gk8JM}IC#9lnF_S7Qgx|<218X+LBcGXU@`J1aCI#?j2666mHLomv4cK*{Y<3xsWYZBNFBI z?D+-stTO;x5CL<$e1%Xd|gS!dg0W!^FT8T|70PUk(rcC+-8vR;f zg8q?XdGZ~cmcV&rzM)#$zs-9m{65(e|{o1|kN)NE{+ceG%x8uQ32rO|)f zA%qk*?xAPA2P1h^7kY2-C*n$z`sM9P}ieeulnMElJ-U*zrp~ z+|6_de+f`l>A!XBZs;p=GLq=jd@V-@;4eU=$pIx=P(3BD&(cW*!=8v4{?Yk$ftfO` zzp+FKA~rY+GCuYGkS-IHeYyAA#-|N-O=%@ zLTEfAY?7W93s>$pI@L$~S(^V%IdDNfAC$~{D3$rqLf)AK23G(Y9E$|7@?%K3ezU*8 zLYJs$m$vmOxtFluUGluV#pf3VTMXJ5Sq!pE z*}E}Ei=tC!VO-CvoI+h~K*M3ig@gm0NwZb?Q3en0BjYx}q*5yr zc01$y>8@Amam(~HEdK+7GX8!D^=TM#%Q~cs!8r~o&&PN>Obe)$qdGaI)YU=7M?bCn z*`i@HJF{GMDY>bGfySaiUsM^DMg&x;#_m3w)zY*0mg1qJaP2XfE4nwG8k^B=xi>w`Y>$DDxg>7)-7(@^^)CO%*c@s;}g29;9W)s76)pUiMHY`&-rh z+o{Q3#}F-#w3*knU`tpmmNw@C*SGxUtWzSaE~`M>&iGS7_Io5*w!9}zjA!Z44(43P zJiNQh`=ks51@wOw%GKg-V$_Lx!BXQ83+BZ;H?cGla?$W^x29(pq1Bq+85h0(Tq`_j ziC=S0GRHKL2&;JKWi%zPNv?YQX&%2JbT0Y8eZ%+stsnbx&6ob1U#EM66?=VxMxj^F zU%5zV97yXl+^v?e`a_1w_zmg?8 zlb4aL$a~5E#D`-*qpAPFhrB>;EX-Wl*vCfV-wW6N$Ou0;F=`=yiE=C}D^ZBz=Y(&9 zpOxy`%WssS;-}RLAuiyjv6;+NlclMw;Ah~} zw}xPz0O+==uqvNuJxT!+c9q~|7$})NR#F}~+#eimgwQgwkrR^rI+C!2&8A3pWahOj zPxj;-{YtS*8fg|L?5&52hP@l6jnNXR>rrweHT9<2f&S^gpuT!YFcH;J_>-@WMj{@? zzVD@L{BE{z$uPV+w-R5CYfb-8o0cPBkI==U?jHXlWUwbT9_4rAkIO5%;> z8Xd?9Uhlm}A3BJJJna2B`RLTLtE;QC!J-%@YMRev^v2~mN%|VBg$^2xROQEER8Ukb z3k~1(=*8|Z3Pai9DBS;k7$v~PY zN~nyi#p(?tY84fUWTHA2Wr{?>{$!>>f+5@TZ3nyGO%R?;*pN|&WGAz0uzG1)SL?sF z4h(g%gPBL5Jpji>fU`+bW5_g}X(zwH8A4-LCaO57$txR|+`#zN6EV}Cmlz;Rh{TX2 zIkZ+kF0&b4FFYG=OU~|ox$=AFm4IP)ysL&|x09OYta1fr=7%Xc(jsM^!>-(vEy3$- zIOjrVc>+Q!#e=>l+Dg_3zG?|A z-zquv{bp`pb>j8ysGlzvD|K{b>1{mbrx91|c2}m2Di7vb{GHLC?>ZY&lJY@O8G}$9 z*L|CKx_oN1Yw_adbSVEm*JMk3lIA;-al}3L@`1#z2FK>rGR&$}) z;!wrAIX(g%Mr-gI@Nqtf;O;dCQ@Pot;$pEX|11UX~Z*1q!Pl5xvQCoQgP~U4JOSS{9WnF;vlK;YL44@!y4y&a>U2gBN;LXDh>fB)`qkLeoST*fTfci%H~|T+!dSq~fpF zdb(XdV@i^l-z%tjx??Oh7kBFKq4y9vzThh@BR}oLIgdNE6rEM{D$QM?9V;?&#Z^Bu z@@}C^?Gfk{70UXRl@s9x%4l>L%LcQ4;{W!$gTuGxnT~l7r#LPQB!w1_*7a45#q!MY zY^S`6-=|-Dw9j?6drJ_X(yvM%+p_<8Y@jfKQAWmRPp0I!!xw3qoNbK(?o_l*m!8^8cy3_fKITH(xM0fZ>*BOgVL3)+u^ zxJy}V=66Kx|8z##jJ zDWmS+_6T$U;2fVT)mF`vn-#FM#Y2PN%XHqcbneSOh`}$1tuavGnfwgfgX1t4$U-jo zgqA>rRf|fDHfQ{p9EGR)ud*NA#6Coql`^y!n>L=vN9t7jrG4s6PiX(-3h8b6fG0Nan5a&WG$dO@L01X7Ls9)^Fe6HQ5|I z0__9f<5v=zyiRgejI~Tv$<~DQY&b1k4EZ8Nevr{^H0&|}Ep2*C9y0$4C+|Dau7(1q zXpXHpQ+@bSHuQILT)W9FRl(bmmG?=gH@%;r%57KcX-#|*@>7McUxynQYEagitj471 z569O3Qjk4cy*L_8`x1fm29d|AS~>9N6d;zdj&}NV-pzehx%W>uZqDXgKgvjsHv=+f z-xMkuP^W~}?RaAHqAu=<(5v}sDoWoZkD0rYDkBD|$w&oEgO#lTBV#rEFr&#MBKH4M zA9mo7?F%JNG6Onyl4F-V;^1^eb4Zzm;vktV(Xk@)x1^j(7v8WW4m}}>Rr#D@)(maV z7@OImb8d`x84@qv9+%D5)zw-v1v)7c4JY2?3tgk0GUAen{}IF|0SK<~Et=m(R<1j z+hoD{*5k*g5br>x>nz5sj zz?6OfiR}5JTsmR%Rcv|&fXD(beX`LM%!U@_9fcezG6P@t`Ox7?c&9G#OOxm2NxH~p zB$g+x7g_hIs#54Pe>E|hoDmb1xb;c2MJjT)25qmaJCW>wKirv}y4Em7#_uJXd$aQ$*cbd%vzX5zLxS(K_jh@7@5P@t6kXfa4wzq4v) zhB9RKO?_x&lhmev4h!O7hhVej;OCj-U8UsfOokMUd-8eH?92HVt5Wt{L>=|uAg{ko zTVeO=r~XH7fs4&~D;0*WifV~*_hSG$r8R)uF&QC~Lb9O{MUdfm_K=urVVL>Ts{Dyl zUgl5Kr6FfVHz(EcdTTsP7>4&D*9n_S^ur$dh6>U>vBAZ(Byk@PapC#%Pxm9xF&qcl zDv~DYHe|)(A{0Y>VB=v|VI*R;CNtO`NUREC;{;%r-BAyknQ-=%Z)SLRHv7j=XheY8 z6Cwapkd2=4kDWs0%0DSo<}vQ>=j3!VzZv7b?pXM}Hj}IDjK4kmiXGwrc|pp1lgB3& z|6cKmOX*nO2*3d_U7xfiy4LBO+48C}6|@zvv1fLxvm1gPEE?GhEAvffik>IPhhPRr za$(=>_glNfUP89h`_K!iL#|> zh{#2(7j1fr*pM_%vjZa3$xrXhvFBik47eC-XIg727gvF~4V4uQ=v@4rzvj_{y_#t| z#R~5-!lD$PAQr}g?s89T*!x-S@}V_ouLTZkJ^vKK-bH4KCB(uhUIB zeq&*VcxR`qTAZRD9N<<;^CKe-Hu|gL%Z%_de|q+X04!PioJmzp%6~o+T=V5&M=Ez| znY#Wz;N_iv@MiA3s$_^ky62-<))Wf59e+k=twA;&2ZRsT)7hg^;o5iZHb zAwPnXfY|!yoNg%(sT3vvmNfwR1ZB&>w}a(;Vg~B*GT_XBW&Gj!7fxIS#Jv(@vBd6C z3Lu+dJF#|;qkg8M(NW{uEULzap(I*T3PJ<+eRxihWXj?N9p&Kf_7ob9puizT^e*#f zZgu8BUOZ9zsU16jY86GovSwXgiES@OM_ov0NuFSAjE(_;f>m&!uk^s=7iSdxul}Nv zj7MAv3WSbPG+t5hs%i%t?xa9PIe{<^oZxZV-`|!eJJg`i|IXzO0C3&K(}aSS^He;h zs5g>{u8yR_?8-$srL?bu`^I%Gvasm*O0c$Cl?+v) zKjQWwLtYMrxUF*(OO70kxlD0?rZPo6&n=;|+ zmaDXJs#K>_!=)QbZ90RapcNCnUu{3e6aplH^FR*p7uS~N|M?Kaze9+N(<3S`pSi7u zI2h}tk8`n)3d1r0xGz_oyu52?9ky>|i2~Tth4<=^a8HKW_@Fvw-{;Fjp{VK$UAUJ% zPEqZCe_aJK4jqQ3l?$5ZhjE!0U5>pm8%H6E_RJ%9j3KP2vJQnB5??#+y5?4clz$tn zS3*hNAJQ^zC3S@HD{2-@FFFu;;>TDQ!m`xNs)L1POs1C3*=!6d^qbCUyEtyC5a;G; zd~Om^Ben0bzETM>{yq&gqCKO>E(W4d3la)zmGX-`|I>{3;Na&eN==Mva`AO6T~$d4 zYtT^Av!;yCiUXi)cmTa%iZbk1`viG>M?zsvd<+w%c&xqbb883uguc+VMe_C#qSJq0 z1=XLxc#v}HRmH6yzVx5}Nl-icsnO}CYu((ACl_nh70Ugz>7AWUWNurqE33EFe)jO! z2g@i}cgKVA<}oq&aCa+Hw{$e$^S&UqY0u$x;!rnCQCx#A_ley>76H|;{KE*$K zv#J*UADYg>q3QQ~``c(3IA9-cZ4Zk(yS&E_j^SQ;BlWf?)Kx|$H`V+_lryJeNKD(VY(iPp-!`X z_9PpCrU^(2N$5G5nvNJ2!6lEN1wr(>;}$=_1#i~q=J($>DUTlt;D4L3rIzH_yt|)wD^=*tHZ{c#EQcweM>U__hAl z>!4uB-mUcyu&C4O{Q>lW1zE&dtlC%6pNaSc5NTnU_$(G`i|83sOn@}#< zOqUG+po9THjowr*z;vn=`V3;vc4YKZDp^ve#Wk$aaus+u3^MPZ+8FxXr3@#|;7IFL zyKpm*EnrK$(m;!lEViSh@fOGQ!-=45Lh3Qk8-|KRRo!yr#*+&E13CtP9VCQeN>uuF zpeF($se<}5@7s^<-^+Owh$DgA!{AbRGbSmo&aZ2ijyBt2`-oN7g1c7m{AULB&I!_#M%QM$&U};L{+p-VzFhdxFLr#!x6;dL3_X66<=4a%9!$G zN@!yFvjNyL0D!cJjcA~ptdkd?#jqx~A`D7&Z86f3Fi#QP#Wg)yg}<3>_04UQOF>2b ztqrep_{YbQPi>XI9Om3SP8%>ampHT}(L$aOc1CV>Ziawa(f`U^OY z4wG?CH~PJop%6Ti4SeFTV3C z6N!w18_I?RmwA5Xnm89 zOG7fbX`V`q5@JJ%65s&hESRd2WY)fQ0K4_Q9ZtaR=iM*MZhm!4dXTy^r2F1v!ThgE zs^_-`FOfWyia;xne5s@Dr^iGiN+hj{pRet>ysyl_bwyNi8%e^=LYhxV&CVg_nP%_q_l*;2m zRB!w3qx`SGbt0$y0Ur|+D=TGq<%wITRMB=;4R;dKj72ev&u|Ic%y{xknl+c`iEqO{ zTxv@4D!d~^cxmNw@cT-$OZ=if-cY|0YWBSQtmB$i>TAPqYo@Q$*lpn!W%ec8%@ zXH`=am;>WePG3k+b%A>BTTbSt-6rr8~)=+Dh6KgY^Bb zUy8Npo~ZQag)%PJD)b!iIDn9lT zoRH5e{Djz}_x*|{$biQ9p`lYyL(*flJOne?O*$W+oN#njx9{w6kz_`^)W8PA>-_T& zN0WBs@-RWm0Dp)Fj>(rSl_oCV27_il8mREvmQf*^LK21MD6_&=8|Ea3q48~&=AI*< zQW9G#jynk>lOqcVScJJkEv7K~um^s$F-KpLoQk$fDpbj_=8EDbk^lh(1UL}XsI0AQ z%%tpV(2CEpj8%vJS_J=u=K{fw-DFBb0vt%^o0?04R+O@8btCPr0P{@Ogo)EGk6BAkyE-GCHhgDESjE$ORt# z2i|*azKL_PCB;mcP?VHb?LA8)g4lVxnCK!864w|YNGmi}M(Uo&_U?Phcq2GYp(8;5 z>X!oJ@`N+a0pg0Kh-6=pagZqEBIi0Pbu?W*qLDv;hV}Lt4SrA0yU`*iLE=bR5RJtaf`xCzW+6-P`nlj*SR;u1o#1n#K)28D@yk4>IQD;pMb*){F?FqkY9p%9P zq@I5@(1QutZw{OY8Jo6B)GZd;)-FsXjhbjyP`eCt_i{1neb^cse8PKM>&I9LKnq28 z3K}R9t&W{-d_5`Dcq;}=?&fqAoOJQJ#`N*g zKpY|^j*RIlOBcGh`g1XArtTw6l$~5>#moP{2<>=rsdY03S&^2rreXhx@WP&aYDn}X zeEf4dI^)wfW7d&KXK*kMokj7C2tA!qYSYf6r<- zg&zH%&NhUl+u)gCC;L8mEk`{FH^oQWYY+P|fAuNTB*k}D8T}sX`kUz2q5Fm{p>JWd z?87~Qmk(i30H3|Lt`k#iTcY*dh_K``55b_KBG)7zUGMxJFodP7oc?ASM zx&j2}HDdtWGRISP2PP4vJ&p;Os_exV5mj_fuC0WS`Rag7LSy(8? z{?>!)r7(@iG+fafR-T~u?1q4ef>h1IN1t`QWkbTSFr%Y~GUz(aI`ueoWL4&0W&dq- znCIbZ6Ke(u!XrupJ4wzkZj84E`r=qb!3l6)OsZN#25E06pq+gCM@N1jXT)xGG0B&#PDYRd1 z8Ix7r!`{hDjqxGT8!HUu2&|<$D9~--1ZmdFnhyTnUo_JrmH;N`1=X#(QyPpVa@9oU~LkbP1$sEUmB{DXbWSCM^EXhsnKO(e_9 zq^x(%MufHAm|B)GC+hgOQq8LNKOj_-gy;E7PVOoxKN4n?9;!Y>J))w#vGsiRQ+_)f zsK3)FWn4_qLAV9o)0mgm=}r(K)kc{Q?3{|GG(@n=18Jasvoek;w%?B5{kA?kv)Sz@ z)%aTZg|*$3-z`e*Z-#d1@CMW)1PM7OOedJ+;j79sQLF@jXr$?=KkG;DN=h7zFaUMH zD4}gXPjT2jvZ$C_`A{G>uSB+7Vs2P9G+H!(vq;eO&qzycZkI4{#9c+4C@Ly_ z(m09md=*h?Z+`E#lsALZDUuB$e{~Sfge8#Z`IY&5^9~sOdFzh}hz_&Gow&7Bkv@X}pZL zrIwTPz5!9(GJVsw>*WW4oqs^6KUS@`VyZ9=DPxrTKrqh1>x(fYfCWmPsI+Te{B#^M z91`2;#Z3a3>9>HviAgc7>1^N?xYNqG&5<36{0^<37b6l?93#j^%u=+FIR2;p3?4u# z3UcWjm_K-CnE<#ohWVjd^FU3}98vmWgu3=U0w{h;O*Ic)j zUJb$T{xr;S<*G4wybHrWpc4RI{Vgg&$NllSrK`oHh90vKpGdIbOmu~(RJ{%Qk-{^X z&-e)AGRJjyH4Pjwbv=^UOgz&ZKdO8c0TN<}aPOi9S;MjhVjNPl4 z4U($Ov3w%1^I{TjPPw4Hgn(M5(6r<=34lOJ2?E;98wByP|Zqt3tZChR_(j z6r#vF1fM$)CGqQc&O2ChmA}GM)`3TYrzy!Ipr+3&37Gmda(&Mu$0TCG&2U89w#qNR z$3$^}RBU)pYumrx~hE{rB-Vl0UibOi!5v4fQ}hMyp8tt1lx*hpug&wgGd=2>ttCbz&Kr73XUq*stdn1u;)PP?CKs zX40Zd{!6PFIbhNMUrqqwS?@l_XHWxLBp!yM1Z(RVr`88Bu?he^1}I5M?k^}qXD?p+ zNHv1Z;;Vq49R*(eda&IotU~uue-PYPKSK^jfY#ac)=3Y%9=Io7k5&(HJ#HqRd5wK5 ze)_A+GykC{^${h(*#x1bO!K_w87Yif6pDWZgpn|<%^V~$iGc(~pw_E7iO)$fhfdke z)doK-BZ0nTxRwjGThA=*6ES79y-4><9b>*+aAUmdN<(_ff1)RB;=G~HJpEm8=f!6S zr4$&Sw8l9GKK?8k zrSJ26OI6=|Wk2=t`T72VweUo~jurXr1hB8apf5-Cm1F~~ zUQsm5^H1o1M-Gnn@eoyP*U`FB9)AtPr}U8pd{PUM2_uu% zbB3Kwi@Db^^w%`0RGM7zvQ{?>s(-=$nK`+H#ZX|!MLUGx zqk>J3#E*Lcu7t_Js$KDus7?X2l;7jHNKI3{JMVN0p*)OPuJ#7;Hf;d2__z}DoeG2& z7Z$`Qe-<-jKrhTgvHQ%}+1h1%yTjUEe>hpQOgbaw9I58f{n5zECa2FJ7`v51-~pz$G_ zfK4^?4Cos*yiu_X3;VRE`8*fxyy`mr3W73P)VN|HzlmkteED0-$E;d}%&AgmT9jfl zRURjXG#+K>Gz*1NUs_iKP<0=i`qxG# z%TXPk8-s#5lY4Z-@~iKikYPa%O8Uve0!Br@w;Ch|+Ei`Sr!N)z2g&NbI3>M&l;51r zJ5KrsbOr$La`JGN)C6_qRD8US4$0RgO5kD%?mpz6=X&ruoU@07piwDWx~fnbIKx-3jh5?<2bT zG6h(TLl@T}(aD8hN%kdc?p zpC$Ar?Uh*pL-G8t__XHmW|5@2XXuUE$R_le7YT=R)9i)KU8a_Ap8A<&Ct4_S?+y+O zJpTu@4#yKMSEy!G16t*>+y;}Ze7q?Pi`0LY&2gw&jR6#;$a8+?0|2l95d4l5H-nV+ zL7Jbh6W}FRj6|hQI~aK5Ae-zVZtG7UQhY(u#f^-_jtc{xv&J^pIhyvhswiaIK(#FClo ziOq2I8@4BEdI{DXG?S811BC(e4(F0^-B*zt#Wbs&!^C((@UKFVym^i$3Yc7nyiF03 z?MO0JfvDH>WYg+>v;~07l`s2S_AMrQiM?b3ysZSvU^%87!c z48c&3g_RDk`0ls9;m-Td3JX}7tmpEi_!hDyT2e-Ym`QczK@xxO=`&StO=?VQBsKqg z)n5hRRsWVj{jmbyrkq@(v?*AM#81jKEPw!paBL|#eqrp8C?ZE<#EyU=g;DHHZS;H^ znHFt0p&IBZKKx)8jTU`;JEbBkJrBFDHcZGt^s&xC=d>Z~uclPX9itEa9j;;;e>!Bi zR0*h753!Jx{YIYCiGil$&R@(x2-#uAQk;<1M$(7AYL_P6=6TLSqYak|cB#&`avx}x zEk4V4R*6_NlT#EW8-M@18~yB-Rz11ipeo%VR|-MtDYEJ4*w9;z>=_;LYr%cNBlIsq zYXCe-OO4}#8CsJ#`{ohwAB;pYO>9zpZLh#aq!v&&0t_TBLY~9T$u*WvlkvzuGAm=Z z37&m1eX3j?AU1s5hRhg4`8{5#*T#IFp{|xG0k<3BTl*y5GZGKno3iKuNm!Jcx);<5Cl36tqP1dEi#+c zn1Aj2;s*9HPn)GPlb$V4%Lehvz>6>JS$Lv&psYy|&#YM)5F@&_?(vU*$^QKL&!%Vx zfV0Fd#vI}u>fS#-Kiw5MFbhB<`WK-S zI5^>0s=P!aNG2Is{~c%N3I0#d$O~S60JOa$$peC*X1G;G%A|}R5+0OK=-m<;hiQVv zzg*di-O$Q1^(fM)OMGdNHpj^SAtwoY3vK_Y4i+rbl@3rvesq4#i$R}Kx0A5e`)2T4 zTD3d8U|77p?k|`GNBYnj&OSsDB``lp@mkdS>*t2G+K1ji^pOI#U#U~aI_z&GNwl&M zmbd5HUGDM^^b~}DcpriWc&_h*chVZpU5I}jx%E63vI%kdMo(R_UgXI^$*P?8@*mJS zT(v<>7*%cKxRsY*e8**}GXJaPqR2+YQh?5ijS(o!l?^VjyfT4b9mb%=;L)UoR)Zsx zw0)et+e3=-*}5*yJEl!PSC5%zELGNCx}Th+%0P=u9!Q96m+e^6Um@-EY$blJB{e!f zrgz)_b&}^k17Jc8b!GUsW!U<1xlBGb5N7mr29Zuys8itq8v`6f6!`65vxkM8jt?oVQfQw zx&B)w+;jHIV{J=?6@==fO75356_Pi0yuuz2o?oIyySTo{SNVHB=rIAobZCaW5@J0B%_AYLjV--@G^}*K*~Ne_*xR7SQd+n7g>mI7 z_UAFTSbk<$3^nPyh>-BtPX~T1bU&x}SX~()9HjlyYMKeGjJT~AN0UfP5e8c$2;R+c zjZ#~(9)f8BZ}};JQG|0bPrs@{`;`~7pDKi*R9?m~B6vbZzdk{m_`rg4)z54M4{b!0 zTJGXc8SbH>53WV5hWk(!^jOV8f$1DEx;Y3oEq$Sl)=l-vOJfYppJBECHBL_vc-UU3 zpoU5jy?Ykzqi;VtFx^a*W3a+QAR{S9$9%cWdjev0VMza>H(U%gnG8_?qzK6k%Z z1c)TIhS@K}%UM97{7D4~{fZw;Ocq7t^hACW#tbIcA2_meB`mFAGUQk&@|IdwPOSKa z$>m~je_e8!bLT5`Jnwc4pzl%Bmd{#USiKrAH~)3XDKEQQnrsM~zxppiX9zH%8(VdZ zPLSu*!_qSR49QAbZjbLQAUVxWV6YyssqPs|eywNe)v%A+wDvIjge;vL^r99q6RAKx z#dC8s-u?N}41XSnr;djj7x`J3R$8pm^V9DeJ(bO=(pr)7QqD&ue>x>E5gbruyFHQE zeGdS}0kh*E268T>P(r{!lho#q)jS;7;nk_{Po7vQezT&^8LB{C7`)mwcZ17or9>UG zh!TB+adZ??$+3HDMmN5`l8UeU!E8S#&ZT&GJdnTGRA>X3{k}F*_3y}?!ts#VocO2+ zy-7aQE5lE^23G0umIcZu9)9szW*3t`I{UmB5YW^DOn}+;)lbS%NYcKNJ<(H0wwvHS zA=u>PXfAN?&DfKA=FdXN`T3mkmxTJ)gRW!BLhoebfdvVd*f7#acU;jRjp}w|ARO-~ zF9F*JTkr%k6&xYU5(GfWqnunIq=*{=@WmfTHLmx2E$5=M9nOP{pOY{MZH&fBEi<|` z9ho1KIEFr8OH}&3t12|Pbw2+bXrN6+m|Z?uEEFFK{cHdZg~p8im*qfs!<=k2;KqJL zS*cPnYHXXW?U9e=1yKQ@ZV1GO?5-B8s_SDRyft}-i`9y;Pl0AVbN~bRT5wM|O(ias ziNnE998Kb_wS~V!USEJ0-v4C(-l;VUrXw^9CC&&N`4SCJ^)MIzeKQ&Fa-4KauqXAH zhz$ecPF%pT31**;ON9~f`Ro!jOufdl`el()Fo)R6vvo3{nkQ4kISA-2PwWM zm`&8P`mmwd`HH9y*IY;HdqP|*_Jm|%JDN`7WX}tC*BtyJ{{dZ~fp@D3_jYv%l04=}iDD6l(f9p;)%htSk>!yQE8-edKCWJZQeNK*QGhZ0a>tJ+s zu52O6IL%H~Ss6rMpggAE#yS0GeS89khB}Cp*Kat;Cze~^ z#KLlp10s~{#MOK6U&RrYMCa||e0TEUwq6A>!pLG4R&c9V08UTY@{b1?VY4x$zTCt^ zS27YZh+>gN+E2vwg>e)Jx_-YXGAl=&)&Xj@qv+E21tri*JdVcP<8)_J$Wji41)xc$ zw128_K=S2=pX%veC2p7GruSPH*hBfffHua~ek#;^J&WK)ZSr|@L;H?43)Z*=*$o>? z?~5MXN2=>+sE#On8FE3Q)KT(DL8R42K$l9(LI2Wc=D)d%NjRQjA^#M&UH_Y;($qA3 z3#OtS*A)4?3LbAN<8m)nWyCby{P`TAQ>g}KkR}H2O`{=bn>>LtHI%I7ZWxd zSYJxWcW>Gst2q@1K8jAo+z{gp0=hbO9B@MwuAFA0U2|h-dn_oKX@6L=5_q~IPn8lW zBi<`pe?758)GMONw*cN684MjrRFc+51v1ZwJ?{S;?N=Hjwoa4+V>=8I4ZGaFm9)+v z0TM=8jSu1xJ>+dWy}MguhvSk*16|={=+#In0<0A_je(bET!qfNA0|J)vuY{UOlBDi zU8ukq`uFW2@UQY#eYWCylGpvi41Xv91d&9K z7UtFdQrAyEJ9x?w%DQ4Cr(B!?X~-+lBqN#@}yr| z7Y2lZQqezZJ5qFKH8-fFtpSYumrur%ixeO>u+=1YGB-A766qplJ$;^6C4zGLydqR_ z{o!I;r3V6v4tY_IfhX=gM=p7(4ie=j%QDSNi`<=bmgg+-!d!;{1?~o^k-kyQ z#fWGlFeW*mt%{X70?@=>2Nxt2$5D3TjZDpVcvIGhb+oT0*6oL#oBPivv0ip2dYPdfGyi~&5O}k5Y$!cckaGL=lZHa!lNqaj9SN}KV+Bx0Ug8fgdCo8fVHIjnGO#_A~RU&HpVmU zQo|V&i$$0{mLfg5)6}h3#ixXSx*e`s0teF_h=TFamGh)W zpTA%;UBot9{AxUofg7~G{ zhlVzmc`*}L+C?b)9_gB`BkMf=pbO{G+LIf7S5MgyK02VYBi!EZpoEIz+)v6#e zBP2`I^u$!lPQ;)dGtK&1Z%XCITV}3pAh&B90r?aT!xH0}J_F0>C%(C)!Kvw_c|k8H zmD@On*14()l5d+RcQ4PLC?h=xSpx18l7A8U0s;rX!Eky3>Dze5@yKo=p51=J=Aw3|b(#^Tx$#iLM^No`|E#M&Nl9h&G%|Hs=g;D-IW$$PfmdMMdr zQ9A#VsP}^=A^y|P5p9o|ckv>&5sj|p{{!OB<(T50k_xV1)C$J=`7>5Ha7Sn64`#Kp zR5pcq39qT*=+_~MR73$CG$PDGRcWt(`~!b%ehCDqoApyj3e!Y5PkxieRP(N9JW(;k zkg)d51m;6m!;05yJo4$qD8x)%G~a5hLLp1j$+YB1@nG;<*a(%zWK3gO^L$b|BLm>ML4En^rXUaPCQY4Iae1>EPUwJ7i~EJixn@g+Bq@HV#;oJFSMSPqFgE9)m1W)*i40R z4CYgcraFh&%ekxINIQZ2uSM(2Lc4_&{b8v!;8(^Nl4uchibULC4B^aHH961c@IHcl zLMwnLS8nn!T%)%0N$T2-V1KWaf_7l`a5v7>sZWaS%I`|PL5*%rjrXe>-{wzFI1E>bzp-U0MNS0PtPNWy>%O1i6Z$JP5Ns;6S)njj71~)V0T7xtXXtQEQrIU}G9jX<@%K_otuX%w;VW z&T#lm^dWFv2CZnhU{>)z)#oV)Y^1=)fl3P2P}|awSbG=cPQuv7o8HHtzn2I&_LJj2 z!bw4iLeJQ-q_y-tDWHmNGz?4b6{f7)RU{huqIO0H;|}$yU&Ka4U*G+#qnXsuAf)0u z7Pwpe`j@orGB>%JgeX1bvi|Y0>(xR}?u$6Yak9@j9V?R{Ulb4&Gyht~$j_TuQ(}&v$vWva%IB!KKV>{ZxLYM|_ z-%0SU{jFZo`1DLz8?br(i_j?m@2d#cG+6^MIq%3Om;jayKfTg6I$$*;B#E62w*O!# zOO>L_4lp1{1$(VG{@)&p~`u8WLFS1q*KuiW?n}iA@X9nOHgfLX6 zVSd)_rYi@O?UtP!U(c@rdF-~!g?KA$%8^=hxxx$ zTnyPKWpaBOqA0(2aXR@Y}!oP3;VxIMLa( zSe6oS6(bda$mm6DcxyX_y)763ORRU*6;A87IP7s2Sl3@Zu`Z%Fj=oVK* z2(065FDx8#*M(RA35^foxYwCN93>i3^<2zmDUsKS*mCbE*DUFl8Gr@oNwO@02hpx= z*3u0lx)zboq=@Zwzsb4eI&}r4044BU%nuI^)Vhhph)CDg`Gih=8PF(-dLPE5$=BYG zNX2kbk!n{2X1#b{ZCB+M>SV+~eNH$8H<3rkzkOYM0i@epAAQlNtc5r!dEO#gOj3n| zJaHQ<8}eEcNF6b4roEv61zOA75P!!l)5?j2uq5wv4*%p8c3!}(WwlGg_layEOQi6w z?&@)eM;Q9N&^!Ilu^y$%Rcu1}|5f?^)8!_UoFvUf0KZm7b$*oz{)iSO#AKY#9j4!m zG=B=k!^OmVLi@tyo2`8cTT=UirXe12P z`XL_me@9F*a?)4qw?}Zc7`cQZavis;r(VgasnA61BUqJY-g-z!%sAV}RB3Kwx1UR@-?AUdDIkW=?II?D(=yHSgz z%{RRygcan?jMI3eo(T-L<}OF>EvRN30RUYqpF(c{S6+pZ3Jf6g)eQqW%q9hA!k0wM$Id5;p zs=mTAYLS0HXMm}kQ{Ebwo04lWQ(+qTWd_wkM9+3D0jlTrv8>Rd6 zLjJ-5daWk3J~`LBS5FGnuwgK;dSY*GSDDwxd&5o{&+WkLLu##}cx|D}Oe^o)6;W(c zmIjI~u4a?104MwMiZ15Xvq;sN_`PcvHULqPaihQ+Nq*d24n@4VjR3Cwywq2C7=)<> zRSLhyglm?gUqY`v&<#8SpUIedUq3Fj8JEU$F%pEKofQ^c6sl4~3QU%#X?K8=#EaQ9 zsU%Q_`hP&E>w_4p2nT~w{|Ab)-D3O`bS$&dG+rWt3xl%}u+>l<$#Zg&KW{uSq1_5nD+o8w%!Fd^op}#5raVgxEL3IGp$HLw zqL$iy8u;Lk-OCg&4Rc@I-!21@%aB?El=sVvh<(Sk(M(jC0PV0FJ z6Yps93unB_Yc?Un#w}$TtV$ukMDvKv=&s;=_VZ!8g5OX*9W&@%yaAwo4kJuJ=tq!M zFF`Y1^S}8&lyaJKlP{LLPU;op_%w`Rhf!9)zbp4-o#ZAXLDFzM%i1UdZcAB6$bgwD zS$gj6SX;eV7G@5Eudu_v<6`qD7PLAyeUtyh<#1@O(_cju-?%wytfQjO#3PCLf)Tu1 zfzPN~kS?;6yp%=EPl`r+ym>}u^AHJS)PY?$Gjc>Q@M1m3ZDWVTz9>n>rR+IK)U+tt zv#`*sN~lMG&f0klGJtw?+T11R98e_-c_=QNSSeUhoQ4>Wg07s&z-!5|seJH~35XeA z__FeUpO9<3Qh6!vZY0amYDyH@00;emcL=F9hC8@q1hV;p^39~PB=4w<)hrb+?vp`} zWNRortC9SU$+rd3{hKeeB%Ip5nVEEU>T6nWTqH;tG3XRp6$hdPwHd7e%ogJM1;W#E z?_4jXb?VX?%@8!1APzS85;(PCwrCjwEHS{wz5XZ#U-s*Y+_2)-3mth+^lT)>@s9x2 zOQqTos|63M0s8QFOj1?Auy2ZvpMKH&P%nJy5=VniAZ+nb5e+^-Z&sV8*Xnpkr6N!J zpCic$0t`#%RkH#1zb7usEXIXpNp})qM`dZ;ph=O27#GgOBBtg|3K1&i+8QF(X7QB# zkLpI{foGlHMgpH00%Fk$3n&k-P1P+!X>%h^>$@!aOp63eJFHftp9`7Hop<|Kp|`{R z3%D&m*4*6&n())QGAL?oa^((Uqjp4I|4WRG*^%n#;Qp z&SkJ}-O3LjrrI*Aya$qFkcpw!IO+q_$a`|LB5;Btn=@XBM5p=ZE9Xlama>Ku%GB`# zIVL!9r$a)lH_HH+_KKNu>dO2E&kM(+bn(D-%T4dznS3@v3irVcW6Of|#|6l9mR2s_ zM&v{d40*0IKSisHV}5*<=;dYq(_NM4)eKP%^5 z0PfThs!*u?`U*9*jS_t-{H7~_(@O1RsIwSIyYgi=8$HhwQ%tCU8hE;kY6wbjz0{jX zn>CBi+vLNIvMnreP>{wE#+7~d`&@g@OlzSf*C-*y&QGE(XX4n{EU}w3O5LC~#s6U~ zomh3E?3tY+(pm-x(oKnqfS1gDBzxgLOY#csy)mB$4%%Q}Br%{6G{mK+$c|}-d}#m~!v&U*b~=Ob=WRbvK+J(O4~)#v`LUgRMDBM?NdPjzd}eoEew2@oKa5GE zr>}nAQBOqy0U&fX7&FWQs`7@dx#tkLQd~5edEnBm%Og}_s+~nsUXN2s7nq_(tx7bb zCo=xCw)QKA=3&bby?Y0#mG8&k(F^L6ka5qosFRY0eoktI#$ryFz~678Moj)4In;Hi zx`OY&?Xs+lyJeXDNABLgQyxhRmLX*z!&h7=AV?x8DP{?->oIEbxM5`U}dCp(RgTn4U%}tNAd+ zw)eUV#xA>e)t+KB&DSgnqkHTip6m9b7Yrt4;bM((z;IZlh@S>hwiB}aXP0*Z$E)7w zQ)O_Fa(!|r6`rXD+S}zWJ~;;n!;P1aio9**vltbF7%m&oIx<*27a`M^^l6G-q zhBPP{S_93{0O%X}1+oJsn#ykk@myeZs+?)1CFqlzf)8l%3hW(}K`f8~DU6LO)`Ft@ zMt)N4%=nMiNMCeq)d(aahnV`wvmC<>Z~00)TyASvxFE$}1=h^8Se*YH_)igFDG`oo z)Q$u{R>sgU5})Di?;rns_kA)pkn?DbvU%A`DkZ5rTCeg5?)v2d0jaA4%d+UOsK>Az zv@!b3$J@VsyeW5hlE`h)m zeDfw=0U;GD|A1zf507%Fy;@LD0?P1-FHkQ48w3!Yh9*e(C884&_93Bgc(S(Stjm2R zMn14%?A9m7Y%??M;X?e@gnYuK+Hm_VkRyCie({F^&#;Wb3+%EU8n=P-}b`3hY7ij$!>OW}izBVi&T z{&d1toe-T@rM?C2vW!dlv2r%<-GD^7(b_9Is^*2Z)@jpob)5W1ySKltwqIK+Yv-6F z6a_6RmPxs;>RJ4DI48_YE@J|uoM@hNkO6J48cOMtB;y!@$rN#l=e2Fxc?1aX5c_mM z{>vWKl}>{CG}jFX1t0TW;(p;vn563pRC7+NQbxA~w6fG_uX;d@^WSQl6A(e93jZ|s zJ1G|y7Kbz(ANWV{w^tjfA8EK)euY4Q+)#LDpIZAqNFb7|dpBQlWzy6PNa$J1NuaNJ zJewWs=mQ@6w68+SMf;`W;s-yDg|Pd@hhh8*>$k!2uT8i?#1QTW%cQ^W8!SG3@HmxC z57GlkhEP>WX42bp6si||^#=irF<)>hd@w%fOpLhjjbIZR-D<5+m+!q-o_FWc5Sr0k zS$_Higxeehf{pWpk2vb_2||A<_^V$IYfSjmVsF3G5SuD}Aw)dD9{9`G_6Yt7OV$Q_F0cZGV_LHWjBcXxwycL^vmy1PrdyF*C< zX=zCb=@2Cqg}u|?`xorGug}>z=X;+!V4MWTNh##(yBv;c#?uyfjN_X?JSj^V&tiEd zvx0=~ea{4W8r|3eK1bWg1Tr`N!aOxBkF~Xw&P}@RiZ-=6L)XaZ*?~Lz6@UBj-x>>dZ z)9Z=R71HqIYAjsUk6!zme|+4!sZ`oEq0O2a@Mf^|ZQec6!AXDi9RV~$*DGRwtkg4( z3_mUqdcF?>z){i&a28hD%rY^uCC)Md<3Mn3cWwQwVo7(m6?>d~cD{w~s~Q!K>7q?* z%FRC4*}+Z>yN(!_>AwF?s%*cNe)>M1qLdRd8o7jrSu)47f#9$^Ag7A}p#Dq7I)UTH zvLnA9yrf?yS9hdV63~BqDhAL=ffROmzs|(*V-iZTnGF$qVCFc5@u9_pmpGDE3jv(+20NkTjC~h^uFQpVJyoXg|UbB6w9~6{r z{|xpU;eOTH(1uL{g_HatzSalA@jDsl5S9$A99plnV_H{V_tGm6qn&iAoXeOi`JLiW za?!MBypt@GWWly8gKdsa`msh*A5=!Yo(ZPupnPL@KYZ=?p0eR{u0iJAKNbs_w*99^ zwVuauNIS{#HX~Qbv~SXFxQRLxjuvTTD}~_?2W!67TqfBSYlImk!+VWmvA< zYwv<2X%kP(>gNlc0f5v7657vN3o8PA-PDu%?^RN&$z1&1ipSYKXWr@cd|3K0hMmjF zGZ$y*yZe!khaRKR??n9|rB>FMbaL9>`RlCyanmEw$^-XxWiIP!nL;)4CE}klX08M2 z?@}GAtg1XIk8MGCG_6|40sw=+8iI1xEFrvc5vl5YvuFtG2)*3c@R;H2_dlaJ=rVH) zO2a691f#be#An+dSEl^Ok|t7;mf7W<8mM(Of5k{y*(YXG1xy&p)(p?$&M2Y7PZx%7 zv!xQip8x_c<^JH^_(!Sb1CsJ`U3>(n}o7 zywyK6sTXcdsS)bYIB~bvh?6bR@G#^$k3G|8g5BiR-`slKcR1K_rd|F8gpB&qmPB$S z8WSG14!7ypkPDL~>O&d;v`X2&1XMM+LFBAmajw?Mk2V`?Z@IM>XocD?E^hs0Pe@*_ zajZm%8O*z+FqFQkyicG(WAUL&ZI{v5xYR4*F78#xz3%(2yTXG5LMEcFGV|~NCq=O* zdvuTEkb&O-9(B2ZW!@AtAEf)oNw>xBVUR(WP{hf8zrd#^i#p4;=?CvXK%CuVkIDMd zx<9$@__$Uy6(3Y&n`EYG_haFMvegq8ICi?G=&k(a(;NBQLkAl0{a-)_a2$F~*?MsE zL>OVET@-G!$)yM+mhjK@AwkGV}zyXBW<G<90LpuP6LJO@TkNY9iZoyK-4;Y zxk}Pul;nBZ%xm}?45L)0hW z1V>&`;0D@Z=eN2h)QjZ9@K%s}Eew@xYenV|J@+mb*J~0C z6}uN$USxPR$2c1m-y0C+PFB+q{fE_ofuCzWVZWGt!)+QHm2&uZLPr2RdQ-6kWEh)% z70dUV*g!EBvX?82%AtN)VfAuoz8GoADhn1hw_Glsu6WBXA1xi-O`ur>&@<*ql2{b2 zkB)&J+ib}qv`#58UIqpTu!4^$TD%`c^MJhPpQeF7g>9dT5ag1d{?K&vTZrER$$#&W z$>{?Ca?mtrtI!O9f}4?!iE0^hDh#7!efTBbviAE}$t0Uk`+m)I_*!2T^ZwEpR}g{MU3=iq{Q{beqD$m~4Nv7fZQu~GLGirYyS##TafLu12+u>Z8J zMd01Zx7s+Q52snw(jfZMVMki6+Ye20rjp8^gLSr-r}SOi|B)o;AaFqw7bkK;uZUT0 z!?8}LeOOyrpGtP*4hyR}>)b+pQB(Ce$LPl+iX!Nd<~JKB8@{<#tw`L_h~cQ0GybFh zEr6ftXx`(9e1=yVn{vnLY40=%;O;daK`~%hn1=n4{ArRP=smrUT_C5N=-O8Gsn7atqStgJMy z#0sS1vP>Wc1xJ6t*zCamZ{vAK4DOFYrD9gK4CdHbfjWq%>1X9DH4KPxvI||6Q$(mw zZ4F5=f!4%g$jf)LJ9JWgOxX>8&e_OJG~5PdZf)Jn7guAfY4q9zGa`d2g59mVRMl^A)T& z-;WpV^wt|K67tkgEd({njmvbr!XJ_k( zhz*WTs*s%qolQGq0Rh~{1aNyCPts6*5o<_;e!`S74UoV|JqIg^kFw*0(E>X2I(YN5 zy}dO*jde!DPL4-qIdfns;VTRKdO{o2JGPbb+RvN9bASN-8PoFX-3%DIyex?)r#TcI zyPn8Cm4FrXK!|0{T=2)9U=(&0CU>5I|G~(+>pI@#;3`)^OiMUxS&x1Fw`kG| z?Y_Vv?Y2r~XIc2;YVE;RANA(N9ioAN7@WXrw773e_3sh<3joLULbobMBiE+x#P>&* z(E~wPD|%GmDFmIF+f6+@2cKE(Gw*CXuii~`+BZg$5DIb<0lRQt{I@Zz?2IJ0|4p~C zydBH_;fBF@U1xqmGMD}XO{cGAjS{cYx6@@Sch;EtkuB|W*H)JE>PK5r_VuNBf}an7 z(grD1k;%kZ*s#lYKn~(W=xlTw=Xi~3=_wnv zIg#!vRFQXSeP|crtHezC5Y*2Qwh1r(3K))wW~d08u_AUB?=Ef$o$mYWda4i%@vGQ} zDB|QRr9zkD05q(|S{ZJ#MYdn{Z41~$rVP*Vs^9WivwUy2rW`v6fWO`ySz(kfFAv0! zBjp9-yqBX~-?hviKN6s|acvQl^V||QPYf=^QpeU^{X3zfFfis2*EEldv?pN|Qx-0h zYdWgUL|+*I5C{N}eRT#AB>FO8(`v{)=`}6%6GPJ?l`75GYVxDl93Y-^ktU^Y&DDi1&hiRoZ3V8Lsnp0nyvi&3IJ zblk=Qh%^7dEZ*XtR(x0>^IJ!GP3GEIR8!hex8?9Wefy;4WJPkNVwmn?V!GI8W4Kn7 zN3A~myt(tlu-2?7&DZc5OaAhk&PCtLIY`goFR!RSPYa;U|} zU`&8q*jETD4Mj>7<(PDZtkN#e$IPnhVvlNkf3idJO9(s0Pc+o`<1*_S*{(tU{xJ*s zvQRSgz%E#B$`!$&W`s9p1eKd9NfPvH@uePLcRRUs`e=3GN%5Df!i}% zcaK>U6+0O*vz@dGz)@s5%f@%k3M-QUJSC}^9m+x?E4u8>#?jgKVI{d~<54%O+O3uQ zj&~cews`@M07lf}GbaN4BI}A7rawMnTVab2eetCSuneVKCp~G~F&%2`i>nEC^ zGIn`+lFX${rZqf2wHb0nc)=|~~0=A}Lj&<_7c1z&{W;>z>mB0B}fVD`q@u>qh_VV8$`XH_Pw~;K5rdUA5xm+G5 z?6wd#uF#d&c6wWLBoum_tzVGx&Cz&wa1=@F+151}j83_Th6WnhG($5zT4Ai&HuJ3Y z?slopzG@fVr{-8<^AAe51Dcg)pTD1@8%5HU=drnnaRUfYq>`dpA|hO*c7RbM1vem- zlBzpeN5_1Jrht~J@Ja&lig`zdH?%D##TKGyH_d|MxIK!StK-hr!I%^N$ScC9CM-TJ zqf|Dk;cqQ_AD7SL@x0{mI`$`3ak_8+rOTa$;ebOV6?5D}-C@j>$a6?6)QK0w8JeYH z*RQOqG^il05GBTBv5?Jh4ue~Hx3YfNJ}iq_VhYP`=m4M+(pN~+S4RpJSv-gC>hcik ziYt^wtJC2!aWZFt_9<(Y9;0KSgzW+m@fE7z7nevH!MPGNgOg~@9&y$O=+g2=D~M%2 zsft|PGc#9OsJ6i~=4>ZwYtz0k6TWEC@1JC%O1jT;`MlAiE{SNZ@?ui9=ZkyBLNOue z8YuK%@8|;yS{y663!CzO_t&S2X~5qJeG3DpGI4NFXiEn%GgF3RQ(X|7y1*?Mv7A&rp=$?)#S%-=6aW zUh11q52z$yJD(Y@wo9rN_S07&>*9En38|J2UPLYOrHi00g?(;EuR&nxz@M9_gac$1 zrjTPxGQxBvL*(}*U7#a9#&%l=S}W=ILhm-F@tZWa3?37F=54iZ3Z^P}`8AVD=CiOr zCj)-(zPxP}W8$oOsAJAeNVGE}fw}($bOuzNo8qXaa369ft{6?n-FX;t*3QQjFm6yz z*0(r~Jm(HFV3#e}mDSid5i(C^h+MNa#iT{Gj2hWJE$4~I(B>)Nv2n_MQy;ZeZ7`j* z7lk@U!8%5){WBCZZXzQnb<)K(m0qR|O+o&%OD#a2m4V8ptT(O%4!@dT05j>J6in;8 z)_ktx!c9vfBT!Zx!h&7&CaZPU9(*zFbRDkLa*dchz2-l*D{GmlxuA=5aJJ~rdn|uy zqrN;d%&M=hlAHD+?=i3c)d8&+=J*Tf9NBAB!OtN+J`_yBG#ZY_>NuY)I^hXTm6~$` zd9=1u;BxI>ywKj)*62~2$wiguSbb%ys1b*W-OX1pL0Y!$rW!#YWNJ8q7j}(DbDm;i z`3utK!X+JzN9&-iKKB&TG(720gdK9*_Y{J7@>zc`l#2f>A?v>Gr}sOtS^*;}H0Bmr zqB6B+Kka>rBDk(*4@RoXre}KXVCYP))`KN=|)De%V`Y% z1(YWCs(zCp;9vBZj~_+D-aJhh{wLc$3kPF8=W;FA1Ui!1D~IE*HZ`-dPe>1z%kzCO zuFZwMa-kCpWk(fNXih5m#AHAVIgGUW#a~rw4aL*Ck59v72y=7zaQI4@)Mo5Ogr96V z1j8;VVywq5qBCZ2hTBf>`WADKk>RKyYy5~h1bKzaP&icJg9#m1smgBO3A9mvWLkes zU8o$xwPYWL)9a272P*2v9nW(0?j`Su^INkpD&D}pd`u)F3aSqI$p)3KiIAxOBFEh! z**Jr^a#MWiujuD1&0;+TGc1Yy_au3ak|6kkg9EAwtgNk&&PamHV8Q{#%92A0?ND>8 z@KEj%4q7(vzGgxG3)UV*?WyM9s%*+cvL+ebNdkrww~B*{JswulE07%2*NC9H^y&ei%ViT@dshgy=Hs+sci zl;O0$E~4W&rBJ5y96IDvA^)AWTgaKIkH+M<{iKp%uz@d6Q{$0Rnv?WXN5v13=$J=7 zdZ9$61B{4S2}l41yf({7LYRZXJ*f)!^?~f;I#UM>2*EUnVFqgTuB`6|S`t|$@q8}X zcIG?A)@LIzQd%NupsIvuW(79KD>SHeWkq)7H}!S&A1OUlRlN`$ZMbNkC=^xaT?>~_jwJRe6(| zK$%KRA}GYiIC7G18^A)##TstiRR5Cb$kHs=XaWldDsMICQ^ zoE7>Ozwldidt5)iJen$$oUvH*&xy!%UfApMje(hG+h7wLnm-G+uwZk6dpsqwDu(#i7BtG(3^}u6{9KvhzK=GX9SHX z^aLZ)H^UacC4;*Rbvi_rP)QO06{>;Qfw)&%3p7GSGqYMKdK=bv7S=R zIKJss@!eL7~!Z&_?-weZcpB4RDO?E-e!J+^B z-bOY|pQyufGUdBS01TO3_Lpc>{hrR%U^x`)L2Q>Uoaz5}Hn8G|M$D zB_U@1SWH7^@%IwqF=edCoNa~iUoN(atZos5$1gcxS#57kYTqAEv14ofcc2igAy*{U z`c3Zknu5CQh554N%F_tvg-=F+1h%>L0)AntIRLT*FR^o>BqGA`o-Y7cVHUGG1{!bZ zyQF?-tk21!OY`@BfqL)(EJ&dc! ze&IdY!lvXmF;b%a&#`s_Q2nz7t1s3J^-nq|LEaQF?pWy!{nD&EWms!lgF24)Y{_c! zSx|x+sWXIyNt1Q=HpYmc^KQX|9j90q;=V6&2z4vRs8F!d>w>8np37&-tLln-&{!2+ zl{ieT3N89-5wMNd0l@3q9kqIdQKv`W&-amu0DwdsG`c*vN*}G4ZherM* zQ>Ze{YH)E@+gz%|w8>0U%Ub@regiDbKOQr~ZN|ki_+fi5GX?3uf^B03L@loIF)1_} zcWk#3n{g?gDJe$rezPDV7oa_Fw> zN5u6y3j$Os06aFG;O) zNn~GkI~h8zqwzUYQg5l5eN6#9&e1fY6vU z>^1#Vb$6mm;}a`&6@JQN`AqH4{iriw92^q~H;EbcB5w&8N0G*~bT+D#pSMqurq}Lj{`@kpPF3MogJbDC*1{^$K zo4-?y!<0phg^W!6|A3Z4xjD*RhfIkNkm|A&t?X}7d~90VVZ0x3{*d9q%!YJq;PH+l z^P~e7>hh2MyPsY}*?$0`@PsZg+GsONkMD%56&Kg7b15{d9Ti%5{TA9%_g=l2d04#} za1Qs6nZG>$)n}^0t67kgCs!-yM%UkSu)UNCutRC`lG3U;G$Ivp+?$M+i<`eA%fr7N zks|b*VCKUrk+W+E8R9toV?rV&9OqIwk!o0l`+FTgB2c~hvgm`WU`PTr;v=^*mj+Rk zhEP@e6JomSUyH>VNOdq9#!>D83}j-`&WNo(b68ssF3;xmx_)@EG8B|PL`61az%KzI zVfxA4=1f8<#RtZARnen>sE3Z_>s#eoVDtJW*5w*c8U2Zqh|0NG$R~O?@Bx9SWk@3( zc$}J?I`}cI9dfPDMeP$!ZZviraZE!9B9Sgn_##NHvr3CYbN9Ah0ZKH=0s^oy3yZU3 zeS2^EdhqU>zMo~5QI!slCSMYZmt2YQfRn^C1c_m}K4TMt2zM`b%D z%oOb^ReYL%mu=*^3h3jQM(Y0(s}A%_;&|`%tB5jzpwzjVN=kc@HSvW>S}AMSo`iM| z>=ZbQRQfP{4Ld?E0dHx3$|A~vwd4MOK3Vm>j8D2I0`~e!0L$ zuj4wtS>0R9Az$fIIaUg*_IXjI38jKJ`C))Q)(EZ0`$k08i(j9_KRt|>>>62=8|yCA zz@>S01Ao)Z8^+ED>yI?lq{A2_i6~f$r!vt&C~ibVkY`#v*(52qRKDUR1)Qp}6l4VF z+xmx)N}X8{E5%yNPN0#)&oqL+R?W%&h-Uwg8Z8ia+OPycjK z)p#oUMgH$U1jiZt#m$NAyQ-+J$jnGA&hJ4Wp3)IpHVaW(v$1R_^ZoPF6=&G?%OA?S z_s&Ep@-_J}rpE>!MJ@0qCdbWInKbUWU6Ef^IlCmonGlOW;Di|amp3ze^ zX#7T)`~`%xOTgn(!~9B%A-xi{)q4-xNq zv(poCqI|B1f@*gM%ytZck2)av>a~|!Gw%bl54VaRl3jLqrK0;JDmWYUpV)YUNINb9 zdLrWD8rBIR7aCu#xY%j#`DoZDv(b2Lpo~C@QUm%liE$VMm34_}t2inIc5;3Ydaxr?W;OF@ovZ1sxq1BMQ}q zk90$_%wa;^+eGh^9vyh2%T!p@lxFzs{q4)vW)u_*O6X1-N+>a6Be7vu2-k*}>Vyv9LB^Lp zBehFa->j4(saq>(+20A`lt}&`JUNiw4PF@QOx{cw0ozqH) z?*Z@LeY_V%=#O0hb?2m>i|D=Jk&+B=%y^78{SYQwgi0XQ(55lPIl~gdL+I0q2_JMI zyXtQ179rs;2QAtj8c0X|0I=M}$NR}fB}xt_8zPS%UL>syl*%_;5or$F9pOwbg@EP> zOGTHB|8sEn|EgCWfkoar;vAZ(^l9~*=b|s^vKvW>`DBpT7oG86O`q)Fj_aNsWgj8+ zOh`b;&wvC)o}-+1$wl7trFD;~Z#X=# zBF%y`b8*wH!+mN2z+%eU5lfhH3o)D?SKT4c%*e58GTiYZ)KM}`#2zj2na0*)xHSUO zG|`3Mxb z?+Ws9AZ6R0_^dZKxitPR5ATXu5rY+BKogaxcCk=lG_K{8i?-d7&{`Q~*?IQ7lmUdn zH=SBP)F>1PdCe6CT!+KK-nXN~2}|zbdY>!f({E>ms-UPB%taLMWYHJ%ODe zP@zz&8b>``RWxjzLZ7YyTLfbKg!i9b{LNJ!Wwp>3`Hu1%bE^Ch9Dqx({l6v{Bv*gj zA*m+rIOLh^K$(!Un$R4^%KmkP2%IifiPY4Vfym9VSFb>8=$&B>fm!stHs4}zaEDf` z7>Qb6z#>p=ExXI+dj<0ZOd>X2^R<&lTg$l8U!aM6_1;aj20PEpH1Kt#`3g|DY)|q| zVYQoSkNvxHLPEMFDdU96}S#_R~zY7L7#@hmK%%ik=?N(+6jg zyEtA;*xqyxAdnF~G-WH4g8@w}Hi*N3#rRu#V=R^J zDIMSk&(5FPSX!cL$)f)hp_yYJd8@|KY^llehD4s|HdAvC$e%%Gw{HGz3Sl_aqrx2J z&O_1Z_N4X2JgP3qJn3YME=&3-jr*tN_esB9I~0aZg*LufzAT!WtD=&ZEjaP(e3!kl zx|>;$ec5*JSRcDgt*oQ*4JjcO3C@@pK-@00`2ygC4ZV5Ap%c7mI`R?5xlvaD>6)5a zZyvjB_R!0R_2^-orf(8y(?8E&FZ*bB4S^v2EgR;qQWX{^dQi)hGcnLphDY4YP3_k_ zIz!bbzm+y<)SplRP}-3My8;=%Zz?6fV-3wt`PXkK2~U$|j(O9u|9=i)|Fn`$K)!cn zkUI6hokLZutPZ6)S_vn-s|H3JO&NsZ5D-|QM`u`j+hJ|eqm1f9X`hX|*(h_oS|krE zR~AIny~m4^P(C9IDMdJVXk;|=50V7+G?FW!Cc-AM2o za6+%M$Cgj;n+n&H>yF)`X3%_bs(73BeD%mp4wby@V7hipMwcPjUa9&;fw>d8l$vBpk~i z$sxZr1w7L$NbV5RgoPSk4D1Lib|?=tHG9ocbJQG%bDN$I-Fo+DnnG+lvvwy4vb2H|NUr zRhv!G-i=mv8bykfL8)8f-1d{@BXb9Gk9yNe6dM`(2Dcy}OiT`bpD$D>{vRoj2ApMv;VbI@c0`C zsELCQxs=qZL%N^OpIOEL(qZ+2G+v{7e1c=K8vQu;W&GEMQBLtrnuPhynoF)Na>y*D z!42H}B}Q~h4wgY`ij#-?B)yd6=|t=v4M&24@gv0DfxYgG8^{MgbqBIeV zL9XbHEbk_V`ax(y&@?WAH&5jdcWR<%S zCCwX4lYz^nOLusH{=q^h z@;gA{@XsfN9b_km`PnDahQ9O>u;W^gob>qhbWs=VQ6GTm2RLXGRmR--33g%=IgU&* z&vr}klwrq$+R_ALS~4m9c5%3nOF5NV(WPWO)( z%O6(YRfD)g^fn^JB;{1zE^x_O92pum^;=$7Osn4T=f@HOJ;5ACk53p8 zy?Y&C#p6Ej5~y%w7tEVYefa47@_lLzIWHIozL#g!SNxFJvw)Fx~=n0OSu@%0063I z3atUgG3AD-!i&v&I+joMs&@^nYP+-)J92UK0Q< z#W>z`$ylvrm`=;g$C<^pI6-~~zINZq2(kdL%||E6^OzdkDrf(j{|`KJz5cFb&guMrrXcAY^Bp(vfCWj;2*G?D#ev>-!P( zEHc@(OGyi$4$%&69VouY*oxrNV{_*aoNjPmR<*+^V$*{6+lwH@+?{JYNpBR+iDV9RCriq_~YU^9))}N!kl8`|S8_rpbvUl|6 z^s&%kFj1U-|+;exI8V=5N3K1%#yKrVC~3ktE5hq$8$6o}AFg zQ9lf9ML4q~eMriBPI`dlhz^dZL=3c>yuPK~li@olnxgTx1D@%mx=Ybz)n_{_U6l-J zf8~V;I`kOn6-%$39GCz8JiBG^^Iw<62LeGiekt;ER{=c^{KhV0J>e-c2C=7d?mc07 z6jN98b_BW4gl99-M}DNlNhvIZdaD@Zl7MyFUcTAHn=HsQVAC4-#^^sgiGer_lxB`J z*f~=;v3kT<8cP`aBQe3wlD|9@xqv%@sXk8O_ThX_8?)HE$Mp&ZvTCkLO$=B@TH}DY!P}H>i%vmopTXK z9n;!h($={rTD>=hArIE+XfYP8FYkj9Cfdom{~T+`2!1<$fxnGpzG+nz;an8;h#AEF z6C6V7q2`4_pJgVL`e6wgDxB@oJuxdUyXV-51CInb)iNzq@-C+hf>l~#jQ-a`|8yxgO@IPZsafZ0pxNPb$Kyy=qk90 zB&HF@PP~fWHw%18bCRl17dJ|1ZgloBnx`(eob`=H!LjwbQ6p5(5`F*c*|FT6tJv2k z1JzZIw@_uJ2Jv!da@}UU3YS6WEBXik0^q`5?98`Dy%?w2G?#sLq@poj{n=QOT83c++h{P&*Y z3@F2o;N7vc=ut*YG@~LGuYCsF$dc4a4b^k6oq_EyLP*pLJq#!bJXvbJn25Q3#7&v*vU~)??nyyANkGn<@E}i?S>XQ*fq-TZd zQw2|D%DAwmeLY0Pw_r)`g`)fv9(itwZ;m0CetV&BpmpN3^a}ULV-S%{}<2+9D5{MlB3y4I;M)bq7o~BChtwVMlODx zdq8@ST*xgY81usi^q`G2gS9ALSu5LI>Ip7qj)&B@s&5W;98>&=G1|`+=NJ2_bf4#p za(_rw5oH{%+qZR+Ot1XNA^g(bK({Ac` zjWLDGQVQ+HQC1hgCjaTd1Z$VVk~|4NODcDtNX|>ef!HX@NLAkIsshV3n_)}0xj3{0 zNb#PdETgl?MjtjvoPtiqBVSSPL9yD)^cN7a)laKSR&XT4%HcI2z{LzBT^G`TKuME*#7nD4=fnF*Ka{2rCQgxXZwzHPQDL*4*Wu zeCHwUixo{8DB$WQ1(vPEA|z$X9@!3KVx}o*ulX*Z0@C?>F!=H-N&Po0SWT&*7Mb_> zf3LnOljHR-L^Uw9*-2}EB=IT>4W&fk4Z#c3vvSlVZgD)Y(=n2`1l33TAo^5#N(>7C z{>XDSfPl&?A_{lVw?oNd#70W@As6$I9U2MbNfF2-;p?p$cQF*Q!`scWbV?+IO@@$h zi3`X|ttk)^l_9R9=pg8uMF;85@MS>06b?G*`Ho5HpcH~gk2DB{QVx$H35W$9R}4nlcl*yNjs3|5rnA1B z=_YR%wd@G6V1N2bhqXHgR-~>#eE;+Q#4O}WI@&q*Pf{j|{mq;5G>Su!big*3J1S)l zK|vA*sesMIaC<5JluPPyyi&Z{kL5JYMYBv*4>WB%0fl>Q>$0tT_7xg3wL#!uIRy}? z{P60Q1v01;_f940B?UqtMTF#^jdc$WPGo!j*9z`K!JJzjd+hJ9)rkL$94A!zgWQYa zQWG6jc|`2j7GER6>H=cNh}a1~1;L=m&=FL-$pQ>wjv9y{*Kou3>SQyMiPi?4H^yNVOSI4wd{IQ7oa>@!J8ZucRrDS!zON}3kA+B6fbWvEj+DmB&) zp>X1!Xfx^lh@R~jcHHOGOP4=di}u%U4@?uC_Y1DC-n6J&AzPTVtb5c#5M82k`D1PD z0?RCt3ntlZzl>kDElXbe1^u1Sb{LLQs;F8E7SNycFgJ@nfIV}%sFf6wmHzT|XEm0A$>W-YI8AsVa}z zSoHO{FpSApCws9ZRu67db%ZBPNjB;sJe6|vv*AVL8v_*VSe)l^olQU7>?tV8QlDub zb&)NF^v?(1nN>rHNSI$sVE+Y#j47fRRaOJH5UOXM@%)Ir7v}B(0KigakaMm`rH{?E2>_Bt1QYTu@UI#v`m8Mj8XvPj)D7&K=J`{npI72=x8H4GjChukroU zLj}&Ikif(nYKrC|a<}!c{)bgx%fhp zMxXNURpOyj9bLDGx<1w3zkrZoY|64?_00{j5y=M=8GSpm&nc8_R5Ox|Om3rR$vUF>7M-PilR^NOvxQYQ zD1zZGp*o*0bQt!lsP4NShO6;Sv_yuvg2KH}x}~-tSRaTePBOyE?WV&J9e}9m z30EwPTnfyuLb0+^dX;0hND;WKnTzwh`L^>qNiuFrh_x0mBp4l`3m;<4#cF%7^PuGc8fZX+Y>h1FivlsHClnGLn1bcr z2CCo7Tg!oyxC%0qjYp|@9+hk_{h~!D*u}FC+3jrst?!l^H+b>o>`Ro!>W};Sk2B5t zJoxrC`Wl?AjtYid|M%b(1{Rd$Rin@hb;YZY&d!BUUTOnS!jmtvvTHnWXn99$`2Q%7 zvN>=(yd?NOmow@2fibM7*Du&kUE*{s2XSGNOy~83Wa)J$=BwK5IP5O1ay=6@AM`T!kEiCqntDmGQGKY$HEAZ2 zVDcH*>VPfX+4!02`o4myJG0-`gYBN{UcZlmS}i>+|8TD{wA!El3GoIi@M1W1^6PYpIR9ptuMsZ2^X)^Li z6%W~?!ct_ckwlytKD$AqMaf+#dn%p)ppY2kNk?$%e11hxvL3@f;$9cNcRAEbso-ri zNEKS6`E!|IX5APLcTh?B^Z5}igCO0AL?(Xg@j|aYWoV>KC;3%foamB8;?qcJRhg!b z9XH|zqR1Rc4gK*K&?yLKS(Il6swwT2R*@QoTg~{n{$qLx01fg^ZID8+|Ai3tmhL2_ z&PvKkW$rQ!^JeMjYpD4OW?f7qTE3YQ2`3$gp>Ln|uKLW!vX`i;sA!XN;k=*2X=XeVOUJ z(h#AWQ}eU}_$LZJh2u!G3nIB~U~(Okd^$GI2NXyQRcP^Yj;hf9j7*beMxULBbAWG# zF9nnu^ogcjOSaTVKqf6d)8p<)iFMOQ&$#7f13$}^9I9fdBH}XRMIqrV0;Sr*q-zi*FuC@iAh!l z2>Sa+99-{^XoK~4;o3QwxXA|68Kg1<0=t<#b{(s4ozm-mJb&@j^*A0ceknnoy?8*& zO2f+K%b~gQZ&N@9UI3YpfRO(o7JDRF?^wTA__JUH)l?B0=L8$;ijsoV*4C);-ApoQ z5|^!YnK+MdLee?PI44%cVqPoiY5SV-EN!8%jZ5b>6$KdtMM*(-v4|r+j>vQJh{6q9 zDvr(B0?2F8P4DN}F(opxDA=2F>HjjncD6fg^5UM<-pml}K8Vk@xWloimw? z`ZdDiy4shl24mUOKHBSo3E}iA7v`-QHx2`OoG96L@3sycm@I3L4m6K<1`v7yd`nBh z)!z6s|Ge$U;zhXwelQfNQ>Zt=)h*)J&*5DXc{GglC$ zYxM^^HulUlLT?Eo!;}0YwWICUh%{mQ$GWz<>8c`T^|5ssoPOvPPal7MIQjlmsi=A# zi9kFEurD&W-`@~SK-(6`+YZ>ZNTVOV!(ibbfa{~=^tmdh#KlbIJM*A_Q0yI$q>Ue`O+ygqOvfjAjBwG(YKuEoNJIo=(m>|zH)gr`Hsek z_dG#!C_%orWAo+JwDZ4_B*wZ@wscv1e^1j(0HaqRAztl0>LDrlSAvMMX zwAPcBQ?uOVMWy6a6bvgC1uVkHI;?3a;Mi$X9x# zH#1W`DXWuKlmb!u6$8yd~0pcDqCI!p+x6*Gu z3EzkP?g{(d_Mkz}B(c^|!P>pGF9%3~fa85UPkTfUvdB4sWBC+tQFB&S(Y0EIaFoWr zm@nuwCd*QnmB3TTT+p>Ie7C5S_0q~vc~wP`>_gy`gFq&lvKPBXmKSXb+`kdE$PRP* zv^u?i&o0Nj9>=fnuMVLgl$;ngmeznL(QaNLjE_`{rr(|b@(^&xg)`$XM_edRCG#pF zybM@)K0cnEP_orK?*dUfK;I}6g{$`X#$3cby=v^H7o7TGi!lh8uEmw36N`*e)=f3J zOT4a#{=WT*x>kx9`K#XnWrjUT@)86K2ZA7QmQ-RjyYL3TW}dZS6O@i@f7ay!qTz&5 zO|qh+l9JDHc;kKFCl;QKMv1k? z&^Kk8&()Z8mj4050yktJG+`b<+uF*k$heZ-ksA3434McgPO?GQ>I6aSv}zl|cyi6vdAMK`iM!tIgrdfCSJenV0*u?>3nFx6@bJ)RxEs(9JAsK)BM#73tI@T0=~4S_2YzxQtNv*LPD$?cQ96prGVmhrV0CqH*b4R!4J zg3~UO1bp%S^8b#ph!~~0Fh@?-irmow)0ZnLBX^4q$qST)4rK{? zN*E;Qap#7Ph02Glhwb*&-fyhjNjvf%pI_*7hd!O$OY}2xv$${wwK`u0u;6%n$oGI- zY}@v|YY(lb6pEQ-IAAj{slq)pG|8kjFo$(gzqeOw#G15{nTm|S% zHy-xm{GUNH7I^&;Mt2E0fg$TSWF~zy&2g@hwex%}@Vl9E{57wV49d7>VoqFmwg69K z`Mh9!Q;nd7mZ9(gA)rw8zbM$Zt_!bv-NujGBF1qHDodmLmk#{4b@)iNl+zcA9@&hx zLl`N=>BZ{8o}!HfR;In+Y?qbj53$(xVp*51*a~chk*Xe@ow8TqXbRD1Tn`fL$;cg} zVOeE%8xWxY&{qP}kbziI8Ffu6G3h18E@BG}Ok|*9;O;CnViF{Luneo{31t><)H0VG$-uxNFX zX+mgZlCS#yzo)M+>JMKuCA+?sk0q`6WE8y0DmL*jaj^s?p|Q&mg*M*v z(UUT_?r519T33u-Vq+0X;u1Gg7koSa$Kt7%vDAUJdA){?z@Kp!E(QZ?nis`pW~57* zmIpUu-G2e?06;A%%6m9I%n?l-!sz&C`^NTsLkQ;7tCc*|`ypQcQs!6%{~+x8>&^$b z748VN$<-B2dLx+2TMB^573KPC`K4q7b}c8o{e@S|VbhBP^I%<9EcA&gQsprp|09M6FWVjJiZ)vG zW(Tsr5in3dGr_GxdGj+A$<03VS^6x2y;DYV^QlGBDO|OlD=zS{(W<@_bi%uf?| zWbGaQUOpIw#(8OkCPWVySL?`@L3r3#d!1aT3y91d?fBxy*BQeAQy^1k@A9q#-PGIF ztCbA`%yTHLf4+h(0%DY?NjD9dRTUpAoGJ^l$J{SfvtJPms2QC8IFGA%{rerP$f=Jy z)rTi?<9@h%W}V>P=w;OPYa$zelTv0?mPkH(Np^2XV<8JF!?m31ONI%u_2LoiQhjH| zy=ee~Y;Ho1yCeB#&ygsTkAdQpng}O~uwPtPm01o4P{EqvQ)0t=ZJ*Rz_YD^Pn1NC= zhV9^Ags?!yK|<3lE|= zJ^una0YFA1MG<_eF5ww$7=~ur4>4H}SMF+chy6veSyL|=uAgoVp(#wb4OQ_n1qEm( z&k+Ai%`{5E;kIlATKlN_B86-q+;Mf!v%2}4z{j78!`)|#E>+R40plEd)MR*E>8g)nyy{*XX@ zL)09dk_`waY23bOe9KJJYX9WNf{BKTwHDesHDvcY&73)tjP+Z?C}mRKb9?&c>(DW# zf3$5(uU_FP-!z}QY+U*tTV&F+HLEAJ_1hG(eQ781X(M)my+`GYZGV?$EQERZ;J=3mKVYV91$oeSjkVW6EeN-HFd;at-`C9@MNQ-}NO5EZT53>F3 z-w5piAUeVr?^5krE8@MK3!+V%6SAIeAGs(CPzykPhAAyT=ty6C_G_VX!cUm3wJyVy z%{*E&$S-%W&&3WqfheLx?$7v?usp``GYWqrGag4lXhR9dC=MbvL*Ir`YzgBt zOKixgr6nl8Pr}X>+7{@iD$J<%#?l6hiRFhq##rrhe?Rka3_jMpFRV(&nle5Qi~H^$ zAQU*$U%8=Wj5$7w)9->9maL?_&aE|2B=Om$$_^N1USkLK+=GD>8?uq@zUKXv=^8EI4%WPI|7(0{t zWt`T^riV;z>xZ{>BaOfm{?2+viyJiMRQzQ-H zoK@=xOgtxTmjc8t?>Qkmw zVCm+9gI>l_6CkN&xwqH^krAVbasAQrOfDn2ItHr0TvzPTh0B7%Pu_)Td>F=If2K&4 zN&;ab1AOccDX?SkPY$#8kIT_2jc8xbkcSye+E7VgluQywacGo0}^e1%#U4+@D__<916bvfy03BT?!N-ECwZqC>YAFCI^i|GX1u?R7Xakl^f+THl zrHw3Nc52M#{i_tZ7Qa`|8QJnmC2IUa?l~Z zOcwJivzb^51lVrRL#lCtgwFK}L>dQ+nE>ggGqhAx#$&*g-F!Az%a>1KsPWAOzL@7k z6l@sH-)Fo4AP^Uq+k28grF4;jvJ|RVVfiu6ukyV{`tYM{kG}2bY?WN~Bl?nV`X_Ql zc|0*sK39uw8#q9h;*(D)gOEwHbswY>o*Y#>o-bu7Uga164zxNvd?x1m?+yXLNrcjg zQZ{IP@&mtXB4eI}z1LC#n(6$5{SpPPrGCc`OZn&6nK|ts2NneKX{b|4GLm_U#bmKT z(VX$gx*wT!6$KTcvL?unP6%EP>|!Z;{C@n8s(}f(t@?d)*K3lg)tRMxD}EBIaEsFl zyND~&T04RedB|!EyB4U;rk@zM;VV7~>VeU~UA0t;ro(ItZ{@98W32f}Y~0yww5r`i z(<5zH!S%~KRO1SJ8)%k;;a9mvM|GN4M=nxAW86(tC z;f0PNaU^Vj)%4_4lQ84p+X)V|*?~0$0 zJo$8e4&gDH3`0}N;I*L?dfm!HvyVyGYc1PpH9|XIz{fE-%FHp3FO6| zB&Xa6=BF@|d5Z#o7IKxNq$CQdzHnC5gcHL+Asv%ba>5HFjm}R#BqzKpa%#xC>m`J%&l@i;8OIFSjMrun}UJ%Gt{efU1OML#b=M}t5g({XtMaL0RIC5{R z%Ea>x40V70F;G))pa`G?VAZ%a4M&kTH{S2%@|B8G+RO*k_KZrNo>2I_U*+>!9AG2O zmKUxAU^M{boA8Kz_{2*%a(-3TS1bs}J&LN*5P_g7s=~~J#Kfz@$#rrIvfsY%!0DB( z9(~LsT=A`!11eiQUwLHFVN~$RtH<@kjlDRxQGxPVaD15QMQzGoKp3enp%`Jr+aX{S zbnh%Cw?#lPX@iN)nW=aM8^l_bQ6eU;{<6kFe~c6thA3?E9&wlt{0d>dd95XL^TFrh zzx4C#fTeHN3d|TYo(Q7Ky8OE=&Ij)%N1Px5rlr(w+@8mVhGk`MR?O}VLMIEl+dAMJ zq)a2N=UEV7E`Tu}Ni<~WP44*F$>oO&I}?p{bx=uXkb{xQ@2c_=I*VZ24S_}CAf26{ zF(Bm0kzNv1<~MJ(hxoBdjmR+#6M5HAc|YM}_~6Ek&Mx7bu75`k^ZD?sUGncVaX;>v}NT4V^@?0p|ZV(dOLsqoj%PW;z;gPf6AMC6YzB>rQAcGXBg zU5ohmy1xU>5ofmYZrjg#rh9)V|M>L@v+!@hf`*w_I6#>)KiFr6veuvXhWAl-h91xM zb$r?Oc#j89PALvIvI>^?uda@Taid*-d*?-;)y;>M$vQoOzY*FG2ZwA({{i65;_uVxLvq_Yl{$?HdN_7{|H_JdXtM&^xo z;8sO62(W^>=%*3B>?lN+Vc%sH5I~Hb{>32FWYK~#qJ)YeRzCLQWF1vUPmFCITIz+l z9`Xh4B=zMju0Ev@Q~y+cIqofs@_TlXifk3dNsAb(DB}D3%~t7k^@2Zp8b4_)s>xP7 z2r`LLiUiAm{yJUkS>UO~xZ-7aoY*^j0N{?*$p!*zX=cV*ztdAIMCbE*GjOt}RV z!Igcg3);1A4fUwqvjohP@AF^Y=QQ6R+)Zvg+R%vpUzP*c3Jd)0VntxOSlL7^@N~1P zpFljeVd0O;P{{>-nV3>D6|8Jqv536-df&mAAZE^FX*DTnz zEw`pF3$#4;vT`5U6!PTge*NM7xsV`F>+UPlPx_hW+ZeT@pUw-SIYIz{xWVpB;)Slc zi8BRXy8Q_1fnRtu9jLBNTxbrUG9^XBfbg0Y>!?VhU}neJ&krO1?25`Sk7XG12K#+I4Tj+aSUKHcfoa83Xez6hw>i69-UBJDkWc7>Re^%ChY?V8UcF+YB-~Vb<;o$-jL~*%% z3HD50zArRKOoqj??H>ZKhcgfcbk}ut9m; z)Ph=PcQovIaJwqgtgpM~aFkk1w-+XSO4`m-7-deuFfR83WlFj#YQk{b&%D28s_LLv zMb&kqjI1U?md0PFA_7W`8gv=4$$>bLO)P2@3U3XEiE~Uur+Ms&d2aEziJlyOImWIj zQ^7@F(ibqBu7&4E4Ie?MwQO#x)2K^cS#WRt?+%4S5Do~UUEqWtl*2nGR~Ys%r1Uom zz(i4r#4Is4*Tq+vrxH`nGo&bDts3CR#kk-)*viVtxAP;! zq0`dXLnZCEMFBOYjNe>ls zG=QMIKY9sjIDghPAj*Mhk!c5r@BhX_7~aJ}9LAB%b?_xGyF&vXoF2SYSye&xecluR zCr^_B&{T%|S&Y&Nhyg0n=di>ydC9sj0zR}9tnMEf&xPkw;vDKE=4!u$&sGoHl{QLB zmp<4`oXv{oK+6QIn8@vy9g7#Dp%c0h z%KMOdFOjqE_=Uqq^g&f&BT}9@I?JaVmmKPY`N#D0`D>SXYZ<&HUztz$WHGL-Pvv~F zwBWS&bB%Iw3TfUCAXFJ?6A%W-{f*EN3d*A?)ll(%LL;iq?;3^-&^ORlOyY;aHV4hx zk>OUa+1_+{P5lC4%(JjEEKS)tE)TMwRiPZ-?RDgJZ_`~4e-yo~&~Tf|_8mvI>_3$9 zUi{gkfMhEhEuIRo{SwIo!9IB)=?*|K7)CPb*Yw4n=7jSx0l54ch|~Wt`x;tTdoq z$657(EvLyyZU4=A)#uYoP&B|z;J-r!ML<@pY_h{(=A9g$*Tjd{6-f`-$=I$S zc0?EHlpoWgrJKOrOnVRFQQPs*1jqkdpU;y z;vgp3hc0ofA2KbN!cC{Y|1$;e1%NKA1rfPVf&MvcaaBald;~Ug$&ScJb=cHc&QM@m+~1jI`;R-+Z+USfV^#Dt64I~V z4yoyTF+j>;(`@_n&y60+TTb`pw|lEifuJEC6b2MnxhbcElPZ*j2O{$qyQ|S``Yy}h z0y+~8LF~IV{O(r_I#dD3zY*$3fg^npjTosfGpcH@OTrUVQ}wjkN4nNq#Yu6^OQ$@XK8Sz2g=NUcc6u%qOjOWThyy7n#1RpzcNcr zqlMl_$=5RW?PjY5-uj&U1vG*M%G41Ut0V@hkvW>6vuVUsI)di@drhI-w9R{c#ncE( zs8*3V6N-m;SE3Pa#q<520bY2iG38oR1K;U%`e)=d(*LW?L=}p}xP+%eNSg_e(m}z_WOH~_h-QLdX1G2P5Kvoa%3#maYb`cH6tuBDv z?U{V;NxN#paqT|{`nQ++9srUG6Gvdgt#uL|9mb?^g(VEPLR3v-#MRpD_yqXFc{$54H2AXvEcX^An?0M!cEDwFg6U zp2S(>8mp2>|;8aYAarhSQ|($iG|6K&qP z62rMVQ^>YjH*@KK1FuySD6?A>0doOr(ZKmGWB&x8;wj!}%b@hPGqkzex>|TYvrzj| z8YkHme)Y7Vd&ERR0mBl@WloxGpAr6*r@oTE=(CmTy)c!)^_D#=+ab(eOLcS3Nl=0= z#nedh$dyMYsN*){AS`3!^-*(QaD6#6%Gnep<6%+r^PTRmc}xD$HyTxPEZ|KUq;L^I zGn zUP6Z2ql(}stB8u2f7hd)<+ljT>u&AD(#5IPlS31SeEV+i_xubLTj)0KO39kdC@=Tk zr;N>EZJ(+{hWsoM+!)n}MD zrO&`Twq?c>4j&379lBZ$(4{N5nDrC+wjFV~A8e^*|BeR3hUg`vnllCH)MI+(!4Jv5 z8Y+}-WBTy~fA0{++or2inj_bX`6(|P;}6x)K+#1YNNU2%-ABc`ogdnI$U{k7b!+Sg&HEqHlajyQ*Q6(EQ<;OJ;-j&^`suzc1jbTkIltuXqibv7 z?u^8o?}JqT0y+SK6#{t?e3NL4bau+fq>_6oY8w0uzle0An)zLKoY$=i94&arrX16* zXM9g>;@rJQnh9K0&1yu$0QRG@lylb7`iKBrter1B<(xSxVyt6xR5Dlbx`yNC~;x zI>mSOZT|)I4I2Up!s!1^qunzqCo%{(nP?z?_9$3L(xhPnqVhQ>~;%9JpDQT8ux8I+g_t6VXx=&^$t*R`me+w%LLx$Q; zW-pf(N_=AsFD6wKa>?G=ivvvU!29ryxa;#0TrN@`t%8EjJ0kD1+V!Ahe38c=O?Xk; zN`~3-HmbQF7^B^to6~y!up;CV&!Scp+f!#WPwmu_A6(*V($aXX>kCK56|?*Dxz}jv zC6E=3`~!pqDJeoUv`nMj7%I0SKuo8KsIk}O+IG`d%u6&$XexYyE$F%WqB{&uhsWe|z?3e}B%8 z)2*Lu2^pm=ZFt>@WWpxDfXE1f;0QA@CPpqJv>SE4`YT$uKAW>Q?gY%6Ccbh0^A-B2 zn{E3SqWbmF#gBCK0 z(KG)AbPNE`rSL#n+|lSFOj1b7y_sWGo7gU@@}icaQ!KHO%X_maBlt{DP(uuP!~HLcSGEUF4kDp8aU9 z220p}J`2l)b?&b_N`yo>kePIAhP13J)Kd_y305=;Mezr$`Tw}nID}wL<%_wx7ku?VTZ2@ zz36=AO8CB4rH0FAZSASg+h$57DqDX28YNtY|DG3Tty>=J6=^602KI&A5{KngPWV-> z3UVCZE7*!pQ2NTiyl&JiEXuN&!Xa@lKyhALz&focbmTDy+iO?fXBSUWLDWKt_-v9} zsn#VDxHb{^Ug&r=EkCO?7>lEMW3a`OZ!uTFRc%l5E;~Wjo?jeyizB*Z#3uncr73w# z|00CZL&wMH6lnu|Ok-q?inom& z^OaD(k&y{mjh*TDz19S(HHB0EVqhm=0pR;CWRfMC$iKuMOtN*OuxVW(Gj7$G> zefVpVz|A*?q02pIXDiK&n;Sjf+{8h#`lbDBXrQHpE<+W|IbSh>iM&6QN5wF9fYM1O zpMcrU+!A?xKZ&P3C+bliQq|$6(Z?!}&iBfdkx13pLdz)LC8@dW#8?Qcdpp6->Dub> z@hP9bhifhoWC5@Mgh+sJa@9^romIoqq491%X`M+m-|N}L$F52xAN?Oc3$uA0D#BD@ z!+z+54>K7u(6v{MHs-h&?D@kp_^7FfWy#(3-Q^hR(|1C2Sij$g1hi-n^31RQP zd`XOd%bCohxYiLBYW0P9<&*#bP|8gD8M~-H#|M6K{VsE`tU^!T$<@N9@l$xYXsv^J ztz}B2`kQtZ$3&bM@r23)W4c6l_wh=H)felUIyMAsq!A})RhI!gv}4mToP?zUx&Cs`n8{l|yeAm?|QV7qQyF8JX^tZ6C*IN$qyYLW3d%U?i8 zSdiROZbXawLXyd~%uq0xjYRQ5RSD|FMj$S1JZc=Pqodgt z>g_AhAG{%djY;Z%e0euuRROeF4l$ZUfrc! zIhj-nvKjn|4)acrtO?*C;Q~-FIZYCK3arROOAv z;hXv+M4}$hlcMS>CYKLZD5nh;v#vqWKuFa1E-60g)H=ph2N>TY&U+E`CU1;Ea0+M zEQ8egT1tkqnr|hP3HM+E;9$X8D8Tk|hV1`!pz5(2HGHjU*Y2ErP#Q{;>>55!4lTXvdVA0w3?(c-!NQOEcX2NTuGNph@Qz=@3p#j}pzX0foT%3qpd>TR7civ0hZ4xdym1_Ar9n|SU zr4)EMnqedqbIp2cf+nygkJ34Y9;Z(!U8MEegF=;T$MtiSpXKsVtv3RJT>bL360P

Sez^YphRw)TUHhNqb{5x4;FG0)5dwf!UL&Sq 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%0Dn+3gS5%-*Hd&$*?7~#HH~cr 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�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Ð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

9icbP0KP8b|+~auDDPLFQ6b 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 diff --git a/multimedia/media/media_js_standard/videoEncoder/BUILD.gn b/multimedia/media/media_js_standard/videoEncoder/BUILD.gn deleted file mode 100644 index 73b133096..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/BUILD.gn +++ /dev/null @@ -1,32 +0,0 @@ -# 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("//test/xts/tools/build/suite.gni") - -ohos_js_hap_suite("video_encoder_js_hap") { - hap_profile = "./src/main/config.json" - js2abc = true - deps = [ - ":video_encoder_js_assets", - ":video_encoder_resources", - ] - certificate_profile = "./signature/openharmony_sx.p7b" - hap_name = "ActsVideoEncoderJsTest" -} -ohos_js_assets("video_encoder_js_assets") { - source_dir = "./src/main/js/default" -} -ohos_resources("video_encoder_resources") { - sources = [ "./src/main/resources" ] - hap_profile = "./src/main/config.json" -} diff --git a/multimedia/media/media_js_standard/videoEncoder/Test.json b/multimedia/media/media_js_standard/videoEncoder/Test.json deleted file mode 100644 index 6a3573045..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/Test.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "description": "Configuration for videoEncoder Tests", - "driver": { - "type": "JSUnitTest", - "test-timeout": "2000000", - "package": "ohos.acts.multimedia.video.videoencoder", - "shell-timeout": "60000" - }, - "kits": [ - { - "test-file-name": [ - "ActsVideoEncoderJsTest.hap" - ], - "type": "AppInstallKit", - "cleanup-apps": true - }, - { - "type": "PushKit", - "pre-push": [ - ], - "push": [ - ] - }, - { - "type": "ShellKit", - "run-command": [ - "rm -R /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results", - "mkdir -p /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/", - "chmod 777 -R /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder", - "chmod 777 /data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/*" - ], - "teardown-command":[ - ] - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/signature/openharmony_sx.p7b b/multimedia/media/media_js_standard/videoEncoder/signature/openharmony_sx.p7b deleted file mode 100644 index 9be1e98fa4c0c28ca997ed660112fa16b194f0f5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3437 zcmcgvX>b$g8MY4FF(5FQyMT=#m||qU)nQ9cId-MBB-<-lvSdq&snM}IENNF>t+bK| zgowuF2vC|SxSZxNN5eHhV%(WPpbeB9Fc3;JDMtzMBv1-XAc2N~c2_tCXW&OCGw6qQ z-s9VS-tT?h=bI0tMS+~WDXqHJyCPmLzdbE-fV8Nd&*MRZfG8(#POFZG3xs@Lb{0ry z=R8j3wWo!5g=yjKx#BoZMFS)uA)H}cTp@-^K`9VV?RC3J59@}eik*>n|pRKOLZ zxdn7G!Yv@9O#y<&eUy{)vMXb;fQR)ffVAADQsEMXm;IBMDLfLD0w^U;6%HVo-0Q_5 zCHEa?DBuauNpZzoF+tK27w#n~?u%toS-DhR4k@Q*{7x^8Q=D6&kd^_~J#VVG2LXkL zaAy=}U*?Jto)9hx5MGjdp9hcQAu@tfk_;l!PeyxPY<8b&+&D!CyaBh9=8BSVKLpk4 z4Ml3yY|&Th)vyK4cpC{!uU8v2YBlVV`d~(nz&<@{G1oe*DHub1z7~J5*;s2bX<)_* zV_GbsPQg`(&rpxRb_*Od7}++3+liSw-$!1 zs5*g}EHWhI3i|!-FcfzYL0`SL-rq>LENC;PMl)G(0(1U2%Va|smp0UFx0xd@soZA* zD5LYc4OlbE7@ARt#h}rr3>K@bf%B#^-c+xz8Hr)0D5ExIFltezN@Hn8>o5d~bSfYtkc+_Z&kI#-N5_GhCg*V-^TSO=!G~ z(fXy{n2XV+k}6w_W`dTOP2a4u0ly;ANZ>4OxSKAzFB!yBzdo`gX zO?o|H@WiAw$y6l?=^3jA_Hy0S)nTYs12;4hKE&ekQ|>?|ZLJ}#F`2BczC7kdE4@xV zZBD_)Otwjhz+NSaz?d45!;FsGSu-#qh#hStD%B}f!mCT!KqzSo>I`NGH_9Dea$1Qi zg29Ydt!~lQVR99_T7#Hije~(12drl-P)SV?QR*9sus`8th-8^OQ7@xI$(Yp|^;bL1 zR50O$mDXw6P>i7B(TJ)ciPzTE>XY%X6HAa)b#OBRXv&~%Bw|J#Y><i4=e%95bjtw|cJp=#P#Pf#*luqI_wR;fISDCJhAqSG6R%xItn%~QtZ@m%&u zjGGLX;t6Ls62eQvNmf@v+}J%54^CygxRZ`?8X#r|wkev7(s;Ou4T#y1XNNf)h;o7z z8a^Lfq<1uH`E{G9E z*(=)Css_LSk=>E9jr)s5^2-!+MN=Ds}>1hRma4`uCIz9%p3O77839E{xf z4c_I?**|1`K2tg4!Hvyrou4BsJQuv*UfF)<%CelYIS>D^o?X)3+MK%la6kooW8&G@BU)Y0hT`+mOm$Z_%rB=a%o>I z!2c6lHyKQN)VjiFwa!eE^p8jc$sy$vB+8i25lI~6KPFFh$!o$avA~rj#L6xvR|Z83 z*WD6T9e+5Pyy=F+)pNTf{ny3cy>7Rkd3o*TS?TZJ`NS^NF2%HMkyS{?uJ$`!P4_L^ z1`NFDUbNyg_qREifgktnp1_v{Jbb`7m}2PTyUdOmtJj~m z9bB=ecw4_^rw1IW=of+>nrW5=d3k`3qHCxsIN_F{T1A545};;+fsyC&qChi+YV zr~M63H8ZLCPYmsjY>ls9cL%I)F|JIW-#+48$+lD4k*(P*kDM%zx_fvu4u5ZYUnI}5 zdrycFq>xFU)&X3p@pP2u%$o}}YcRn(MhJ&B2o?KS@cIVz>Ye%o^xV?CB{_Qhu z;}_q1bvO^g{8<3!gYbo4Di{8qzV+(9 zdlmksohQmRTs@qB;(Wo?dER_ux6XQb@q$tQPW?CMu6GVQd;R=iR;-S{Kr%Zks7>b1 zNs{|-+jhObYE}NR&`TGGr^h^4bjh%c>R#@=8nM&Md>_a+zVulsl;){flFekV1t9ob z+SqfV_Pv3$2f)bQ8%Ul2>fdYR^1zs0BQF~olsOj5AodC&Q_7SMFzsz2 z9newxE&jodk~tNHwl%LBMMDbrk=(^b diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/config.json b/multimedia/media/media_js_standard/videoEncoder/src/main/config.json deleted file mode 100644 index b52e6a681..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/config.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "app": { - "apiVersion": { - "compatible": 6, - "releaseType": "Beta1", - "target": 7 - }, - "vendor": "acts", - "bundleName": "ohos.acts.multimedia.video.videoencoder", - "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.video.videoencoder.MainAbility", - "description": "$string:mainability_description", - "label": "$string:entry_MainAbility", - "type": "page", - "homeAbility": true, - "launchType": "standard" - } - ], - "deviceType": [ - "phone", - "tablet", - "tv", - "wearable" - ], - "mainAbility": "ohos.acts.multimedia.video.videoencoder.MainAbility", - "distro": { - "moduleType": "entry", - "installationFree": false, - "deliveryWithInstall": true, - "moduleName": "entry" - }, - "package": "ohos.acts.multimedia.video.videoencoder", - "name": ".MyApplication", - "js": [ - { - "pages": [ - "pages/index/index" - ], - "name": "default", - "window": { - "designWidth": 720, - "autoDesignWidth": true - } - } - ] - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/app.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/app.js deleted file mode 100644 index 830070d19..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/app.js +++ /dev/null @@ -1,23 +0,0 @@ -/* - * 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'); - } -}; diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/en-US.json b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/en-US.json deleted file mode 100644 index e63c70d97..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/en-US.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "Hello", - "world": "World" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/zh-CN.json b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/zh-CN.json deleted file mode 100644 index de6ee5748..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/i18n/zh-CN.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "strings": { - "hello": "您好", - "world": "世界" - } -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.css b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.css deleted file mode 100644 index c9195944a..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.css +++ /dev/null @@ -1,61 +0,0 @@ -/* - * 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; - } -} diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.hml b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.hml deleted file mode 100644 index 8d0e2061b..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.hml +++ /dev/null @@ -1,20 +0,0 @@ - - -

- - {{ $t('strings.hello') }} {{ title }} - -
diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.js deleted file mode 100644 index 67f8b8567..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/default/pages/index/index.js +++ /dev/null @@ -1,41 +0,0 @@ -/* - * 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 diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/List.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/List.test.js deleted file mode 100644 index 078ccff26..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/List.test.js +++ /dev/null @@ -1,22 +0,0 @@ -/* - * 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('./VideoEncoderSoftwareFuncCallbackTest.test.js') -require('./VideoEncoderSoftwareFuncPromiseTest.test.js') -require('./VideoEncoderSoftwareReliabilityCallbackTest.test.js') -require('./VideoEncoderSoftwareReliabilityPromiseTest.test.js') -require('./VideoEncoderMultiInstancesTest.test.js') -require('./VideoEncoderEnumTest.test.js') -require('./VideoHardwareEncoderEnumTest.test.js') \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderEnumTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderEnumTest.test.js deleted file mode 100644 index 504a0e0df..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderEnumTest.test.js +++ /dev/null @@ -1,52 +0,0 @@ -/* - * 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 {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('VideoEncoderEnum', function () { - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - }) - - afterEach(function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - - /* * - * @tc.number : SUB_MEDIA_VIDEO_ENCODER_ENUM_VideoEncodeBitrateMode_0100 - * @tc.name : 001.VideoEncodeBitrateMode - * @tc.desc : Test Enumerate VideoEncodeBitrateMode - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_DECODER_ENUM_VideoEncodeBitrateMode_0100', 0, async function (done) { - expect(media.VideoEncodeBitrateMode.CBR).assertEqual(0); - expect(media.VideoEncodeBitrateMode.VBR).assertEqual(1); - expect(media.VideoEncodeBitrateMode.CQ).assertEqual(2); - done(); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderMultiInstancesTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderMultiInstancesTest.test.js deleted file mode 100644 index 744177491..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderMultiInstancesTest.test.js +++ /dev/null @@ -1,320 +0,0 @@ -/* - * 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 mediademo from '@ohos.multimedia.mediademo' -import Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('videoEncoderSoftwareMultiInstances', function () { - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const ROOT = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/'; - const BASIC_PATH = ROOT + 'video_multiinstances_'; - let videoEncodeProcessor; - let mediaTest; - let surfaceID = ''; - let outputQueue = []; - let outputCnt = 0; - let frameTotal = 100; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let sawOutputEOS = false; - let needGetMediaDes = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - videoEncodeProcessor = null; - mediaTest = null; - surfaceID = ''; - outputQueue = []; - outputCnt = 0; - frameTotal = 100; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function resetParam() { - outputQueue = []; - outputCnt = 0; - frameTotal = 100; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - } - - function writeFile(path, buf, len){ - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function dequeueOutputs(path, nextStep) { - while (outputQueue.length > 0) { - let outputObject = outputQueue.shift(); - outputCnt += 1; - if (outputObject.flags == 1) { - console.info("case last frame"); - mediaTest.closeStream(surfaceID); - toRelease(); - nextStep(); - return; - } else { - console.info('not last frame, write data to file'); - writeFile(path, outputObject.data, outputObject.length); - console.info("write to file success"); - videoEncodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.info('release output success'); - }); - } - } - } - - function setCallback(path, nextStep) { - console.info('case callback'); - videoEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - console.info('outBuffer.flags: ' + outBuffer.flags); - if (needGetMediaDes) { - videoEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes = false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - dequeueOutputs(path, nextStep); - }); - - videoEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - videoEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - async function toCreateByMime(mime, done) { - await media.createVideoEncoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByMime success'); - } else { - console.info('in case : createVideoEncoderByMime fail'); - expect().assertFail(); - done(); - } - }) - } - - async function toCreateByName(name, done) { - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - } - - async function toGetVideoEncoderCaps() { - await videoEncodeProcessor.getVideoEncoderCaps().then((videoCaps) => { - console.info("case get getVideoEncoderCaps success"); - console.info("print videoCaps: " + videoCaps) - }, failCallback).catch(failCatch); - } - - function toCreateStream() { - mediaTest = mediademo.createMediaTest(); - } - - function toSetStreamParam(width, height, framerate, frameTotal) { - console.info('case set stream parameter'); - mediaTest.setResolution(width, height); - mediaTest.setFrameRate(framerate); - mediaTest.setFrameCount(frameTotal); - } - - async function toGetInputSurface() { - await videoEncodeProcessor.getInputSurface().then((inputSurface) => { - expect(inputSurface != undefined).assertTrue(); - console.info('case getInputSurface success'); - surfaceID = inputSurface; - }, failCallback).catch(failCatch); - } - - function toStartStream() { - console.info('case start stream'); - mediaTest.startStream(surfaceID); - } - - function toStopStream() { - console.info('case stop stream'); - mediaTest.closeStream(surfaceID); - } - - async function toConfigure(mediaDescription) { - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - } - - async function toPrepare() { - await videoEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - } - - async function toStart() { - await videoEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - } - - async function toFlush() { - outputQueue = []; - await videoEncodeProcessor.flush().then(() => { - console.info("case flush success"); - }, failCallback).catch(failCatch); - } - - async function toStop() { - await videoEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - } - - async function toReset() { - await videoEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - } - - async function toRelease() { - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_MULTIINSTANCE_0100 - * @tc.name : 001.create multiple encoders - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_MULTIINSTANCE_0100', 0, async function (done) { - console.info("case test multiple encoder instances"); - let savepath = BASIC_PATH + '0100.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - let array = new Array(); - - eventEmitter.once('nextStep', async () => { - for (let j = 1; j < 3; j++) { - await array[j].release().then(() => { - console.info("case release encoder " + j); - }, failCallback).catch(failCatch); - array[j] = null; - } - console.info('release encoders success'); - done(); - }); - async function runCase() { - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, function(){eventEmitter.emit('nextStep')}); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - } - for (let i = 1; i <= 3; i += 1) { - await media.createVideoEncoderByMime(mime).then((processor) => { - if (typeof(processor) != 'undefined') { - console.info("case create createVideoEncoder success: " + i); - if (i == 3) { - videoEncodeProcessor = processor; - runCase(); - } else { - array[i] = processor; - } - } else { - console.info("case create createVideoEncoder failed: " + i); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } - }) -}) - - \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncCallbackTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncCallbackTest.test.js deleted file mode 100644 index b7a67b1b6..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncCallbackTest.test.js +++ /dev/null @@ -1,562 +0,0 @@ -/* - * 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 mediademo from '@ohos.multimedia.mediademo' -import Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('VideoEncoderSoftwareFuncCallbackTest', function () { - let videoEncodeProcessor = null; - let mediaTest; - let surfaceID = ''; - let frameCountOut = 0; - let outputQueue = []; - let frameTotal = 100; - let finalFrameId = 100; - let reStart = false; - let isStreamRunning = false; - let stopBuffer = false; - const events = require('events'); - const eventEmitter = new events.EventEmitter(); - const ROOT = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/'; - const BASIC_PATH = ROOT + 'video_func_callback_'; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - mediaTest = null; - surfaceID = ''; - frameCountOut = 0; - outputQueue = []; - frameTotal = 100; - finalFrameId = 100; - reStart = false; - isStreamRunning = false; - stopBuffer = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoEncodeProcessor != null) { - await videoEncodeProcessor.release().then(() => { - console.info('case videoEncodeProcessor release'); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let failCallback = function(err) { - console.error(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.error(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - function writeFile(path, buf, len){ - try { - let writestream = Fileio.createStreamSync(path, 'ab+'); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.error('in case error writeFile: ' + e); - } - } - - async function dequeueOutputs(path, nextStep) { - while (outputQueue.length > 0) { - let outputObject = outputQueue.shift(); - if (outputObject.flags == 1 || frameCountOut == frameTotal || frameCountOut == finalFrameId) { - nextStep(); - return; - } - frameCountOut++; - writeFile(path, outputObject.data, outputObject.length); - videoEncodeProcessor.freeOutputBuffer(outputObject, (err) => { - if (typeof(err) == 'undefined') { - console.log('in case release output count:' + frameCountOut); - } else { - console.info(`in case release output called,errMessage is ${err.message}`); - } - }); - } - } - function printDescription(obj) { - for (let item in obj) { - let property = obj[item]; - console.info('video encoder key is ' + item); - console.info('video encoder value is ' + property); - } - } - function setCallback(path, nextStep) { - console.info('case callback'); - videoEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - if (stopBuffer == false) { - outputQueue.push(outBuffer); - dequeueOutputs(path, nextStep); - } - }); - - videoEncodeProcessor.on('error',(err) => { - console.info('in case error called, errName is' + err); - }); - videoEncodeProcessor.on('streamChanged',(format) => { - if (typeof(format) != undefined) { - printDescription(format); - } - }); - } - function toCreateStream() { - mediaTest = mediademo.createMediaTest(); - } - function toSetStreamParam(width, height, framerate, frameTotal) { - mediaTest.setResolution(width, height); - mediaTest.setFrameRate(framerate); - mediaTest.setFrameCount(frameTotal); - } - - function toStartStream() { - if (isStreamRunning == false) { - console.info('in case : toStartStream'); - mediaTest.startStream(surfaceID); - isStreamRunning = true; - } - } - - function toStopStream() { - if (isStreamRunning == true) { - console.info('in case : toStopStream'); - mediaTest.closeStream(surfaceID); - isStreamRunning = false; - } - } - - eventEmitter.on('configure', (mediaDescription, decPath, nextStep, done) => { - console.info('in case : configure in'); - videoEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info('in case : configure success'); - setCallback(decPath, nextStep); - eventEmitter.emit('getVideoEncoderCaps', done); - }); - }); - eventEmitter.on('getVideoEncoderCaps', (done) => { - videoEncodeProcessor.getVideoEncoderCaps((err, videoCaps) => { - expect(err).assertUndefined(); - console.info("case get getVideoEncoderCaps success"); - console.info(`print videoCaps: - codecInfo.name ${videoCaps.codecInfo.name} - codecInfo.type ${videoCaps.codecInfo.type} - codecInfo.mimeType ${videoCaps.codecInfo.mimeType} - codecInfo.isHardwareAccelerated ${videoCaps.codecInfo.isHardwareAccelerated} - codecInfo.isSoftwareOnly ${videoCaps.codecInfo.isSoftwareOnly} - codecInfo.isVendor ${videoCaps.codecInfo.isVendor} - supportedBitrate [${videoCaps.supportedBitrate.min}, ${videoCaps.supportedBitrate.max}] - supportedFormats ${videoCaps.supportedFormats} - supportedHeightAlignment ${videoCaps.supportedHeightAlignment} - supportedWidthAlignment ${videoCaps.supportedWidthAlignment} - supportedWidth [${videoCaps.supportedWidth.min}, ${videoCaps.supportedWidth.max}] - supportedHeight [${videoCaps.supportedHeight.min}, ${videoCaps.supportedHeight.max}] - supportedProfiles ${videoCaps.supportedProfiles} - supportedLevels ${videoCaps.supportedLevels} - supportedBitrateMode ${videoCaps.supportedBitrateMode} - supportedQuality [${videoCaps.supportedQuality.min}, ${videoCaps.supportedQuality.max}] - supportedComplexity [${videoCaps.supportedComplexity.min}, ${videoCaps.supportedComplexity.max}] - `); - eventEmitter.emit('getInputSurface', done); - }); - }); - eventEmitter.on('getInputSurface', (done) => { - videoEncodeProcessor.getInputSurface((err, inputSurface) => { - expect(err).assertUndefined(); - expect(inputSurface != undefined).assertTrue(); - surfaceID = inputSurface; - console.info('in case : getInputSurface success, surfaceID ' + surfaceID); - eventEmitter.emit('prepare', done); - }) - }); - eventEmitter.on('prepare', (done) => { - videoEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info('in case : prepare success'); - toStartStream(); - eventEmitter.emit('start', done); - }); - }); - eventEmitter.on('start', (done) => { - toStartStream(); - videoEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info('in case : start success'); - }); - stopBuffer = false; - }); - eventEmitter.on('stop', (done) => { - videoEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - toStopStream(); - console.info('in case : stop success'); - if (reStart == true) { - frameCountOut = 0; - outputQueue = []; - reStart = false; - eventEmitter.emit('start', done); - } else { - eventEmitter.emit('reset', done); - } - }); - stopBuffer = true; - }); - eventEmitter.on('flush', (done) => { - videoEncodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info('in case : flush success'); - eventEmitter.emit('reset', done); - }); - }); - eventEmitter.on('reset', (done) => { - videoEncodeProcessor.reset((err) => { - toStopStream(); - expect(err).assertUndefined(); - console.info('in case : reset success'); - eventEmitter.emit('release', done); - }); - }); - eventEmitter.on('release', (done) => { - videoEncodeProcessor.release((err) => { - toStopStream(); - expect(err).assertUndefined(); - console.info('in case : release success'); - videoEncodeProcessor = null; - done(); - }); - }); - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_00_0100 - * @tc.name : 000.test stop after last frame and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_00_0100', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_00_0100.es'; - let mime = 'video/mp4v-es'; - let mediaDescription = { - "codec_mime": 'video/mp4v-es', - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30, - } - media.getMediaCapability((err, mediaCaps) => { - expect(err).assertUndefined(); - console.info(`case getMediaCapability 1`); - mediaCaps.getVideoEncoderCaps((err, videoCapsArray) => { - expect(err).assertUndefined(); - console.info('getVideoDecoderCaps success'); - if (typeof (videoCapsArray) != 'undefined') { - console.info("case videoCapsArray" + videoCapsArray); - } else { - console.info("case videoCapsArray is not defined"); - expect().assertFail(); - done(); - } - }) - mediaCaps.findVideoEncoder(mediaDescription, (err, codecname) => { - expect(err).assertUndefined(); - console.info('findVideoEncoder success'); - if (typeof (codecname) != 'undefined') { - console.info("case codecname " + codecname); - } else { - console.info("case codecname is not defined"); - expect().assertFail(); - done(); - } - }) - }) - media.createVideoEncoderByMime(mime, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('stop', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0100 - * @tc.name : 000.test stop at running state and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0100', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0100.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - finalFrameId = 50; - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('stop', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0200 - * @tc.name : 000.test stop at end of stream and restart - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0200', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0200.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - reStart = true; - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('stop', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0300 - * @tc.name : 000.test stop at running state and restart - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0300', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0300.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - finalFrameId = 50; - reStart = true; - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('stop', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0400 - * @tc.name : 000.test flush at running state - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0400', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0400.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - finalFrameId = 50; - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('flush', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0500 - * @tc.name : 000.test flush at end of stream - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0500', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0500.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('flush', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0600 - * @tc.name : 000.test reconfigure - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0600', 0, async function (done) { - let decPath = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0600.es'; - let name= 'avenc_mpeg4'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - let decPath2 = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_CALLBACK_01_0600_2.es'; - let mediaDescription2 = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30.00, - } - eventEmitter.on('reset_for_callback_01_0600', (done) => { - videoEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info('in case : reset_for_callback_01_0600 success'); - toStopStream(); - surfaceID = ''; - frameCountOut = 0; - outputQueue = []; - isStreamRunning = false; - toSetStreamParam(mediaDescription2.width, mediaDescription2.height, - mediaDescription2.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription2, decPath2, - function(){eventEmitter.emit('stop', done);}, done); - }) - }) - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - console.info('case create createVideoEncoderByName success'); - videoEncodeProcessor = processor; - toCreateStream(); - toSetStreamParam(mediaDescription.width, mediaDescription.height, - mediaDescription.frame_rate, frameTotal); - eventEmitter.emit('configure', mediaDescription, decPath, - function(){eventEmitter.emit('reset_for_callback_01_0600', done);}, done); - } else { - console.info('case create createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }); - }) -}) diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncPromiseTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncPromiseTest.test.js deleted file mode 100644 index 9337df2ac..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareFuncPromiseTest.test.js +++ /dev/null @@ -1,698 +0,0 @@ -/* - * 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 mediademo from '@ohos.multimedia.mediademo' -import Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('videoSoftwareEncoderFuncPromise', function () { - const ROOT = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/'; - const BASIC_PATH = ROOT + 'video_func_promise_'; - let videoEncodeProcessor; - let mediaTest; - let surfaceID = ''; - let outputQueue = []; - let outputCnt = 0; - let frameTotal = 100; - let stopAtEOS = false; - let resetAtEOS = false; - let flushAtEOS = false; - let sawOutputEOS = false; - let needGetMediaDes = false; - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - mediaTest = null; - surfaceID = ''; - outputQueue = []; - outputCnt = 0; - frameTotal = 100; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoEncodeProcessor != null){ - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - function resetParam() { - outputQueue = []; - outputCnt = 0; - frameTotal = 100; - stopAtEOS = false; - resetAtEOS = false; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - } - - function writeFile(path, buf, len){ - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function dequeueOutputs(path, done) { - while (outputQueue.length > 0) { - let outputObject = outputQueue.shift(); - outputCnt += 1; - if (outputObject.flags == 1) { - console.info("last frame, make choice"); - mediaTest.closeStream(surfaceID); - sawOutputEOS = true; - if (stopAtEOS) { - await toStop(); - } else if (resetAtEOS) { - await toReset(); - } else if (flushAtEOS) { - await toFlush(); - } else { - await toReset(); - await toRelease(); - done(); - } - } else { - console.info('not last frame, write data to file'); - writeFile(path, outputObject.data, outputObject.length); - console.info("write to file success"); - videoEncodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.info('release output success'); - }); - } - } - } - - function setCallback(path, done) { - console.info('case callback'); - videoEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - console.info('outBuffer.flags: ' + outBuffer.flags); - if (needGetMediaDes) { - videoEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes = false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - dequeueOutputs(path, done); - }); - - videoEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - videoEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - async function toCreateByMime(mime, done) { - await media.createVideoEncoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByMime success'); - } else { - console.info('in case : createVideoEncoderByMime fail'); - expect().assertFail(); - done(); - } - }) - } - - async function toCreateByName(name, done) { - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - } - - async function toGetVideoEncoderCaps(width, height) { - await videoEncodeProcessor.getVideoEncoderCaps().then((videoCaps) => { - console.info("case get getVideoEncoderCaps success"); - printVideoCaps(videoCaps, width, height); - }, failCallback).catch(failCatch); - } - - async function printVideoCaps(videoCaps, width, height) { - console.info(`print videoCaps: - codecInfo.name ${videoCaps.codecInfo.name} - codecInfo.type ${videoCaps.codecInfo.type} - codecInfo.mimeType ${videoCaps.codecInfo.mimeType} - codecInfo.isHardwareAccelerated ${videoCaps.codecInfo.isHardwareAccelerated} - codecInfo.isSoftwareOnly ${videoCaps.codecInfo.isSoftwareOnly} - codecInfo.isVendor ${videoCaps.codecInfo.isVendor} - supportedBitrate [${videoCaps.supportedBitrate.min}, ${videoCaps.supportedBitrate.max}] - supportedFormats ${videoCaps.supportedFormats} - supportedHeightAlignment ${videoCaps.supportedHeightAlignment} - supportedWidthAlignment ${videoCaps.supportedWidthAlignment} - supportedWidth [${videoCaps.supportedWidth.min}, ${videoCaps.supportedWidth.max}] - supportedHeight [${videoCaps.supportedHeight.min}, ${videoCaps.supportedHeight.max}] - supportedProfiles ${videoCaps.supportedProfiles} - supportedLevels ${videoCaps.supportedLevels} - supportedBitrateMode ${videoCaps.supportedBitrateMode} - supportedQuality [${videoCaps.supportedQuality.min}, ${videoCaps.supportedQuality.max}] - supportedComplexity [${videoCaps.supportedComplexity.min}, ${videoCaps.supportedComplexity.max}] - `); - await videoCaps.getPreferredFrameRate(width, height).then((valueRange) => { - console.info("case getPreferredFrameRate valueRange success"); - if (typeof (valueRange) != 'undefined') { - console.info('getPreferredFrameRate.min: ' + valueRange.min); - console.info('getPreferredFrameRate.max: ' + valueRange.max); - } else { - console.info('case getPreferredFrameRate valueRange is not defined'); - expect().assertFail(); - } - }, failCallback).catch(failCatch); - await videoCaps.getSupportedFrameRate(width, height).then((valueRange) => { - console.info("case getSupportedFrameRate valueRange success"); - if (typeof (valueRange) != 'undefined') { - console.info('getSupportedFrameRate.min: ' + valueRange.min); - console.info('getSupportedFrameRate.max: ' + valueRange.max); - } else { - console.info('case getSupportedFrameRate valueRange is not defined'); - expect().assertFail(); - } - }, failCallback).catch(failCatch); - await videoCaps.isSizeSupported(width, height).then((trueORfalse) => { - console.info("case isSizeSupported valueRange for width:" + width + ", height: " + height); - if (typeof (trueORfalse) != 'undefined') { - console.info('videoCaps.isSizeSupported: ' + trueORfalse); - } else { - console.info('case isSizeSupported is not defined'); - expect().assertFail(); - } - }, failCallback).catch(failCatch); - } - - function toCreateStream() { - mediaTest = mediademo.createMediaTest(); - } - - function toSetStreamParam(width, height, framerate, frameTotal) { - console.info('case set stream parameter'); - mediaTest.setResolution(width, height); - mediaTest.setFrameRate(framerate); - mediaTest.setFrameCount(frameTotal); - } - - async function toGetInputSurface() { - await videoEncodeProcessor.getInputSurface().then((inputSurface) => { - expect(inputSurface != undefined).assertTrue(); - console.info('case getInputSurface success'); - surfaceID = inputSurface; - }, failCallback).catch(failCatch); - } - - function toStartStream() { - console.info('case start stream'); - mediaTest.startStream(surfaceID); - } - - function toStopStream() { - console.info('case stop stream'); - mediaTest.closeStream(surfaceID); - } - - async function toConfigure(mediaDescription) { - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - } - - async function toPrepare() { - await videoEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - } - - async function toStart() { - await videoEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - } - - async function toFlush() { - outputQueue = []; - await videoEncodeProcessor.flush().then(() => { - console.info("case flush success"); - }, failCallback).catch(failCatch); - } - - async function toStop() { - await videoEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - } - - async function toReset() { - resetParam(); - await videoEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - } - - async function toRelease() { - resetParam(); - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - videoEncodeProcessor = null; - }, failCallback).catch(failCatch); - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_00_0100 - * @tc.name : 000.test stop after last frame and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_00_0100', 0, async function (done) { - console.info("case test stop after last frame"); - let savepath = BASIC_PATH + '0000.es'; - let name= 'avenc_mpeg4'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "codec_mime": 'video/mp4v-es', - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - await media.getMediaCapability().then((mediaCaps) => { - console.info('getMediaCapability success'); - if (typeof (mediaCaps) != 'undefined') { - mediaCaps.getVideoEncoderCaps().then((videoCapsArray) => { - console.info('getVideoEncoderCaps from media success'); - if (typeof (videoCapsArray) != 'undefined') { - let videoCaps = videoCapsArray[0]; - console.info('print first videoCaps from videoCapsArray'); - printVideoCaps(videoCaps, width, height); - } else { - console.info("case videoCapsArray is not defined"); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - mediaCaps.findVideoEncoder(mediaDescription).then((codecname) => { - console.info('findVideoEncoder success'); - if (typeof (codecname) != 'undefined') { - console.info("case codecname " + codecname); - } else { - console.info("case codecname is not defined"); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - } else { - console.info('mediaCaps is not defined'); - expect().assertFail(); - done(); - } - }, failCallback).catch(failCatch); - await toCreateByName(name, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0100 - * @tc.name : 001.test stop at runnning state and reset - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0100', 0, async function (done) { - console.info("case test stop at runnning state and reset"); - let savepath = BASIC_PATH + '0100.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(1000); - await toStop(); - toStopStream(); - await toReset(); - await toRelease(); - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0200 - * @tc.name : 002.test stop at end of stream and restart - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0200', 0, async function (done) { - console.info("test stop at end of stream and restart"); - let savepath = BASIC_PATH + '0200.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - frameTotal = 10; - stopAtEOS = true; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(5000); - resetParam(); - toSetStreamParam(width, height, framerate, frameTotal); - await toStart(); - toStartStream(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0300 - * @tc.name : 003.test stop at running state and restart - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0300', 0, async function (done) { - console.info("test stop at runnning state and restart"); - let savepath = BASIC_PATH + '0300.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - frameTotal = 1000; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(500); - toStopStream(); - await toStop(); - resetParam(); - toSetStreamParam(width, height, framerate, frameTotal); - await toStart(); - toStartStream(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0400 - * @tc.name : 004.test flush at running state - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0400', 0, async function (done) { - console.info("case test flush at running state"); - let savepath = BASIC_PATH + '0400.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - frameTotal = 500; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(500); - await toFlush(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0500 - * @tc.name : 005.test flush at end of stream - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level1 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0500', 0, async function (done) { - console.info("case test flush at end of stream"); - let savepath = BASIC_PATH + '0500.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - flushAtEOS = true; - frameTotal = 10; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(5000); - resetParam(); - toSetStreamParam(width, height, framerate, frameTotal); - toStartStream(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0600 - * @tc.name : 006.test reconfigure - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0600', 0, async function (done) { - console.info("case test reconfigure"); - let savepath = BASIC_PATH + '0600.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - resetAtEOS = true; - frameTotal = 10; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(5000); - resetParam(); - width = 320; - height = 240; - framerate = 30; - let mediaDescription2 = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - let savepath2 = BASIC_PATH + '0601.es'; - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription2); - setCallback(savepath2, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0700 - * @tc.name : 007.test recreate videoencoder - * @tc.desc : basic encode function - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_FUNCTION_PROMISE_01_0700', 0, async function (done) { - console.info("case test recreate videoencoder"); - let savepath = BASIC_PATH + '0700.es'; - let mime = 'video/mp4v-es'; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - resetAtEOS = true; - frameTotal = 10; - await toCreateByMime(mime, done); - await toGetVideoEncoderCaps(width, height); - toCreateStream(); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription); - setCallback(savepath, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - await sleep(5000); - await toRelease(); - resetParam(); - width = 320; - height = 240; - framerate = 30; - let mediaDescription2 = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - let savepath2 = BASIC_PATH + '0701.es'; - await toCreateByMime(mime, done); - toSetStreamParam(width, height, framerate, frameTotal); - await toConfigure(mediaDescription2); - setCallback(savepath2, done); - await toGetInputSurface(); - await toPrepare(); - toStartStream(); - await toStart(); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityCallbackTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityCallbackTest.test.js deleted file mode 100644 index 8921b8da9..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityCallbackTest.test.js +++ /dev/null @@ -1,1551 +0,0 @@ -/* - * 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 mediademo from '@ohos.multimedia.mediademo' -import Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' -export -const ENCODE_STEP = { - WAIT_FOR_EOS : 'encode:waitForEOS', - CONFIGURE : 'encode:configure', - GET_INPUTSURFACE : 'encode:getSurface', - PREPARE : 'encode:prepare', - START : 'encode:start', - FLUSH : 'encode:flush', - STOP : 'encode:stop', - RESET : 'encode:reset', - WAIT_FOR_ALL_OUTS : 'encode:waitForAllOuts', - ERROR : 'encode:error', - RELEASE : 'encode:release', -} -const STREAM_STEP = { - CREATE : 'stream:create', - PREPARE : 'stream:prepare', - SET_PARAM: 'stream:setParam', - SET_EOS_FRAME: 'stream:setEOSFrame', - START : 'stream:start', - STOP : 'stream:stop', -} -describe('VideoEncoderSoftwareReliCallbackTest', function () { - let videoEncodeProcessor = null; - let mediaTest = null; - let surfaceID = ''; - let frameCountOut = 0; - let outputQueue = []; - let frameTotal = 100; - let finalFrameId = 100; - let isStreamRunning = false; - let workdoneAtEOS = false; - let stopBuffer = false; - const ROOT = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/'; - const BASIC_PATH = ROOT + 'video_reliability_callback_'; - let mediaDescription = { - 'width': 320, - 'height': 240, - 'pixel_format': 3, - 'frame_rate': 30, - } - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - mediaTest = null; - surfaceID = ''; - frameCountOut = 0; - outputQueue = []; - workdoneAtEOS = false; - frameTotal = 100; - finalFrameId = 100; - isStreamRunning = false; - stopBuffer = false; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoEncodeProcessor != null) { - await videoEncodeProcessor.release().then(() => { - console.info('in case : videoEncodeProcessor release success'); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - toStopStream(); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - let failCallback = function(err) { - console.error(`in case error failCallback called, errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - let failCatch = function(err) { - console.error(`in case error failCatch called,errMessage is ${err.message}`); - expect(err == undefined).assertTrue(); - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - function printError(err, expectFail) { - expect((err != undefined) == expectFail).assertTrue(); - if (expectFail == false && err != undefined) { - console.error('in case error failCatch called,err is ' + err); - console.error(`in case error failCatch called,errMessage is ${err.message}`); - } - } - - function writeFile(path, buf, len){ - try { - let writestream = Fileio.createStreamSync(path, 'ab+'); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.error('in case error writeFile: ' + e); - } - } - - /* get outputbuffers from codec */ - async function dequeueOutputs(path, nextStep) { - console.log('outputQueue.length:' + outputQueue.length); - while (outputQueue.length > 0){ - let outputObject = outputQueue.shift(); - if (outputObject.flags == 1 || frameCountOut == frameTotal) { - if (workdoneAtEOS) { - doneWork(nextStep); - } - return; - } - frameCountOut++; - writeFile(path, outputObject.data, outputObject.length); - videoEncodeProcessor.freeOutputBuffer(outputObject, (err) => { - if (typeof(err) == 'undefined') { - console.debug('in case release output count:' + frameCountOut); - } else { - console.info(`in case release output called,errMessage is ${err.message}`); - } - }) - } - } - function printDescription(obj) { - for (let item in obj) { - let property = obj[item]; - console.info('video encoder key is ' + item); - console.info('video encoder value is ' + property); - } - } - function setCallback(path, nextStep) { - videoEncodeProcessor.on('newOutputData', async (outBuffer) => { - console.info('in case: outputBufferAvailable outBuffer.index: '+ outBuffer.index); - if (stopBuffer == false) { - outputQueue.push(outBuffer); - dequeueOutputs(path, nextStep); - } - }); - - videoEncodeProcessor.on('error',(err) => { - console.info('in case: error called,errName is' + err); - }); - - videoEncodeProcessor.on('streamChanged', (format) => { - if (typeof(format) != undefined) { - printDescription(format); - } - }); - } - function toCreateStream(mySteps, done) { - mediaTest = mediademo.createMediaTest(); - toNextStep(mySteps, done); - } - function toSetStreamParam(mySteps, done) { - mediaTest.setResolution(mediaDescription.width, mediaDescription.height); - mediaTest.setFrameRate(mediaDescription.frame_rate); - toNextStep(mySteps, done); - } - function toSetEOSFrame(mySteps, done) { - mediaTest.setFrameCount(frameTotal); - toNextStep(mySteps, done); - } - function toStartStream(mySteps, done) { - if (isStreamRunning == false) { - console.info('in case : toStartStream'); - mediaTest.startStream(surfaceID); - isStreamRunning = true; - } - toNextStep(mySteps, done); - } - - function toStopStream(mySteps, done) { - if (isStreamRunning == true) { - console.info('in case : toStopStream'); - mediaTest.closeStream(surfaceID); - isStreamRunning = false; - } - toNextStep(mySteps, done); - } - function toConfigure(mySteps, done, expectFail) { - videoEncodeProcessor.configure(mediaDescription, (err) => { - console.info(`case configure callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }) - } - function toGetInputSurface(mySteps, done, expectFail) { - videoEncodeProcessor.getInputSurface((err, inputSurface) => { - expect(err).assertUndefined(); - expect(inputSurface != undefined).assertTrue(); - printError(err, expectFail); - surfaceID = inputSurface; - console.info('in case : getInputSurface success, surfaceID ' + surfaceID); - toNextStep(mySteps, done); - }) - } - function toPrepare(mySteps, done, expectFail) { - videoEncodeProcessor.prepare((err) => { - console.info(`case prepare callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toStart(mySteps, done, expectFail) { - videoEncodeProcessor.start((err) => { - console.info(`case start callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - stopBuffer = false; - } - function toStop(mySteps, done, expectFail) { - videoEncodeProcessor.stop((err) => { - console.info(`case stop callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - stopBuffer = true; - } - function toFlush(mySteps, done, expectFail) { - videoEncodeProcessor.flush((err) => { - console.info(`case flush callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function toReset(mySteps, done, expectFail) { - videoEncodeProcessor.reset((err) => { - console.info(`case reset callback`); - printError(err, expectFail); - toNextStep(mySteps, done); - }); - } - function runCase(mySteps, nextCase, done) { - if (mySteps[0] == ENCODE_STEP.ERROR) { - mySteps.shift(); - nextCase(mySteps, done, true); - } else { - nextCase(mySteps, done, false); - } - } - function toNextStep(mySteps, done) { - console.info('case myStep[0]: ' + mySteps[0]); - if (mySteps[0] == ENCODE_STEP.RELEASE) { - if (videoEncodeProcessor != null){ - videoEncodeProcessor.release((err) => { - printError(err, false); - console.info('in case : videoEncodeProcessor release callback'); - videoEncodeProcessor = null; - console.info('case to done'); - done(); - }); - } - return; - } - switch (mySteps[0]) { - case ENCODE_STEP.CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - runCase(mySteps, toConfigure, done); - break; - case STREAM_STEP.CREATE: - mySteps.shift(); - console.info(`case to createStream`); - toCreateStream(mySteps, done); - break; - case STREAM_STEP.SET_PARAM: - mySteps.shift(); - console.info(`case to SetStreamParam`); - toSetStreamParam(mySteps, done); - break; - case STREAM_STEP.SET_EOS_FRAME: - mySteps.shift(); - console.info(`case to SetEOSFrame`); - toSetEOSFrame(mySteps, done); - break; - case STREAM_STEP.START: - mySteps.shift(); - console.info(`case to StartStream`); - toStartStream(mySteps, done); - break; - case STREAM_STEP.STOP: - mySteps.shift(); - console.info(`case to StoptStream`); - toStopStream(mySteps, done); - break; - case ENCODE_STEP.GET_INPUTSURFACE: - mySteps.shift(); - console.info(`case to setOutputSurface`); - runCase(mySteps, toGetInputSurface, done); - break; - case ENCODE_STEP.PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - runCase(mySteps, toPrepare, done); - break; - case ENCODE_STEP.START: - mySteps.shift(); - console.info(`case to start`); - runCase(mySteps, toStart, done); - break; - case ENCODE_STEP.FLUSH: - mySteps.shift(); - console.info(`case to flush`); - runCase(mySteps, toFlush, done); - break; - case ENCODE_STEP.STOP: - mySteps.shift(); - console.info(`case to stop`); - runCase(mySteps, toStop, done); - break; - case ENCODE_STEP.RESET: - mySteps.shift(); - console.info(`case to reset`); - runCase(mySteps, toReset, done); - break; - case ENCODE_STEP.WAIT_FOR_EOS: - mySteps.shift(); - setTimeout(() =>{ - toNextStep(mySteps, done); - }, 5000); // wait 5000 ms for eos - break; - case ENCODE_STEP.WAIT_FOR_ALL_OUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - default: - break; - } - } - - function toCreateVideoEncoderByMime(mime, path, mySteps, done) { - media.createVideoEncoderByMime(mime, (err, processor) => { - console.info(`case createVideoEncoderByMime callback`); - printError(err, false); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - setCallback(path, done); - toNextStep(mySteps, done); - } else { - done(); - } - }) - } - function toCreateVideoEncoderByName(name, path, mySteps, done) { - media.createVideoEncoderByName(name, (err, processor) => { - printError(err, false); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - setCallback(path, done); - toNextStep(mySteps, done); - } else { - done(); - } - }) - } - async function doneWork(nextStep) { - videoEncodeProcessor.stop((err) => { - printError(err, false); - console.info('case stop callback'); - mediaTest.closeStream(surfaceID); - videoEncodeProcessor.reset((err) => { - printError(err, false); - console.info('case reset callback'); - videoEncodeProcessor.release((err) => { - printError(err, false); - console.info('case release callback'); - videoEncodeProcessor = null; - nextStep(); - }) - }) - }) - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0100 - * @tc.name : 001.create -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.CONFIGURE, ENCODE_STEP.ERROR, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0300 - * @tc.name : 003.start -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.CONFIGURE, ENCODE_STEP.ERROR, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.CONFIGURE, ENCODE_STEP.ERROR, STREAM_STEP.STOP, - ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.CONFIGURE, ENCODE_STEP.ERROR, STREAM_STEP.STOP, - ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.CONFIGURE, ENCODE_STEP.ERROR, - STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.CONFIGURE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.CONFIGURE, - ENCODE_STEP.ERROR, ENCODE_STEP.PREPARE, ENCODE_STEP.START, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability test - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0900', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_CALLBACK_0900.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.CONFIGURE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.PREPARE, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.PREPARE, ENCODE_STEP.ERROR, ENCODE_STEP.START, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.PREPARE, ENCODE_STEP.ERROR, - ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.PREPARE, - ENCODE_STEP.ERROR, ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.PREPARE, - ENCODE_STEP.ERROR, ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.PREPARE, - ENCODE_STEP.ERROR, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.PREPARE, - ENCODE_STEP.ERROR, ENCODE_STEP.RESET, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0100 - * @tc.name : 001.create -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.START, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0200 - * @tc.name : 002.configure -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.START, - ENCODE_STEP.ERROR, STREAM_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0400 - * @tc.name : 004.start -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.START, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0500 - * @tc.name : 005.flush -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, ENCODE_STEP.PREPARE, - ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.START, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0600 - * @tc.name : 006.stop -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.START, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.START, - ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0800 - * @tc.name : 008.reset -> start - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.START, - ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0100 - * @tc.name : 001.create -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.FLUSH, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, - STREAM_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.FLUSH, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0400 - * @tc.name : 004.start -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.FLUSH, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP , ENCODE_STEP.FLUSH, - ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.FLUSH, - ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.FLUSH, - ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0100 - * @tc.name : 001.create -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.STOP, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, STREAM_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.STOP, ENCODE_STEP.ERROR, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0400 - * @tc.name : 004.start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.STOP, - ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.STOP, ENCODE_STEP.ERROR, - ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.STOP, - ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.STOP, ENCODE_STEP.ERROR, - ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0100 - * @tc.name : 001.create -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, - STREAM_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0400 - * @tc.name : 004.start -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.FLUSH, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0600', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0600.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0700', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0700.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0800', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_CALLBACK_0800.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.RESET, ENCODE_STEP.RESET, ENCODE_STEP.RELEASE); - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0100', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0100.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.FLUSH, - ENCODE_STEP.STOP, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0200', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0200.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.FLUSH, - ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0300', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0300.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.RESET, - ENCODE_STEP.CONFIGURE, STREAM_STEP.STOP, STREAM_STEP.SET_PARAM, STREAM_STEP.SET_EOS_FRAME, - STREAM_STEP.START, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0400', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0400.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.STOP, - ENCODE_STEP.START, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : test for state transition - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0500', 0, async function (done) { - let path = BASIC_PATH + 'SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_CALLBACK_0500.es'; - let mySteps = new Array(ENCODE_STEP.CONFIGURE, STREAM_STEP.CREATE, STREAM_STEP.SET_PARAM, - STREAM_STEP.SET_EOS_FRAME, ENCODE_STEP.GET_INPUTSURFACE, STREAM_STEP.START, - ENCODE_STEP.PREPARE, ENCODE_STEP.START, ENCODE_STEP.WAIT_FOR_EOS, ENCODE_STEP.STOP, - ENCODE_STEP.START, ENCODE_STEP.STOP, ENCODE_STEP.RELEASE); - frameTotal = 50; - toCreateVideoEncoderByName('avenc_mpeg4', path, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE-RESET_CALLBACK_0100 - * @tc.name : 001. configure -> reset for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE-RESET_CALLBACK_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let loopCnt = 0; - eventEmitter.on('configure', (mediaDescription) => { - videoEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - eventEmitter.emit('reset'); - }) - }); - eventEmitter.on('reset', () => { - videoEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info(`case reset 1`); - loopCnt += 1; - if (loopCnt < 50) { - console.info('case configure-reset current loop: ' + loopCnt); - eventEmitter.emit('configure', mediaDescription); - } else { - videoEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info('case release callback'); - videoEncodeProcessor = null; - done(); - }) - } - }) - }); - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START-STOP_CALLBACK_0100 - * @tc.name : 001. start -> stop for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START-STOP_CALLBACK_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let loopCnt = 0; - eventEmitter.on('configure', (mediaDescription) => { - videoEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - eventEmitter.emit('getInputSurface'); - }) - }); - eventEmitter.on('getInputSurface', () => { - videoEncodeProcessor.getInputSurface((err, inputSurface) => { - expect(err).assertUndefined(); - expect(inputSurface != undefined).assertTrue(); - surfaceID = inputSurface; - console.info('in case : getInputSurface success, surfaceID ' + surfaceID); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - videoEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info('in case : prepare success'); - eventEmitter.emit('start'); - }); - }); - eventEmitter.on('start', () => { - videoEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info('in case : start success'); - eventEmitter.emit('stop'); - }); - }); - eventEmitter.on('stop', () => { - videoEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info(`case stop 1`); - loopCnt += 1; - if (loopCnt < 50) { - console.info('case start-stop current loop: ' + loopCnt); - eventEmitter.emit('start'); - } else { - videoEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info('case release callback'); - videoEncodeProcessor = null; - done(); - }) - } - }) - }); - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CREATE-RELEASE_CALLBACK_0100 - * @tc.name : 001. create -> release for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CREATE-RELEASE_CALLBACK_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let loopCnt = 0; - eventEmitter.on('create', (name) => { - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - eventEmitter.emit('release'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - }) - eventEmitter.on('release', () => { - videoEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info(`case release 1`); - videoEncodeProcessor = null; - loopCnt += 1; - if (loopCnt < 50) { - console.info('case create-release current loop: ' + loopCnt); - eventEmitter.emit('create', name); - } else { - done(); - } - }) - }) - eventEmitter.emit('create', name); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_TOTALLOOP_CALLBACK_0100 - * @tc.name : 001. total loop for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_TOTALLOOP_CALLBACK_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - let events = require('events'); - let eventEmitter = new events.EventEmitter(); - let loopCnt = 0; - eventEmitter.on('create', (name) => { - media.createVideoEncoderByName(name, (err, processor) => { - expect(err).assertUndefined(); - if (typeof(processor) != 'undefined') { - videoEncodeProcessor = processor; - eventEmitter.emit('configure', mediaDescription); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - }) - eventEmitter.on('configure', (mediaDescription) => { - videoEncodeProcessor.configure(mediaDescription, (err) => { - expect(err).assertUndefined(); - console.info(`case configure 1`); - eventEmitter.emit('getInputSurface'); - }) - }); - eventEmitter.on('getInputSurface', () => { - videoEncodeProcessor.getInputSurface((err, inputSurface) => { - expect(err).assertUndefined(); - expect(inputSurface != undefined).assertTrue(); - surfaceID = inputSurface; - console.info('in case : getInputSurface success, surfaceID ' + surfaceID); - eventEmitter.emit('prepare'); - }) - }); - eventEmitter.on('prepare', () => { - videoEncodeProcessor.prepare((err) => { - expect(err).assertUndefined(); - console.info('in case : prepare success'); - eventEmitter.emit('start'); - }); - }); - eventEmitter.on('start', () => { - videoEncodeProcessor.start((err) => { - expect(err).assertUndefined(); - console.info('in case : start success'); - eventEmitter.emit('flush'); - }); - }); - eventEmitter.on('flush', () => { - videoEncodeProcessor.flush((err) => { - expect(err).assertUndefined(); - console.info('in case : flush success'); - eventEmitter.emit('stop'); - }); - }); - eventEmitter.on('stop', () => { - videoEncodeProcessor.stop((err) => { - expect(err).assertUndefined(); - console.info('in case : stop success'); - eventEmitter.emit('reset'); - }); - }); - eventEmitter.on('reset', () => { - videoEncodeProcessor.reset((err) => { - expect(err).assertUndefined(); - console.info('in case : reset success'); - eventEmitter.emit('release'); - }); - }); - eventEmitter.on('release', () => { - videoEncodeProcessor.release((err) => { - expect(err).assertUndefined(); - console.info(`case release 1`); - videoEncodeProcessor = null; - loopCnt += 1; - if (loopCnt < 50) { - console.info('case create-release current loop: ' + loopCnt); - eventEmitter.emit('create', name); - } else { - done(); - } - }) - }) - eventEmitter.emit('create', name); - }) -}) - diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityPromiseTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityPromiseTest.test.js deleted file mode 100644 index 00555114c..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoEncoderSoftwareReliabilityPromiseTest.test.js +++ /dev/null @@ -1,1524 +0,0 @@ -/* - * 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 mediademo from '@ohos.multimedia.mediademo' -import Fileio from '@ohos.fileio' -import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('videoEncoderReliabilityPromise', function () { - const ROOT = '/data/accounts/account_0/appdata/ohos.acts.multimedia.video.videoencoder/results/'; - const BASIC_PATH = ROOT + 'video_reliability_promise_'; - let videoEncodeProcessor; - let mediaTest = mediademo.createMediaTest(); - let surfaceID = ''; - let outputQueue = []; - let outputCnt = 0; - let frameTotal = 100; - let frameCountOut = 0; - let flushAtEOS = false; - let sawOutputEOS = false; - let needGetMediaDes = false; - let workdoneAtEOS = false; - const END = 0; - const CONFIGURE = 1; - const GETSURFACE = 2; - const SETSTREAMPARAM = 3; - const PREPARE = 4; - const STARTSTREAM = 5; - const STOPSTREAM = 6; - const START = 7; - const FLUSH = 8; - const STOP = 9; - const RESET = 10; - const RELEASE = 11; - const HOLDON = 12; - const ERROR = 13; - const WAITFORALLOUTS = 14; - const JUDGE_EOS = 15; - const WAITTIME = 3000; - let width = 320; - let height = 240; - let framerate = 30; - let mediaDescription = { - "width": width, - "height": height, - "pixel_format": 3, - "frame_rate" : framerate, - } - let mime = 'video/mp4v-es'; - - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(async function() { - console.info('beforeEach case'); - await msleep(1000).then(() => { - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - surfaceID = ''; - outputQueue = []; - outputCnt = 0; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - workdoneAtEOS = false; - width = 320; - height = 240; - framerate = 30; - frameTotal = 100; - }) - - afterEach(async function() { - console.info('afterEach case'); - if (videoEncodeProcessor != null) { - await videoEncodeProcessor.release().then(() => { - console.info(`case release 1`); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - let failCallback = function(err) { - console.info('case callback err : ' + err); - expect(err).assertUndefined(); - } - - let failCallbackTrue = function(err, mySteps, done) { - console.info('case callback err : ' + err); - expect(err != undefined).assertTrue(); - nextStep(mySteps, done); - } - - let failCatch = function(err) { - console.info('case catch err : ' + err); - expect(err).assertUndefined(); - } - - function msleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); - } - - function resetParam() { - outputQueue = []; - outputCnt = 0; - frameTotal = 100; - flushAtEOS = false; - sawOutputEOS = false; - needGetMediaDes = false; - workdoneAtEOS = false; - } - - function writeFile(path, buf, len){ - try{ - let writestream = Fileio.createStreamSync(path, "ab+"); - let num = writestream.writeSync(buf, {length:len}); - writestream.flushSync(); - writestream.closeSync(); - } catch(e) { - console.info(e) - } - } - - function sleep(time) { - return new Promise((resolve) => setTimeout(resolve, time)); - } - - function wait(time) { - for(let t = Date.now(); Date.now() - t <= time;); - } - - async function nextStep(mySteps, done) { - console.info("case myStep[0]: " + mySteps[0]); - if (mySteps[0] == END) { - done(); - } - switch (mySteps[0]) { - case CONFIGURE: - mySteps.shift(); - console.info(`case to configure`); - await toConfigure(mySteps, done); - break; - case GETSURFACE: - mySteps.shift(); - console.info(`case to getInputSurface`); - await toGetInputSurface(); - nextStep(mySteps, done); - break; - case SETSTREAMPARAM: - mySteps.shift(); - toSetStreamParam(); - nextStep(mySteps, done); - break; - case PREPARE: - mySteps.shift(); - console.info(`case to prepare`); - await toPrepare(mySteps, done); - break; - case STARTSTREAM: - mySteps.shift(); - console.info(`case to start stream`); - toStartStream(); - nextStep(mySteps, done); - break; - case STOPSTREAM: - mySteps.shift(); - console.info(`case to stop stream`); - mediaTest.closeStream(surfaceID); - nextStep(mySteps, done); - break; - case START: - mySteps.shift(); - console.info(`case to start`); - await toStart(mySteps, done); - break; - case FLUSH: - mySteps.shift(); - console.info(`case to flush`); - await toFlush(mySteps, done); - break; - case STOP: - mySteps.shift(); - console.info(`case to stop`); - await toStop(mySteps, done); - break; - case RESET: - mySteps.shift(); - console.info(`case to reset`); - await toReset(); - nextStep(mySteps, done); - break; - case RELEASE: - mySteps.shift(); - console.info(`case to release`); - await toRelease(mySteps, done); - break; - case HOLDON: - mySteps.shift(); - setTimeout(() => { - nextStep(mySteps, done); - }, WAITTIME); - break; - case WAITFORALLOUTS: - mySteps.shift(); - console.info(`case wait for all outputs`); - break; - case JUDGE_EOS: - mySteps.shift(); - console.info(`case judge EOS state`); - expect(sawOutputEOS).assertTrue(); - nextStep(mySteps, done); - break; - default: - break; - } - } - async function dequeueOutputs(path, done) { - while (outputQueue.length > 0) { - let outputObject = outputQueue.shift(); - outputCnt += 1; - if (outputObject.flags == 1) { - console.info("saw output EOS"); - sawOutputEOS = true; - if (workdoneAtEOS) { - mediaTest.closeStream(surfaceID); - await toReset(); - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - done(); - } else { - console.info("sawOutputEOS = true;"); - } - } else { - writeFile(path, outputObject.data, outputObject.length); - console.info("write to file success"); - videoEncodeProcessor.freeOutputBuffer(outputObject).then(() => { - console.info('release output success'); - frameCountOut++; - console.log('release output count:' + frameCountOut); - }) - } - } - } - - function setCallback(path, done) { - console.info('case callback'); - videoEncodeProcessor.on('newOutputData', async(outBuffer) => { - console.info('outputBufferAvailable'); - console.info('outBuffer.flags :' + outBuffer.flags); - if (needGetMediaDes) { - videoEncodeProcessor.getOutputMediaDescription().then((MediaDescription) => { - console.info("get OutputMediaDescription success"); - console.info('get outputMediaDescription : ' + MediaDescription); - needGetMediaDes = false; - }, failCallback).catch(failCatch); - } - outputQueue.push(outBuffer); - await dequeueOutputs(path, done); - }); - - videoEncodeProcessor.on('error',(err) => { - console.info('case error called,errName is' + err); - }); - videoEncodeProcessor.on('streamChanged',(format) => { - console.info('Output format changed: ' + format); - }); - } - - async function createVideoEncoder(savepath, mySteps, done) { - await media.createVideoEncoderByMime(mime).then((processor) => { - console.info(`case createVideoEncoder 1`); - videoEncodeProcessor = processor; - setCallback(savepath, done); - console.info("case start api test"); - nextStep(mySteps, done); - }, failCallback).catch(failCatch); - } - - async function toCreateByMime(mime, done) { - await media.createVideoEncoderByMime(mime).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByMime success'); - } else { - console.info('in case : createVideoEncoderByMime fail'); - expect().assertFail(); - done(); - } - }) - } - - function toSetStreamParam() { - mediaTest.setResolution(width, height); - mediaTest.setFrameRate(framerate); - mediaTest.setFrameCount(frameTotal); - } - - async function toGetInputSurface() { - await videoEncodeProcessor.getInputSurface().then((inputSurface) => { - expect(inputSurface != undefined).assertTrue(); - surfaceID = inputSurface; - }, failCallback).catch(failCatch); - } - - function toStartStream() { - mediaTest.isStart = 1; - mediaTest.startStream(surfaceID); - } - - async function toConfigure(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to configure 2`); - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info(`case configure error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - } else { - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - } - nextStep(mySteps, done); - } - - async function toPrepare(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to prepare 2`); - await videoEncodeProcessor.prepare().then(() => { - console.info(`case prepare error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - } else { - await videoEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - } - nextStep(mySteps, done); - } - - async function toStart(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to start 2`); - await videoEncodeProcessor.start().then(() => { - console.info(`case start error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - } else { - if (sawOutputEOS) { - resetParam(); - workdoneAtEOS = true; - } - await videoEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - } - nextStep(mySteps, done); - } - - async function toFlush(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to flush 2`); - await videoEncodeProcessor.flush().then(() => { - console.info(`case flush error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - } else { - await videoEncodeProcessor.flush().then(() => { - console.info("case flush success"); - }, failCallback).catch(failCatch); - if (flushAtEOS) { - mediaTest.closeStream(surfaceID); - resetParam(); - workdoneAtEOS = true; - } - } - nextStep(mySteps, done); - } - - async function toStop(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to stop 2`); - await videoEncodeProcessor.stop().then(() => { - console.info(`case stop error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - } else { - await videoEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - } - nextStep(mySteps, done); - } - - async function toReset() { - await videoEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - } - - async function toRelease(mySteps, done) { - if (mySteps[0] == ERROR) { - mySteps.shift(); - console.info(`case to relase 2`); - await videoEncodeProcessor.release().then(() => { - console.info(`case release error 1`); - expect().assertFail(); - }, (err) => {failCallbackTrue(err, mySteps, done)}).catch(failCatch); - videoEncodeProcessor = null; - } else { - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - if (mySteps[0] != RELEASE) { - videoEncodeProcessor = null; - } - } - nextStep(mySteps, done); - } - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0100 - * @tc.name : 001.create -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0100.es'; - let mySteps = new Array(CONFIGURE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0200 - * @tc.name : 002.prepare -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0200.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, CONFIGURE, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0300 - * @tc.name : 003.start -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, - CONFIGURE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0400 - * @tc.name : 004.flush -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, - CONFIGURE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0500 - * @tc.name : 005.stop -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP , - CONFIGURE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0600 - * @tc.name : 006.EOS -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, CONFIGURE, ERROR, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0700 - * @tc.name : 007.reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0700.es'; - let mySteps = new Array(RESET, CONFIGURE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0800 - * @tc.name : 008.configure -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0800.es'; - let mySteps = new Array(CONFIGURE, CONFIGURE, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0900 - * @tc.name : 009.configure -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE_PROMISE_0900', 0, async function (done) { - let savepath = BASIC_PATH + 'configure_0900.es'; - let mySteps = new Array(CONFIGURE, RESET, CONFIGURE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0100 - * @tc.name : 001.create -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0100.es'; - let mySteps = new Array(PREPARE, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0200 - * @tc.name : 002.configure -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0200.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0300 - * @tc.name : 003.prepare -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, PREPARE, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0400 - * @tc.name : 004.start -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, PREPARE, ERROR, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0500 - * @tc.name : 005.flush -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, - PREPARE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0600 - * @tc.name : 006.stop -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - PREPARE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0700 - * @tc.name : 007.EOS -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, PREPARE, ERROR, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0800 - * @tc.name : 008.reset -> prepare - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_PREPARE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'prepare_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - PREPARE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0100 - * @tc.name : 001.create -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0100.es'; - let mySteps = new Array(START, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0200 - * @tc.name : 002.configure -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0200.es'; - let mySteps = new Array(CONFIGURE, START, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0300 - * @tc.name : 003.prepare -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, WAITFORALLOUTS); - workdoneAtEOS = true; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0400 - * @tc.name : 004.start -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, START, ERROR, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0500 - * @tc.name : 005.flush -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, - START, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0600 - * @tc.name : 006.stop -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - START, WAITFORALLOUTS); - workdoneAtEOS = true; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0700 - * @tc.name : 007.EOS -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, START, ERROR, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0800 - * @tc.name : 008.reset -> start - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'start_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - START, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0100 - * @tc.name : 001.create -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0100.es'; - let mySteps = new Array(FLUSH, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0200 - * @tc.name : 002.configure -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0200.es'; - let mySteps = new Array(CONFIGURE, FLUSH, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0300 - * @tc.name : 003.prepare -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, FLUSH, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0400 - * @tc.name : 004.start -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, FLUSH, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0500 - * @tc.name : 005.flush -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, FLUSH, - WAITFORALLOUTS); - workdoneAtEOS = true; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0600 - * @tc.name : 006.stop -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - FLUSH, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0700 - * @tc.name : 007.EOS -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, FLUSH, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0800 - * @tc.name : 008.reset -> flush - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_FLUSH_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'flush_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - FLUSH, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0100 - * @tc.name : 001.create -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0100.es'; - let mySteps = new Array(STOP, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0200 - * @tc.name : 002.configure -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0200.es'; - let mySteps = new Array(CONFIGURE, STOP, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0300 - * @tc.name : 003.prepare -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STOP, ERROR, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0400 - * @tc.name : 004.start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0500 - * @tc.name : 005.flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, STOP, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0600 - * @tc.name : 006.stop -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, STOP, ERROR, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0700 - * @tc.name : 007.EOS -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, JUDGE_EOS, - STOP, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0800 - * @tc.name : 008.reset -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_STOP_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'stop_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - STOP, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0100 - * @tc.name : 001.create -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0100.es'; - let mySteps = new Array(RESET, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0200 - * @tc.name : 002.configure -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0200.es'; - let mySteps = new Array(CONFIGURE, RESET, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0300 - * @tc.name : 003.prepare -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, RESET, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0400 - * @tc.name : 004.start -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0500 - * @tc.name : 005.flush -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, - RESET, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0600 - * @tc.name : 006.stop -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - RESET, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0700 - * @tc.name : 007.EOS -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, RESET, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0800 - * @tc.name : 008.reset -> reset - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RESET_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'reset_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RESET, - RESET, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0100 - * @tc.name : 001.create -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0100.es'; - let mySteps = new Array(RELEASE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0200 - * @tc.name : 002.configure -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0200.es'; - let mySteps = new Array(CONFIGURE, RELEASE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0300 - * @tc.name : 003.prepare -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, RELEASE, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0400 - * @tc.name : 004.start -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, - RELEASE, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0500 - * @tc.name : 005.flush -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, FLUSH, - RELEASE, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0600 - * @tc.name : 006.stop -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0600', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0600.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, STOP, - RELEASE, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0700 - * @tc.name : 007.EOS -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0700', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0700.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, RELEASE, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0800 - * @tc.name : 008.release -> release - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_RELEASE_PROMISE_0800', 0, async function (done) { - let savepath = BASIC_PATH + 'release_0800.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, STARTSTREAM, START, RELEASE, - RELEASE, ERROR, STOPSTREAM, END); - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0100 - * @tc.name : 001.EOS -> flush -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0100', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0100.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, FLUSH, STOP, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0200 - * @tc.name : 002.EOS -> flush -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0200', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0200.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, FLUSH, STARTSTREAM, WAITFORALLOUTS); - frameTotal = 2; - flushAtEOS = true; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0300 - * @tc.name : 003.EOS -> reset -> configure - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0300', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0300.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, RESET, CONFIGURE, STOPSTREAM, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0400 - * @tc.name : 004.EOS -> stop -> start -> EOS - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0400', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0400.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, STOPSTREAM, STOP, START, SETSTREAMPARAM, STARTSTREAM, WAITFORALLOUTS); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0500 - * @tc.name : 005.EOS -> stop -> start -> stop - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_EOS_PROMISE_0500', 0, async function (done) { - let savepath = BASIC_PATH + 'eos_0500.es'; - let mySteps = new Array(CONFIGURE, GETSURFACE, SETSTREAMPARAM, PREPARE, START, STARTSTREAM, HOLDON, - JUDGE_EOS, STOP, START, STOP, STOPSTREAM, RELEASE, END); - frameTotal = 2; - createVideoEncoder(savepath, mySteps, done); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE-RESET_PROMISE_0100 - * @tc.name : 001. configure -> reset for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CONFIGURE-RESET_PROMISE_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - for (let j = 1; j < 51; j++) { - console.info('case configure-reset current loop: ' + j); - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - } - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START-STOP_PROMISE_0100 - * @tc.name : 001. start -> stop for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_START-STOP_PROMISE_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - await toGetInputSurface(); - await videoEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - for (let j = 1; j < 51; j++) { - console.info('case start-stop current loop: ' + j); - await videoEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - } - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CREATE-RELEASE_PROMISE_0100 - * @tc.name : 001. create -> release for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_CREATE-RELEASE_PROMISE_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - for (let j = 1; j < 51; j++) { - console.info('case create-release current loop: ' + j); - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - done(); - }) - - /* * - * @tc.number : SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_TOTALLOOP_PROMISE_0100 - * @tc.name : 001. total loop for 50 times - * @tc.desc : Reliability Test - * @tc.size : MediumTest - * @tc.type : Reliability - * @tc.level : Level2 - */ - it('SUB_MEDIA_VIDEO_SOFTWARE_ENCODER_API_TOTALLOOP_PROMISE_0100', 0, async function (done) { - let name = 'avenc_mpeg4'; - for (let j = 1; j < 51; j++) { - console.info('case create-release current loop: ' + j); - await media.createVideoEncoderByName(name).then((processor) => { - if (typeof (processor) != 'undefined') { - videoEncodeProcessor = processor; - console.info('in case : createVideoEncoderByName success'); - } else { - console.info('in case : createVideoEncoderByName fail'); - expect().assertFail(); - done(); - } - }) - await videoEncodeProcessor.configure(mediaDescription).then(() => { - console.info("case configure success"); - }, failCallback).catch(failCatch); - await toGetInputSurface(); - await videoEncodeProcessor.prepare().then(() => { - console.info("case prepare success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.start().then(() => { - console.info("case start success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.flush().then(() => { - console.info("case flush success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.stop().then(() => { - console.info("case stop success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.reset().then(() => { - console.info("case reset success"); - }, failCallback).catch(failCatch); - await videoEncodeProcessor.release().then(() => { - console.info("case release success"); - }, failCallback).catch(failCatch); - videoEncodeProcessor = null; - } - done(); - }) -}) diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoHardwareEncoderEnumTest.test.js b/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoHardwareEncoderEnumTest.test.js deleted file mode 100644 index 524bdcc37..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/js/test/VideoHardwareEncoderEnumTest.test.js +++ /dev/null @@ -1,64 +0,0 @@ -/* - * 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 {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' - -describe('VideoHardwareEncoderEnum', function () { - - beforeAll(function() { - console.info('beforeAll case'); - }) - - beforeEach(function() { - console.info('beforeEach case'); - }) - - afterEach(function() { - console.info('afterEach case'); - }) - - afterAll(function() { - console.info('afterAll case'); - }) - - - /* * - * @tc.number : SUB_MEDIA_VIDEO_HARDWARE_ENCODER_ENUM_MediaDescriptionKey_0100 - * @tc.name : 001.MediaDescriptionKey - * @tc.desc : Test Enumerate MediaDescriptionKey - * @tc.size : MediumTest - * @tc.type : Function test - * @tc.level : Level0 - */ - it('SUB_MEDIA_VIDEO_HARDWARE_ENCODER_ENUM_MediaDescriptionKey_0100', 0, async function (done) { - expect(media.MediaDescriptionKey.MD_KEY_SUSPEND_INPUT_SURFACE).assertEqual("suspend_input_surface"); - expect(media.MediaDescriptionKey.MD_KEY_VIDEO_ENCODE_BITRATE_MODE).assertEqual("video_encode_bitrate_mode"); - expect(media.MediaDescriptionKey.MD_KEY_PROFILE).assertEqual("codec_profile"); - expect(media.MediaDescriptionKey.MD_KEY_QUALITY).assertEqual("codec_quality"); - expect(media.MediaDescriptionKey.MD_KEY_CUSTOM).assertEqual("vendor.custom"); - expect(media.MediaDescriptionKey.MD_KEY_MAX_INPUT_SIZE).assertEqual("max_input_size"); - expect(media.MediaDescriptionKey.MD_KEY_MAX_ENCODER_FPS).assertEqual("max_encoder_fps"); - expect(media.MediaDescriptionKey.MD_KEY_WIDTH).assertEqual("width"); - expect(media.MediaDescriptionKey.MD_KEY_HEIGHT).assertEqual("height"); - expect(media.MediaDescriptionKey.MD_KEY_PIXEL_FORMAT).assertEqual("pixel_format"); - expect(media.MediaDescriptionKey.MD_KEY_FRAME_RATE).assertEqual("frame_rate"); - expect(media.MediaDescriptionKey.MD_KEY_CAPTURE_RATE).assertEqual("capture_rate"); - expect(media.MediaDescriptionKey.MD_KEY_I_FRAME_INTERVAL).assertEqual("i_frame_interval"); - expect(media.MediaDescriptionKey.MD_KEY_REQUEST_I_FRAME).assertEqual("req_i_frame"); - expect(media.MediaDescriptionKey.MD_KEY_REPEAT_FRAME_AFTER).assertEqual("repeat_frame_after"); - done(); - }) -}) \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/element/string.json b/multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/element/string.json deleted file mode 100644 index 0bae6bd40..000000000 --- a/multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/element/string.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "string": [ - { - "name": "entry_MainAbility", - "value": "entry_MainAbility" - }, - { - "name": "mainability_description", - "value": "JS_Empty Ability" - } - ] -} \ No newline at end of file diff --git a/multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/media/icon.png b/multimedia/media/media_js_standard/videoEncoder/src/main/resources/base/media/icon.png deleted file mode 100644 index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6790 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