summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/auto/integration/qmediaplayerbackend/tst_qmediaplayerbackend.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/tests/auto/integration/qmediaplayerbackend/tst_qmediaplayerbackend.cpp b/tests/auto/integration/qmediaplayerbackend/tst_qmediaplayerbackend.cpp
index a19ff44a8..a3e005929 100644
--- a/tests/auto/integration/qmediaplayerbackend/tst_qmediaplayerbackend.cpp
+++ b/tests/auto/integration/qmediaplayerbackend/tst_qmediaplayerbackend.cpp
@@ -78,6 +78,7 @@ private slots:
void seekOnLoops();
void changeLoopsOnTheFly();
void lazyLoadVideo();
+ void videoSinkSignals();
private:
QUrl selectVideoFile(const QStringList& mediaCandidates);
@@ -1883,6 +1884,40 @@ void tst_QMediaPlayerBackend::lazyLoadVideo()
QVERIFY(frame.isValid());
}
+void tst_QMediaPlayerBackend::videoSinkSignals()
+{
+ // TODO: come up with custom frames source,
+ // create the test target tst_QVideoSinkBackend,
+ // and move the test there
+
+ if (localVideoFile2.isEmpty())
+ QSKIP("Video format is not supported");
+
+ QVideoSink sink;
+ QMediaPlayer player;
+ player.setVideoSink(&sink);
+
+ std::atomic<int> videoFrameCounter = 0;
+ std::atomic<int> videoSizeCounter = 0;
+
+ connect(&sink, &QVideoSink::videoFrameChanged, [&](const QVideoFrame &frame) {
+ QCOMPARE(sink.videoFrame(), frame);
+ QCOMPARE(sink.videoSize(), frame.size());
+ ++videoFrameCounter;
+ });
+
+ connect(&sink, &QVideoSink::videoSizeChanged, [&]() {
+ QCOMPARE(sink.videoSize(), sink.videoFrame().size());
+ ++videoSizeCounter;
+ });
+
+ player.setSource(localVideoFile2);
+ player.play();
+
+ QTRY_COMPARE_GE(videoFrameCounter, 2);
+ QCOMPARE(videoSizeCounter, 1);
+}
+
QTEST_MAIN(tst_QMediaPlayerBackend)
#include "tst_qmediaplayerbackend.moc"