fp-device: Return error if trying to list a storage-less device
Devices with no storage don't allow listing prints, and if we try to do that, we'd end up in trying to call a NULL function pointer, causing a crash So always check if the device has storage before calling the list vfunc, and if we fail, return an error. Include an unit-test to verify this situation
This commit is contained in:
parent
15a90eb451
commit
355cae1bbd
2 changed files with 27 additions and 0 deletions
|
@ -1213,6 +1213,14 @@ fp_device_list_prints (FpDevice *device,
|
|||
return;
|
||||
}
|
||||
|
||||
if (!fp_device_has_storage (device))
|
||||
{
|
||||
g_task_return_error (task,
|
||||
fpi_device_error_new_msg (FP_DEVICE_ERROR_NOT_SUPPORTED,
|
||||
"Device has no storage"));
|
||||
return;
|
||||
}
|
||||
|
||||
priv->current_action = FPI_DEVICE_ACTION_LIST;
|
||||
priv->current_task = g_steal_pointer (&task);
|
||||
maybe_cancel_on_cancelled (device, cancellable);
|
||||
|
|
|
@ -1527,6 +1527,24 @@ test_driver_list_error (void)
|
|||
g_assert_null (prints);
|
||||
}
|
||||
|
||||
static void
|
||||
test_driver_list_no_storage (void)
|
||||
{
|
||||
g_autoptr(FpAutoResetClass) dev_class = auto_reset_device_class ();
|
||||
g_autoptr(FpAutoCloseDevice) device = NULL;
|
||||
g_autoptr(GPtrArray) prints = NULL;
|
||||
g_autoptr(GError) error = NULL;
|
||||
|
||||
dev_class->list = NULL;
|
||||
|
||||
device = auto_close_fake_device_new ();
|
||||
g_assert_false (fp_device_has_storage (device));
|
||||
|
||||
prints = fp_device_list_prints_sync (device, NULL, &error);
|
||||
g_assert_null (prints);
|
||||
g_assert_error (error, FP_DEVICE_ERROR, FP_DEVICE_ERROR_NOT_SUPPORTED);
|
||||
}
|
||||
|
||||
static void
|
||||
test_driver_delete (void)
|
||||
{
|
||||
|
@ -2210,6 +2228,7 @@ main (int argc, char *argv[])
|
|||
g_test_add_func ("/driver/capture/error", test_driver_capture_error);
|
||||
g_test_add_func ("/driver/list", test_driver_list);
|
||||
g_test_add_func ("/driver/list/error", test_driver_list_error);
|
||||
g_test_add_func ("/driver/list/no_storage", test_driver_list_no_storage);
|
||||
g_test_add_func ("/driver/delete", test_driver_delete);
|
||||
g_test_add_func ("/driver/delete/error", test_driver_delete_error);
|
||||
g_test_add_func ("/driver/cancel", test_driver_cancel);
|
||||
|
|
Loading…
Reference in a new issue