3f7a638eed
There are two variants one with storage and identify support and the other without storage. It implements the following commands: * INSERT id * REMOVE id * SCAN id * ERROR error-code * LIST (returns saved print) The INSERT/REMOVE/LIST commands are only available in the storage driver. The SCAN command emulates presenting a finger. These commands can be send ahead of time, and will be queued and processed when appropriate. i.e. for INSERT/REMOVE that is immediately when possible, for SCAN/ERROR processing is delayed. The LIST command is always processed immediately. Note that only a single command can be send per socket connection and the command must be send in a single message. The socket will be closed after the command has been processed. Co-authored-by: Bastien Nocera <hadess@hadess.net> Co-authored-by: Marco Trevisan (Treviño) <mail@3v1n0.net>
149 lines
4 KiB
C
149 lines
4 KiB
C
/*
|
|
* Unit tests for libfprint
|
|
* Copyright (C) 2019 Marco Trevisan <marco.trevisan@canonical.com>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include <libfprint/fprint.h>
|
|
#include <glib/gstdio.h>
|
|
|
|
#include "test-utils.h"
|
|
|
|
struct
|
|
{
|
|
const char *envvar;
|
|
const char *driver_id;
|
|
const char *device_id;
|
|
} devtype_vars[FPT_NUM_VIRTUAL_DEVICE_TYPES] = {
|
|
{ "FP_VIRTUAL_IMAGE", "virtual_image", "virtual_image" }, /* FPT_VIRTUAL_DEVICE_IMAGE */
|
|
{ "FP_VIRTUAL_DEVICE", "virtual_device", "virtual_device" }, /* FPT_VIRTUAL_DEVICE_NONIMAGE */
|
|
{ "FP_VIRTUAL_DEVICE_STORAGE", "virtual_device_storage", "virtual_device_storage" } /* FPT_VIRTUAL_DEVICE_NONIMAGE_STORAGE */
|
|
};
|
|
|
|
static FptVirtualDeviceType global_devtype;
|
|
|
|
void
|
|
fpt_teardown_virtual_device_environment (void)
|
|
{
|
|
const char *path;
|
|
|
|
path = g_getenv (devtype_vars[global_devtype].envvar);
|
|
|
|
if (path)
|
|
{
|
|
g_autofree char *temp_dir = g_path_get_dirname (path);
|
|
|
|
g_unsetenv (devtype_vars[global_devtype].envvar);
|
|
g_unlink (path);
|
|
g_rmdir (temp_dir);
|
|
}
|
|
}
|
|
|
|
static void
|
|
on_signal_event (int sig)
|
|
{
|
|
fpt_teardown_virtual_device_environment ();
|
|
}
|
|
|
|
void
|
|
fpt_setup_virtual_device_environment (FptVirtualDeviceType devtype)
|
|
{
|
|
g_autoptr(GError) error = NULL;
|
|
g_autofree char *temp_dir = NULL;
|
|
g_autofree char *temp_path = NULL;
|
|
g_autofree char *filename = NULL;
|
|
|
|
g_assert_null (g_getenv (devtype_vars[devtype].envvar));
|
|
|
|
temp_dir = g_dir_make_tmp ("libfprint-XXXXXX", &error);
|
|
g_assert_no_error (error);
|
|
|
|
filename = g_strdup_printf ("%s.socket", devtype_vars[devtype].device_id);
|
|
temp_path = g_build_filename (temp_dir, filename, NULL);
|
|
g_setenv (devtype_vars[devtype].envvar, temp_path, TRUE);
|
|
|
|
global_devtype = devtype;
|
|
|
|
signal (SIGKILL, on_signal_event);
|
|
signal (SIGABRT, on_signal_event);
|
|
signal (SIGSEGV, on_signal_event);
|
|
signal (SIGTERM, on_signal_event);
|
|
signal (SIGQUIT, on_signal_event);
|
|
signal (SIGPIPE, on_signal_event);
|
|
}
|
|
|
|
FptContext *
|
|
fpt_context_new (void)
|
|
{
|
|
FptContext *tctx;
|
|
|
|
tctx = g_new0 (FptContext, 1);
|
|
tctx->fp_context = fp_context_new ();
|
|
|
|
return tctx;
|
|
}
|
|
|
|
FptContext *
|
|
fpt_context_new_with_virtual_device (FptVirtualDeviceType devtype)
|
|
{
|
|
FptContext *tctx;
|
|
GPtrArray *devices;
|
|
unsigned int i;
|
|
|
|
g_assert_true (devtype >= FPT_VIRTUAL_DEVICE_IMAGE &&
|
|
devtype < FPT_NUM_VIRTUAL_DEVICE_TYPES);
|
|
|
|
fpt_setup_virtual_device_environment (devtype);
|
|
|
|
tctx = fpt_context_new ();
|
|
devices = fp_context_get_devices (tctx->fp_context);
|
|
|
|
g_assert_nonnull (devices);
|
|
g_assert_cmpuint (devices->len, ==, 1);
|
|
|
|
for (i = 0; i < devices->len; ++i)
|
|
{
|
|
FpDevice *device = devices->pdata[i];
|
|
|
|
if (g_strcmp0 (fp_device_get_driver (device), devtype_vars[devtype].driver_id) == 0)
|
|
{
|
|
tctx->device = device;
|
|
break;
|
|
}
|
|
}
|
|
|
|
g_assert_true (FP_IS_DEVICE (tctx->device));
|
|
g_object_add_weak_pointer (G_OBJECT (tctx->device), (gpointer) & tctx->device);
|
|
|
|
return tctx;
|
|
}
|
|
|
|
void
|
|
fpt_context_free (FptContext *tctx)
|
|
{
|
|
if (tctx->device && fp_device_is_open (tctx->device))
|
|
{
|
|
g_autoptr(GError) error = NULL;
|
|
|
|
fp_device_close_sync (tctx->device, NULL, &error);
|
|
g_assert_no_error (error);
|
|
}
|
|
|
|
g_clear_object (&tctx->fp_context);
|
|
g_free (tctx);
|
|
|
|
fpt_teardown_virtual_device_environment ();
|
|
}
|