summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2012-03-05 16:12:53 +0100
committerMatthias Vogelgesang <matthias.vogelgesang@kit.edu>2012-03-05 16:12:53 +0100
commit0483c86add2f496021560b82476d22e2497006be (patch)
treed0fbdd2f09760bf6719443cdceff6e53ee57ae1f /test
parent13acd5530fa2a6689b0a6a3ffa278d58c1428fe1 (diff)
downloadlibuca-0483c86add2f496021560b82476d22e2497006be.tar.gz
libuca-0483c86add2f496021560b82476d22e2497006be.tar.bz2
libuca-0483c86add2f496021560b82476d22e2497006be.tar.xz
libuca-0483c86add2f496021560b82476d22e2497006be.zip
Complete async xfer infrastructure
Diffstat (limited to 'test')
-rw-r--r--test/test-mock.c35
1 files changed, 32 insertions, 3 deletions
diff --git a/test/test-mock.c b/test/test-mock.c
index 5831951..5340166 100644
--- a/test/test-mock.c
+++ b/test/test-mock.c
@@ -32,14 +32,14 @@ static void test_recording(Fixture *fixture, gconstpointer data)
UcaCamera *camera = UCA_CAMERA(fixture->camera);
uca_camera_stop_recording(camera, &error);
- g_assert(error != NULL);
+ g_assert_error(error, UCA_CAMERA_ERROR, UCA_CAMERA_ERROR_NOT_RECORDING);
g_error_free(error);
error = NULL;
uca_camera_start_recording(camera, &error);
- g_assert(error == NULL);
+ g_assert_no_error(error);
uca_camera_stop_recording(camera, &error);
- g_assert(error == NULL);
+ g_assert_no_error(error);
}
static void test_recording_signal(Fixture *fixture, gconstpointer data)
@@ -57,6 +57,34 @@ static void test_recording_signal(Fixture *fixture, gconstpointer data)
g_assert(success == TRUE);
}
+static void grab_func(gpointer data, gpointer user_data)
+{
+ gboolean *success = (gboolean *) user_data;
+ *success = TRUE;
+}
+
+static void test_recording_async(Fixture *fixture, gconstpointer data)
+{
+ UcaCamera *camera = UCA_CAMERA(fixture->camera);
+
+ gboolean success = FALSE;
+ uca_camera_set_grab_func(camera, grab_func, &success);
+
+ g_object_set(G_OBJECT(camera),
+ "framerate", 10,
+ "transfer-asynchronously", TRUE,
+ NULL);
+
+ GError *error = NULL;
+ uca_camera_start_recording(camera, &error);
+ g_assert_no_error(error);
+
+ g_usleep(G_USEC_PER_SEC / 8);
+
+ uca_camera_stop_recording(camera, &error);
+ g_assert_no_error(error);
+}
+
static void test_recording_property(Fixture *fixture, gconstpointer data)
{
UcaCamera *camera = UCA_CAMERA(fixture->camera);
@@ -124,6 +152,7 @@ int main(int argc, char *argv[])
g_test_add("/recording", Fixture, NULL, fixture_setup, test_recording, fixture_teardown);
g_test_add("/recording/signal", Fixture, NULL, fixture_setup, test_recording_signal, fixture_teardown);
+ g_test_add("/recording/asynchronous", Fixture, NULL, fixture_setup, test_recording_async, fixture_teardown);
g_test_add("/properties/base", Fixture, NULL, fixture_setup, test_base_properties, fixture_teardown);
g_test_add("/properties/recording", Fixture, NULL, fixture_setup, test_recording_property, fixture_teardown);
g_test_add("/properties/binnings", Fixture, NULL, fixture_setup, test_binnings_properties, fixture_teardown);