diff options
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/Makefile.am | 38 | ||||
-rw-r--r-- | plugins/tests/test-udev-rules.c | 164 |
2 files changed, 202 insertions, 0 deletions
diff --git a/plugins/Makefile.am b/plugins/Makefile.am index 435d0ed2..2dcde280 100644 --- a/plugins/Makefile.am +++ b/plugins/Makefile.am @@ -306,6 +306,8 @@ libmm_plugin_huawei_la_LIBADD = $(builddir)/libhelpers-huawei.la dist_udevrules_DATA += huawei/77-mm-huawei-net-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_HUAWEI=\"${srcdir}/huawei\" + ################################################################################ # plugin: ericsson mbm ################################################################################ @@ -321,6 +323,8 @@ libmm_plugin_ericsson_mbm_la_LIBADD = $(MBM_COMMON_LIBADD_FLAGS) dist_udevrules_DATA += mbm/77-mm-ericsson-mbm.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_MBM=\"${srcdir}/mbm\" + ################################################################################ # plugin: option ################################################################################ @@ -423,6 +427,8 @@ libmm_plugin_nokia_icera_la_LIBADD = $(ICERA_COMMON_LIBADD_FLAGS) dist_udevrules_DATA += nokia/77-mm-nokia-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_NOKIA=\"${srcdir}/nokia\" + ################################################################################ # plugin: zte ################################################################################ @@ -444,6 +450,8 @@ libmm_plugin_zte_la_LIBADD = $(ICERA_COMMON_LIBADD_FLAGS) dist_udevrules_DATA += zte/77-mm-zte-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_ZTE=\"${srcdir}/zte\" + ################################################################################ # plugin: longcheer (and rebranded dongles) ################################################################################ @@ -460,6 +468,8 @@ libmm_plugin_longcheer_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) dist_udevrules_DATA += longcheer/77-mm-longcheer-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_LONGCHEER=\"${srcdir}/longcheer\" + ################################################################################ # plugin: anydata cdma ################################################################################ @@ -504,6 +514,8 @@ libmm_plugin_simtech_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) dist_udevrules_DATA += simtech/77-mm-simtech-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_SIMTECH=\"${srcdir}/simtech\" + ################################################################################ # plugin: alcatel/TCT/JRD x220D and possibly others ################################################################################ @@ -520,6 +532,8 @@ libmm_plugin_x22x_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) dist_udevrules_DATA += x22x/77-mm-x22x-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_X22X=\"${srcdir}/x22x\" + ################################################################################ # plugin: pantech ################################################################################ @@ -595,6 +609,8 @@ libmm_plugin_cinterion_la_LIBADD = $(builddir)/libhelpers-cinterion.la dist_udevrules_DATA += cinterion/77-mm-cinterion-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_CINTERION=\"${srcdir}/cinterion\" + ################################################################################ # plugin: iridium ################################################################################ @@ -694,6 +710,8 @@ libmm_plugin_dell_la_LIBADD = $(NOVATEL_COMMON_LIBADD_FLAGS) $(SIERRA_COMMON_L dist_udevrules_DATA += dell/77-mm-dell-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_DELL=\"${srcdir}/dell\" + ################################################################################ # plugin: altair lte ################################################################################ @@ -778,6 +796,8 @@ libmm_plugin_telit_la_LIBADD = $(builddir)/libhelpers-telit.la $(TELIT_COMMON_ dist_udevrules_DATA += telit/77-mm-telit-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_TELIT=\"${srcdir}/telit\" + ################################################################################ # plugin: mtk ################################################################################ @@ -794,6 +814,8 @@ libmm_plugin_mtk_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) dist_udevrules_DATA += mtk/77-mm-mtk-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_MTK=\"${srcdir}/mtk\" + ################################################################################ # plugin: haier ################################################################################ @@ -808,6 +830,22 @@ libmm_plugin_haier_la_LDFLAGS = $(PLUGIN_COMMON_LINKER_FLAGS) dist_udevrules_DATA += haier/77-mm-haier-port-types.rules +AM_CFLAGS += -DTESTUDEVRULESDIR_HAIER=\"${srcdir}/haier\" + +################################################################################ +# udev rules tester +################################################################################ + +noinst_PROGRAMS += test-udev-rules +test_udev_rules_SOURCES = \ + tests/test-udev-rules.c \ + $(NULL) +test_udev_rules_LDADD = \ + $(top_builddir)/src/libkerneldevice.la \ + $(top_builddir)/libmm-glib/libmm-glib.la \ + $(NULL) + + ################################################################################ TEST_PROGS += $(noinst_PROGRAMS) diff --git a/plugins/tests/test-udev-rules.c b/plugins/tests/test-udev-rules.c new file mode 100644 index 00000000..369e22bb --- /dev/null +++ b/plugins/tests/test-udev-rules.c @@ -0,0 +1,164 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details: + * + * Copyright (C) 2016 Aleksander Morgado <aleksander@aleksander.es> + */ + +#include <glib.h> +#include <glib-object.h> +#include <string.h> +#include <stdio.h> +#include <locale.h> + +#define _LIBMM_INSIDE_MM +#include <libmm-glib.h> + +/* Define symbol to enable test message traces */ +#undef ENABLE_TEST_MESSAGE_TRACES + +#include "mm-kernel-device-generic-rules.h" +#include "mm-log.h" + +/************************************************************/ + +static void +common_test (const gchar *plugindir) +{ + GArray *rules; + GError *error = NULL; + + rules = mm_kernel_device_generic_rules_load (plugindir, &error); + g_assert_no_error (error); + g_assert (rules); + g_assert (rules->len > 0); + + g_array_unref (rules); +} + +/************************************************************/ + +static void +test_huawei (void) +{ + common_test (TESTUDEVRULESDIR_HUAWEI); +} + +static void +test_mbm (void) +{ + common_test (TESTUDEVRULESDIR_MBM); +} + +static void +test_nokia (void) +{ + common_test (TESTUDEVRULESDIR_NOKIA); +} + +static void +test_zte (void) +{ + common_test (TESTUDEVRULESDIR_ZTE); +} + +static void +test_longcheer (void) +{ + common_test (TESTUDEVRULESDIR_LONGCHEER); +} + +static void +test_simtech (void) +{ + common_test (TESTUDEVRULESDIR_SIMTECH); +} + +static void +test_x22x (void) +{ + common_test (TESTUDEVRULESDIR_X22X); +} + +static void +test_cinterion (void) +{ + common_test (TESTUDEVRULESDIR_CINTERION); +} + +static void +test_dell (void) +{ + common_test (TESTUDEVRULESDIR_DELL); +} + +static void +test_telit (void) +{ + common_test (TESTUDEVRULESDIR_TELIT); +} + +static void +test_mtk (void) +{ + common_test (TESTUDEVRULESDIR_MTK); +} + +static void +test_haier (void) +{ + common_test (TESTUDEVRULESDIR_HAIER); +} + +/************************************************************/ + +void +_mm_log (const char *loc, + const char *func, + guint32 level, + const char *fmt, + ...) +{ +#if defined ENABLE_TEST_MESSAGE_TRACES + /* Dummy log function */ + va_list args; + gchar *msg; + + va_start (args, fmt); + msg = g_strdup_vprintf (fmt, args); + va_end (args); + g_print ("%s\n", msg); + g_free (msg); +#endif +} + +int main (int argc, char **argv) +{ + setlocale (LC_ALL, ""); + + g_type_init (); + g_test_init (&argc, &argv, NULL); + + g_test_add_func ("/MM/test-udev-rules/huawei", test_huawei); + g_test_add_func ("/MM/test-udev-rules/mbm", test_mbm); + g_test_add_func ("/MM/test-udev-rules/nokia", test_nokia); + g_test_add_func ("/MM/test-udev-rules/zte", test_zte); + g_test_add_func ("/MM/test-udev-rules/longcheer", test_longcheer); + g_test_add_func ("/MM/test-udev-rules/simtech", test_simtech); + g_test_add_func ("/MM/test-udev-rules/x22x", test_x22x); + g_test_add_func ("/MM/test-udev-rules/cinterion", test_cinterion); + g_test_add_func ("/MM/test-udev-rules/dell", test_dell); + g_test_add_func ("/MM/test-udev-rules/telit", test_telit); + g_test_add_func ("/MM/test-udev-rules/mtk", test_mtk); + g_test_add_func ("/MM/test-udev-rules/haier", test_haier); + + return g_test_run (); +} |