• 怎么测试直播类产品……


    测试人员,该如何对直播类产品的直播质量进行测试呢?

    首先要明白音视频的基本原理明确视频和音频的质量标准,这样才能根据质量标准来定测试方法。

    a64f27c4b30d97bd9a3ef9943640b765.png

    341461702a4eb60cd93120afe769757e.png

    6bb3c0cb7727b780c8d46cfba08622ae.png

    音视频基本原理

    bb7216f7c67781f83353207fd34b0e89.png

    f8f516d62ee22d38da87175ae31aeabb.png


    1.采集

    音视频需要经过摄像头、麦克风上等硬件设备上通过其上的传感器采集传输转化,最终成为计算机数字信号的过程。其中双人视频和群视频中的播片,采集播放都是由ffmpeg插件完成。

    b1ae8832496473d8dc52928ec0717bc0.png

    2.前处理

    采集完的音视频数据需要经过一些处理得到更好的效果,音频的前处理包括增益控制(AGC) 、噪声抑制(ANS)、回声抵消(AEC)、静音检测(VAD)等,视频的前处理包括视频降噪、缩放 等。

    b32ee2882c5e0cf482c6d01a621f08ce.png

    3.编解码

    一个信号或者一个数据流需要进行编解码操作,这里指的变换既包括将信号或者数据流进行编码(通常是为了传输、存储或者加密)或者提取得到一个编码流的操作。视频编解码器众多,例如vp8、vp9、MPEG、H264等;音频类编解码器可分两大类,语音类编解码器(SILK、Speex、iSAC等)和音频类编解码器(ECELT、AAC等)。

    a6d2fdce34665adfbbd420dd33fad8e1.png

    4.网络传输

    在网络传输中,会针对不同的网络环境选取UDP或TCP传输,在即时音视频通话上一般优先采用UDP,因为其可自由度、延时都较好;除外还会针对传输过程中存在的损耗进行处理,包括控制包大小、FEC机制、丢包重传、Jitter控制、时延、乱序等等。

    a64b2917e485a52143d2d80628c62c34.png

    5.后处理

    数据经过网络传输到接受方后经过解码进入后处理环节,该环节中,音频数据可能需要重采样或混音,而视频可能需要消除块效应、时域降频等等。

    b403a799ccbb9cd0e69bd4de6e2f52ff.png

    6.播放/渲染显示

    在经过后处理后,数字信号转化为声音及画面的过程就是播放/渲染。Windows系统中常用的音频播放api有DirectSound、WaveOut、CoreAudio。

    d724c772eeaff43cffe9b5ebf86a77be.png

    1825ae35f1dad6887cf15ed6dab8b2d7.png

    f36eb07fad12334ba06225cba23034d8.png

    视频质量标准

    988b59f2393681ea5e44967a5a51b7b4.png

    以下介绍视频质量标准和测试方法。

    1. 进房速度

    正常网络要求:进入房间耗时小于1秒(iOS和Android端)

    弱网络要求:弱网络下对进房速度没有制定标准

    Android建议使用中低端机型(如小米note),IOS建议使用iphone6S测试

    测试方法

    覆盖场景:入口要覆盖全,比如app内部、QQ、QQ空间、微信、朋友圈、新浪微博

    1.一台手机打开毫秒级的秒表,然后另一台测试手机打开被测产品,进入主播房间;

    2.进入主播房间出现第一帧画面后,暂停秒表记录数据;

    3.需要重复以上步骤,进行20次数据,最终结果取均值。

     竞品数据

    47aa1c64a97af0edcb6819355e6494a7.png


    2. 清晰度

    正常网络要求:跟上个版本相比,清晰度没有出现劣化现象

    弱网络要求:在网络丢包率10%场景下,清晰度跟正常网络的数据相比没有出现明显下降

    工具:Imatest

    环境调试:

    1.摄像头和目标卡片的距离为0.75m,光源与被拍摄卡片的角度保持在45°,以确保卡片表面不会有阴影产生;

    2.使用荧光灯(D65/CWF/SP35)进行测试前,至少预热光源15 分钟;

    3.测量反射性卡片表面的9 个点的照度和色温,以确保灯光一致性,调节被测手机位置,使其拍摄位置居中。

    cf20b57e416932515d66f91c15fce83c.png

    操作步骤:

    1.使用不同竞品拍摄卡片,将拍摄的图片导入PC,使用Imatest工具计算清晰度,点击 SFR:New File;

    2.选择需要处理的图片,进行添加,选中图片上的13个分布点(如下图)框图处理,框图完成点击【 Yes,Continue】

    3.点击【 OK 】和【 Yes 】,计算生成的MTF50P即为图片的清晰度。

    938ec4cd3afb183dd8851967fe63311a.png

    影响因素

    清晰度受视频分辨率和码率影响较大,发送码率越大且分辨率越高,则视频清晰度越好,注意不要脱离码率仅仅依据分辨率大小来判断清晰度高低。

    竞品数据

    56886b6d7fd8c3b82e3b9311b6beb8a3.png


    3.帧率

    正常网络要求:由于人类眼睛的特殊生理结构,如果所看画面帧率高于16的时候,就会认为是连贯的,因此帧率建议不低于16帧。设置帧率时可根据需求综合考虑,对比竞品。而帧率低于5帧时,人眼能明显感觉到画面不连贯,产生卡的感觉。

    弱网络要求:在网络丢包率10%场景下,帧率跟正常网络相比没有出现明显下降。

    测试方法

    设备:2台电脑 + 1个摄像头 + 2部手机。一台电脑播放视频,一台电脑录制视频,一部手机当主播,一部手机当观众,摄像头采集观众端画面。

    视频源:特定视频demo.avi

    操作步骤:

    1.电脑1播放循环视频demo.avi,电脑2插入摄像头,打开“会声会影”软件;

    2.手机A发起直播,手机B当该直播的观众,A对准播放视频的电脑,打开“会声会影”软件,将录制视频电脑的摄像头对准B;

    3.点击“会声会影”软件的捕获——》捕获视频——》设置“捕获文件夹”,点击捕获视频(大概录制10~20s),视频捕获完成。捕获之后的视频格式为mpg格式;

    4.将mpg格式的文件转换为yuv格式:编辑mepg2Dec.cmd文件,如下图所示,将文件名改为所捕获的视频文件名,保存之后运行mpeg2dec.exe;

    828959b78188f3225af3891ca505f16c.png

    5.打开YUVviewerPlus.exe文件,如下图所示,设置录制视频的分辨率(会声会影录制文件默认分辨率为720*480),点击open File打开转换后的yuv格式文件;

    6.点击“next”开始数帧数,以1s 30帧为基准,30下内场景图像变动的次数即为帧率(最好是数3s)3s图像变动的次数取平均值。建议取录制视频的开头/中间/尾部3处求平均值。

    影响因素

    在网络正常无损伤的情况下,帧率主要受视频影响,视频码率越大则会编码高帧率和高分辨率的视频码流。

    竞品数据

    dd24b0cb5b1e19103a70c7c3b731bb9e.png


    4. 卡顿次数

    标准

    正常网络要求:

    弱网络要求:

    测试方法

    地球仪(IOS)或自动化测试工具(Android)

     影响因素

    在网络正常无损伤的情况下,帧率主要受视频影响,视频码率越大则会编码高帧率和高分辨率的视频码流

    5.视频质量稳定性

    在各种损伤变化场景下,直播3小时内未出现花屏、黑屏、自动中断等现象

    测试方法

    1.损伤自动化测试,并使用软件会声会影进行录制;

    2.查看录制的视频是否有花屏、黑屏或异常中断等现象。

    27aa81ce526d762288acc8d0cf2de695.png

    ed5cd0a7a1bdaea09c65368a2dd7b612.png

    音频质量标准

    d1dbe7fe8604d0fce3e09884fc9697bf.png

    以下介绍音频质量标准和测试方法。

    1.采样率

    正常网络要求:音频采样率大于16k

    弱网络要求:音频采样率大于16k

    测试需覆盖直播场景和连麦场景。

    测试方法

    设备:两台手机、可播放样本设备、录音笔

    1.一台手机进入主播环境,另一台手机作为观众端;

    2.使用一个可播放语音(音乐)样本的设备在主播端进行播放;

    3. 观众端用录音笔录下接收到的语音

    4.使用adobe audition查看频谱:最高频谱为7k左右,因此采样率应为16k;

    d01fa138ad07584011ef40f19ab2460f.png

    2.音质客观评分

    正常网络要求:正常网络直播时,语音音质均分>=4.0分

    弱网络要求:弱网络直播时,语音音质均分>=3.5分


    测试方法

    直播模式:由于直播时延大于2秒,因此采用音频线录制并剪切后再用SPIRENT设备进行测分。

    设备:两条音频线,一台PC,两台手机

    1.主播端的麦克风连接PC的扬声器,观众端的扬声器连接PC的麦克风;

    2.PC循环播放48k语音样本(样本时长为10s);

    3.打开adobe audition进行录制,录制时间约2mins;

    4.把录制下来的音频进行分段剪切(每段语音为10s,前面空白语音保留约3s)

    5.上传剪切的音频文件到SPIRENT设备并算出POLQA均分。

    连麦模式:时延低于1s,可用SPIRENT设备直接测音质。

    1.主播端与观众端连麦;

    2.接入SPIRENT设备测试音质,双向测试时间约为8mins;

    3.得出音质平均分

    3.音画同步

    正常网络和弱网络下,出现音画不同步现象概率为0。

    测试方法

    观看直播过程中,主观判断视频画面中主播口型跟声音是否对得上。

    连麦-噪声抑制

    主播和观众连麦模式下,主播→观众的噪声消除效果跟上个版本相比,噪声抑制效果没有变差。

    测试方法

    设备:音频线一条,播放语音样本设备、PC一台

    1.主播端与观众端连麦;

    2.把主播端手机放在消音室并固定位置,然后在消音室内使用可播放语音样本的设备播放噪声样本;

    3. 观众观的扬声器口连接PC的麦克风;

    4.使用Adobe Audition 进行录制并保存文件;

    5. 相同方法录制上一版本(保持相同的测试环境);

    6.新旧版本进行对比,选取相同的语音段和噪声段,算出信噪比。

    4b8882983fae48b867f7df3a35c129a7.png

     

    4.连麦-回声抵消

    标准:主播和观众连麦模式下,单讲和双讲时,说话方听到的回声较小,不会影响交流。

    测试方法

    单讲:观众端开启扬声器,主播端说话,主观听是否有自己的回声;反过来观众端说话,听是否有回声。

    双讲:双方都开启扬声器,并同时说话,主观听是否有回声,或声音断续有剪切。

    5.抗抖动能力

    主播端:上行抖动时延在400ms内,视频直播不会有影响

    观众端:下行抖动时延在400ms内,视频直播不会有影响

    测试方法

    1.主播端上行加400ms抖动,观看观众端视频画面和语音;

    2.观众端上行加400ms抖动,观看观众端视频画面和语音。

    6.CPU占用率

    主播端:CPU不超过40%(iOS:iPhone6、安卓无指定机型)

    观众端:CPU不超过30%(iOS:iPhone6、安卓无指定机型)

    测试方法

    1. iOS:非越狱手机连接mac机,用instrument录制CPU后使用脚本算出CPU,CPU占用率=(主进程+mediaserverd+backboard)/核数

    2.Android: 通过cmd命令,进入命令行,输入adb shell top –m 10 >d:\xx.txt命令行打印手机的CPU消耗参数,再用过脚本处理,提取出video和mediaserver的CPU消耗,两者相加的和就是音视频的CPU消耗。

    7. 流量

    视频直播时,观众端接收到的音视频数据大小跟上个版本相比,流量没有出现增加。

    测试方法

    iOS:

    1.非越狱手机连接mac机,打开终端,输入:rvictl +手机identifier;

    2.进入su模式,输入:tcpdump –i rvi0 –vv –s 0 –w xx.pcap;

    3.运行3mins,再用wireshark打开文件,查看流量。

    Android:

    1. 安装抓包小工具:

    2.程序开始运行后点击小工具并开始;

    3.用wireshark打开生成的pcap文件,查看流量。

    8.电量

    观看直播时,观众端的电池电量消耗跟上个版本相比,电量没有出现增加。

    测试方法

    1.观众端观看主播端,观看10mins、20mins,记录手机电量消耗多少个百分点;

    2.保持相同环境和相同手机,测试上一版本;

    3.比较新旧版本的耗电量

    9.发热量

    观看直播时,观众端的手机发热量跟上个版本相比,电量没有出现增加。

    测试方法

    1.观众端观看主播端,观看10mins、20mins、30min,用测温枪测量手机后背温度并记录;

    2.保持相同环境和相同手机,测试上一版本;

    3.比较新旧版本的耗电量

    以上,希望能帮到大家。

    版权声明:本文为CSDN博主「xp562870732」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

    原文链接:https://blog.csdn.net/xp562870732/article/details/110489968

    end

  • 相关阅读:
    callAfter 例子2
    wxpython
    python 处理excel 进程无法退出的问题
    常用电子技术网
    Emeditor 与正则表达式
    Windows程序中的字符编码
    Delphi7 无法启动 问题搞定
    2007中国发烧盘点之作《天路》发烧女声版
    一台电脑安装多个(虚拟)网卡问题
    无法删除xxx文档/文件夹:找不到指定的路径。请确定指定的路径是否正确
  • 原文地址:https://www.cnblogs.com/finer/p/16157209.html
Copyright © 2020-2023  润新知