summaryrefslogtreecommitdiffstats
path: root/tests/auto/unit/qcamera/tst_qcamera.cpp
diff options
context:
space:
mode:
authorYoann Lopes <yoann.lopes@digia.com>2014-01-22 16:18:42 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-02-28 14:10:00 +0100
commitb28ee24628f77fced393cacc45500be6761e4497 (patch)
tree811173f8a2caf84e0fa386010283ccfd32c6ad0d /tests/auto/unit/qcamera/tst_qcamera.cpp
parentd964388b38ec4762e315d86aacb779604bcdca1b (diff)
New QCameraInfo class.
The class allows to get the list of available cameras on the system as well as getting some static information about them such as their unique ID, display name, physical position and sensor orientation. This makes QCamera::availableDevices() and QCamera::deviceDescription() obsolete. This patch contains the API, documentation and auto-tests but not the actual implementation by each backend (except for retrieving the default camera device). [ChangeLog][QtMultimedia] Added new QCameraInfo class [ChangeLog][QtMultimedia] QCamera: availableDevices() and deviceDescription() are deprecated, use QCameraInfo instead Change-Id: I64fd65729ab26a789468979ed5444ee90bb82cd0 Reviewed-by: Christian Stromme <christian.stromme@digia.com>
Diffstat (limited to 'tests/auto/unit/qcamera/tst_qcamera.cpp')
-rw-r--r--tests/auto/unit/qcamera/tst_qcamera.cpp80
1 files changed, 73 insertions, 7 deletions
diff --git a/tests/auto/unit/qcamera/tst_qcamera.cpp b/tests/auto/unit/qcamera/tst_qcamera.cpp
index 8c72acb8c..11032a422 100644
--- a/tests/auto/unit/qcamera/tst_qcamera.cpp
+++ b/tests/auto/unit/qcamera/tst_qcamera.cpp
@@ -57,6 +57,7 @@
#include <qcameracapturedestinationcontrol.h>
#include <qmediaservice.h>
#include <qcamera.h>
+#include <qcamerainfo.h>
#include <qcameraimagecapture.h>
#include <qvideorenderercontrol.h>
@@ -101,7 +102,7 @@ private slots:
void testCaptureDestination();
void testCaptureFormat();
- void testConstructorWithDefaultProvider();
+ void testConstructor();
void testCaptureMode();
void testIsCaptureModeSupported();
void testRequestedLocks();
@@ -1141,6 +1142,8 @@ void tst_QCamera::testEnumDebug()
qDebug() << QCamera::NoLock;
QTest::ignoreMessage(QtDebugMsg, "QCamera::LockExposure ");
qDebug() << QCamera::LockExposure;
+ QTest::ignoreMessage(QtDebugMsg, "QCamera::FrontFace ");
+ qDebug() << QCamera::FrontFace;
}
void tst_QCamera::testCameraControl()
@@ -1149,13 +1152,75 @@ void tst_QCamera::testCameraControl()
QVERIFY(m_cameraControl != NULL);
}
-/* Test case for constructor with default provider */
-void tst_QCamera::testConstructorWithDefaultProvider()
+void tst_QCamera::testConstructor()
{
- QCamera *camera = new QCamera(0);
- QVERIFY(camera != NULL);
- QCOMPARE(camera->state(), QCamera::UnloadedState);
- delete camera;
+ // Service doesn't implement QVideoDeviceSelectorControl
+ provider->service = mockSimpleCameraService;
+
+ {
+ QCamera camera;
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ }
+
+ {
+ // Requesting a camera at a specific position from a service which doesn't implement
+ // the QVideoDeviceSelectorControl should result in loading the default camera
+ QCamera camera(QCamera::FrontFace);
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ }
+
+ // Service implements QVideoDeviceSelectorControl
+ provider->service = mockCameraService;
+
+ {
+ QCamera camera;
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 1); // default is 1
+ }
+
+ {
+ QCamera camera(QCameraInfo::defaultCamera());
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 1);
+ QCOMPARE(QCameraInfo(camera), QCameraInfo::defaultCamera());
+ }
+
+ {
+ QCameraInfo cameraInfo = QCameraInfo::availableCameras().at(0);
+ QCamera camera(cameraInfo);
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 0);
+ QCOMPARE(QCameraInfo(camera), cameraInfo);
+ }
+
+ {
+ // Requesting a camera at a position which is not available should result in
+ // loading the default camera
+ QCamera camera(QCamera::FrontFace);
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 1);
+ }
+
+ {
+ QCamera camera(QCamera::BackFace);
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 0);
+ }
+
+ {
+ // Should load the default camera when UnspecifiedPosition is requested
+ QCamera camera(QCamera::UnspecifiedPosition);
+ QCOMPARE(camera.availability(), QMultimedia::Available);
+ QCOMPARE(camera.error(), QCamera::NoError);
+ QCOMPARE(mockCameraService->mockVideoDeviceSelectorControl->selectedDevice(), 1);
+ }
}
/* captureModeChanged Signal test case. */
@@ -1530,6 +1595,7 @@ void tst_QCamera::testLockChangeReason()
QVERIFY(LockChangeReason == QCamera::LockAcquired);
}
+
/* All the enums test case for QCameraControl class*/
void tst_QCamera::testEnumsOfQCameraControl()
{