我正在尝试在Chrome中运行端到端测试,以获得需要网络摄像头馈送中途才能运行的产品。据我所知,这意味着使用--use-file-for-fake-video-capture="/path/to/video.y4m"
命令行参数向Chrome提供虚假的网络摄像头视频。然后它将其用作网络摄像头视频。
但是,无论我提供什么y4m文件,我都会在以下条件下运行以下Chrome错误:
DOMException: Could not start video source
{
code: 0,
message: "Could not start video source",
name: "NotReadableError"
}
值得注意的是,我可以使用--use-file-for-fake-audio-capture
提供一个音频文件,Chrome可以很好地使用它。视频一直是我的观点。
此错误来自以下简单的mediaDevices请求:
navigator.mediaDevices.getUserMedia({ video: true, audio: true })
.then(data => {
// do stuff
})
.catch(err => {
// oh no!
});
(当提供视频文件时,这总是会击中“哦不!”分支。)
我一直在使用以下命令行参数运行Chrome(为了便于阅读添加了换行符),我正在使用Mac,因此使用open
命令:
open -a "Google Chrome" --args
--disable-gpu
--use-fake-device-for-media-stream
--use-file-for-fake-video-capture="~/Documents/mock/webcam.y4m"
--use-file-for-fake-audio-capture="~/Documents/mock/microphone.wav"
webcam.y4m
和microphone.wav
是根据我录制的视频文件生成的。
我首先使用浏览器的MediaRecorder录制了第22个mp4视频,下载了结果,并使用以下命令行命令对其进行了转换:
ffmpeg -y -i original.mp4 -f wav -vn microphone.wav
ffmpeg -y -i original.mp4 webcam.y4m
当这不起作用时,我尝试使用我在Quicktime中记录的第二十二个电影文件:
ffmpeg -y -i original.mov -f wav -vn microphone.wav
ffmpeg -y -i original.mov webcam.y4m
当这也失败了,我直接去了the Chromium file that explains fake video capture,去了它提供的the example y4m file list,并下载了奶奶文件并将其作为命令行参数提供给Chrome:
open -a "Google Chrome" --args
--disable-gpu
--use-fake-device-for-media-stream
--use-file-for-fake-video-capture="~/Documents/mock/grandma_qcif.y4m"
--use-file-for-fake-audio-capture="~/Documents/mock/microphone.wav"
在所有这些情况下,Chrome都会向我提供完全相同的错误。
只有当我完全省略视频时Chrome才会错误地使用该mediaDevices请求:
open -a "Google Chrome" --args
--disable-gpu
--use-fake-device-for-media-stream
--use-file-for-fake-audio-capture="~/Documents/mock/microphone.wav"
TestRTC建议,如果我给它一个C420mpeg2
文件Chrome将“崩溃”,并建议只需更换元数据就可以解决问题。实际上我从ffmpeg生成的视频文件给了我以下标题:
YUV4MPEG2 W1280 H720 F30:1 Ip A1:1 C420mpeg2 XYSCSS=420MPEG2
使用此文件运行Chrome时实际上并没有崩溃,我只是得到上面的错误。如果我根据TestRTC的建议将视频文件编辑到以下标题,我会得到相同的情况:
YUV4MPEG2 W1280 H720 F30:1 Ip A1:1 C420 XYSCSS=420MPEG2
在这些条件下,视频文件仍然给出了上述错误。
我应该如何为Chrome提供此命令行参数的视频文件?
我该如何录制或创建视频文件?
我应该如何将其转换为y4m?
阅读完你提供的链接后,我注意到我们也可以提供一个mjpeg。
根据您的测试要求 - 这可能足够您。
ffmpeg -i oldfile.mp4 newfile.mjpeg
然后我测试使用:
google-chrome --use-fake-device-for-media-stream --use-file-for-fake-video-capture=newfile.mjpeg
导航到Tracking JS后,我可以看到正在播放的视频。
我希望这对你有用!